/* ============================================================================
   FILE: /public_html/institutions/console/_institutions_console.css
   ROLE: Institutions Console CSS (addon, nonce-safe: no inline styles needed)
   INITIATED: 2026-01-15T00:00:00+00:00
   ----------------------------------------------------------------------------
   - Minimal, non-destructive styling for the console shell
   - Designed to sit on top of /css/ultimate.css without breaking global branding
   - UPDATED (Platform Range): 320px -> 4K, touch targets, safe-areas, fluid spacing
   ============================================================================ */

/* =======================
   Range tokens (addon-safe)
   ======================= */
:root{
  --inst-pad: clamp(12px, 2.2vw, 22px);
  --inst-gap: clamp(10px, 1.6vw, 16px);
  --inst-radius: clamp(14px, 1.4vw, 18px);
  --inst-maxw: 1260px;
  --inst-maxw-xl: 1400px;

  --inst-tap: 44px; /* touch target baseline */
  --inst-fs-label: clamp(12px, 1.1vw, 13px);
}

/* Make sure iOS doesn’t zoom inputs on focus */
input, select, textarea { font-size: 16px; }

/* Global box sizing sanity (addon-safe, non-destructive) */
*, *::before, *::after { box-sizing: border-box; }

.ximera-body { min-height: 100vh; }

/* Safe-area helper (use on wrappers if needed) */
.ximera-safe-area{
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}

.ximera-console-backdrop {
  position: fixed;
  inset: 0;
  background: radial-gradient(1200px 600px at 20% 20%, rgba(208,165,72,.14), rgba(0,0,0,0)),
              radial-gradient(900px 500px at 80% 10%, rgba(150,122,61,.10), rgba(0,0,0,0)),
              linear-gradient(180deg, #000000, #181715);
  z-index: 0;
}

.ximera-console-shell {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* =======================
   Topbar (sticky, mobile-safe)
   ======================= */
.ximera-console-topbar {
  position: sticky;
  top: 0;
  z-index: 2;
  backdrop-filter: blur(10px);
  background: rgba(0,0,0,.72);
  border-bottom: 1px solid rgba(208,165,72,.25);
  display: flex;
  justify-content: space-between;
  gap: var(--inst-gap);
  padding: calc(var(--inst-pad) - 2px) var(--inst-pad);
}

/* Ensure topbar actions wrap cleanly on small devices */
.ximera-console-topbar > * { min-width: 0; }

/* =======================
   Main container (range width)
   ======================= */
.ximera-console-main {
  flex: 1;
  padding: var(--inst-pad);
  padding-bottom: calc(var(--inst-pad) + 8px);
  width: 100%;
  max-width: var(--inst-maxw);
  margin: 0 auto;
}

.ximera-console-footer {
  border-top: 1px solid rgba(208,165,72,.25);
  background: rgba(0,0,0,.72);
  padding: calc(var(--inst-pad) - 2px) var(--inst-pad);
}

.ximera-console-footer-inner {
  max-width: var(--inst-maxw);
  margin: 0 auto;
}

/* Large screens: avoid UI floating in space */
@media (min-width: 1600px){
  .ximera-console-main,
  .ximera-console-footer-inner{
    max-width: var(--inst-maxw-xl);
  }
}

.ximera-banner-shell { margin-bottom: var(--inst-gap); }

.ximera-banner-ok,
.ximera-banner-err {
  border-radius: var(--inst-radius);
  padding: 10px 12px;
  border: 1px solid rgba(208,165,72,.25);
  background: rgba(0,0,0,.65);
}

.ximera-banner-ok { outline: 1px solid rgba(110, 214, 140, .25); }
.ximera-banner-err { outline: 1px solid rgba(255, 98, 98, .25); }

/* =======================
   Responsive grids (device-range)
   ======================= */
.ximera-grid-2,
.ximera-grid-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--inst-gap);
}

/* Tablet+ */
@media (min-width: 860px) {
  .ximera-grid-2 { grid-template-columns: 1fr 1fr; }
  .ximera-grid-3 { grid-template-columns: 1fr 1fr 1fr; }
}

/* Ultra small: keep spacing tight */
@media (max-width: 360px){
  :root{ --inst-pad: 12px; }
}

/* =======================
   Cards / layout primitives
   ======================= */
.ximera-card {
  border: 1px solid rgba(208,165,72,.18);
  border-radius: var(--inst-radius);
  background: rgba(0,0,0,.62);
}

.ximera-card-inner { padding: var(--inst-pad); }

.ximera-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ximera-row-between { justify-content: space-between; }

.ximera-stack { display: grid; gap: 10px; }

/* =======================
   Media preview blocks (range height)
   ======================= */
.ximera-media-preview {
  width: 100%;
  border-radius: var(--inst-radius);
  border: 1px dashed rgba(208,165,72,.25);
  background: rgba(0,0,0,.45);
  display: grid;
  place-items: center;
  overflow: hidden;
  margin: 10px 0 12px;
  min-height: clamp(140px, 22vw, 220px);
}

.ximera-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ximera-video {
  width: 100%;
  max-height: clamp(220px, 35vw, 420px);
  border-radius: var(--inst-radius);
  border: 1px solid rgba(208,165,72,.20);
  background: rgba(0,0,0,.6);
}

.ximera-empty {
  color: rgba(255,255,255,.72);
  padding: 18px;
  text-align: center;
}

/* Logo sizing scales gently */
.ximera-logo-wrap {
  width: clamp(76px, 9vw, 96px);
  height: clamp(76px, 9vw, 96px);
  border-radius: var(--inst-radius);
  border: 1px solid rgba(208,165,72,.20);
  background: rgba(0,0,0,.55);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.ximera-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.ximera-form { display: grid; gap: 10px; }
.ximera-label { font-size: var(--inst-fs-label); opacity: .9; }
.ximera-input { width: 100%; }

.ximera-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(208,165,72,.25);
  background: rgba(0,0,0,.55);
  font-size: 12px;
}

.ximera-muted { opacity: .78; }

/* =======================
   Public shell (range-safe)
   ======================= */
.ximera-public-topbar {
  background: rgba(0,0,0,.82);
  border-bottom: 1px solid rgba(208,165,72,.25);
  padding: calc(var(--inst-pad) - 2px) var(--inst-pad);
}

.ximera-public-topbar-inner {
  max-width: var(--inst-maxw);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: var(--inst-gap);
  align-items: center;
}

.ximera-public-main {
  max-width: var(--inst-maxw);
  margin: 0 auto;
  padding: var(--inst-pad);
  padding-bottom: calc(var(--inst-pad) + 8px);
}

.ximera-public-footer {
  border-top: 1px solid rgba(208,165,72,.25);
  background: rgba(0,0,0,.82);
  padding: calc(var(--inst-pad) - 2px) var(--inst-pad);
}

.ximera-public-footer-inner { max-width: var(--inst-maxw); margin: 0 auto; }

.ximera-hero {
  border-radius: var(--inst-radius);
  overflow: hidden;
  border: 1px solid rgba(208,165,72,.18);
  margin-bottom: var(--inst-gap);
  background: rgba(0,0,0,.55);
}

.ximera-hero-img { width: 100%; max-height: clamp(220px, 35vw, 420px); object-fit: cover; display: block; }

.ximera-card-link { color: inherit; text-decoration: none; display: block; }

/* =======================
   Institutions Console: Media controls
   ======================= */
.inst-media-actions { margin-top: 10px; display: grid; gap: 10px; }

.inst-media-row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap; /* mobile-friendly */
}

.inst-media-file { flex: 1 1 280px; min-width: 0; }
.inst-media-upload { flex: 0 0 auto; }

.inst-media-row-secondary { justify-content: flex-start; }

.inst-media-unlink,
.inst-media-danger { flex: 0 0 auto; }

/* “Danger ghost” without breaking brand */
.inst-media-danger {
  border-color: rgba(208,165,72,0.35);
  box-shadow: none;
  opacity: 0.95;
}
.inst-media-danger:hover {
  border-color: rgba(208,165,72,0.75);
  opacity: 1;
}

/* =======================
   Ensure Ximera buttons style <button> elements (not just <a>)
   + touch target baseline
   ======================= */
button.ximera-btn {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid rgba(208,165,72,.35);
  background: rgba(0,0,0,.55);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  line-height: 1;
  min-height: var(--inst-tap);
}

button.ximera-btn:hover {
  border-color: rgba(208,165,72,.75);
  background: rgba(0,0,0,.65);
}

button.ximera-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
}

button.ximera-btn-primary {
  background: rgba(208,165,72,.18);
  border-color: rgba(208,165,72,.75);
}

button.ximera-btn-primary:hover {
  background: rgba(208,165,72,.26);
}

button.ximera-btn-ghost {
  background: rgba(0,0,0,.35);
  border-color: rgba(208,165,72,.25);
}

/* =======================
   Motion safety
   ======================= */
@media (prefers-reduced-motion: reduce){
  *{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
