/* ============================================================================
   STARE — Sistema de diseño "Tribuna"
   Jurisprudencia constitucional · Ecuador
   Una revista de derecho constitucional que resulta ser software.
   ========================================================================== */

:root{
  --bg:#0A0907; --bg-2:#0E0C09; --card:#1F1C16; --card-2:#191610;
  --hair:#2A251D; --hair-soft:#221E18;
  --ink:#EDE4CF; --ink-2:#A39782; --ink-3:#6F6552;
  --gold:#B98A2E; --gold-soft:#D9B05A; --gold-deep:#8A6420;
  --ox:#8B0E0E; --ox-bright:#B53030;
  --green:#1F6B3A; --green-bright:#3F9D61; --amber:#B88521; --amber-bright:#E0B24A;
  --serif:"Source Serif 4",Georgia,serif;
  --display:"Bodoni Moda",serif;
  --ui:"Manrope",sans-serif;
  --mono:"JetBrains Mono",monospace;
  --sidebar-w:272px;
  --radius:11px;
  --shadow:0 8px 30px rgba(0,0,0,.4);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--ink); font-family:var(--serif);
  font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased;
  display:flex; min-height:100vh; overflow-x:hidden;
}
body::before{ /* grain */
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body::after{ /* vignette atmosphere */
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
  background:radial-gradient(120% 90% at 75% 0%, rgba(185,138,46,.05), transparent 55%),
             radial-gradient(80% 80% at 0% 100%, rgba(139,14,14,.04), transparent 60%);
}
::selection{background:rgba(185,138,46,.28); color:#fff}
::-webkit-scrollbar{width:11px; height:11px}
::-webkit-scrollbar-track{background:var(--bg-2)}
::-webkit-scrollbar-thumb{background:#2c2820; border:3px solid var(--bg-2); border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#3a3528}
a{color:inherit; text-decoration:none}
button{font-family:inherit}

/* ============ SIDEBAR ============ */
.side{
  width:var(--sidebar-w); flex-shrink:0; background:linear-gradient(180deg,var(--bg-2),#0B0A08);
  border-right:1px solid var(--hair); height:100vh; position:sticky; top:0;
  display:flex; flex-direction:column; padding:30px 0 18px; z-index:50;
}
.brand{padding:0 28px 26px; border-bottom:1px solid var(--hair-soft)}
.wordmark{font-family:var(--display); font-weight:700; font-size:34px; letter-spacing:-.5px; color:var(--ink); line-height:1; cursor:pointer}
.wordmark .dot{color:var(--ox-bright)}
.tagline{font-family:var(--ui); font-size:9.5px; letter-spacing:2.5px; text-transform:uppercase; color:var(--ink-3); margin-top:9px; font-weight:600}
.nav{flex:1; overflow-y:auto; padding:22px 16px}
.nav-group{margin-bottom:26px}
.nav-label{font-family:var(--ui); font-size:10px; font-weight:700; letter-spacing:2.2px; color:var(--gold-deep); text-transform:uppercase; padding:0 12px 11px; display:flex; align-items:center; gap:8px}
.nav-label::after{content:""; flex:1; height:1px; background:linear-gradient(90deg,var(--hair),transparent)}
.nav-item{
  display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:8px; cursor:pointer;
  font-family:var(--ui); font-size:14px; font-weight:500; color:var(--ink-2); position:relative;
  transition:all .18s ease; margin-bottom:2px; border-left:2px solid transparent;
}
.nav-item .ico{width:17px; text-align:center; opacity:.8; font-size:14px}
.nav-item:hover{background:rgba(185,138,46,.06); color:var(--ink)}
.nav-item.active{background:linear-gradient(90deg,rgba(185,138,46,.14),rgba(185,138,46,.02)); color:var(--ink); border-left-color:var(--gold)}
.nav-item.sub{padding-left:34px; font-size:13.3px; color:var(--ink-3)}
.nav-item.sub:hover{color:var(--ink-2)}
.nav-item.sub.active{color:var(--ink)}
.lock{margin-left:auto; font-size:9px; font-family:var(--ui); font-weight:700; letter-spacing:.5px; color:var(--gold-deep); background:rgba(185,138,46,.1); padding:2px 7px; border-radius:5px; text-transform:uppercase}
.side-foot{padding:18px 28px 4px; border-top:1px solid var(--hair-soft)}
.plan-badge{display:flex; align-items:center; justify-content:space-between; background:var(--card-2); border:1px solid var(--hair); border-radius:9px; padding:11px 13px; margin-bottom:16px}
.plan-badge .p1{font-family:var(--ui); font-size:11px; color:var(--ink-2); font-weight:600}
.plan-badge .p2{font-family:var(--ui); font-size:11px; color:var(--bg); background:linear-gradient(90deg,var(--gold),var(--gold-soft)); padding:4px 9px; border-radius:6px; font-weight:700; cursor:pointer}
.corpus{font-family:var(--mono); font-size:10.5px; color:var(--ink-3); line-height:1.5}
.corpus b{color:var(--gold-deep)}
.maxim{font-family:var(--display); font-style:italic; font-size:11px; color:var(--ink-3); margin-top:9px; line-height:1.4}

/* ============ MAIN ============ */
.main{flex:1; min-width:0; position:relative; z-index:2; display:flex; flex-direction:column}
.topbar{
  display:flex; align-items:center; justify-content:space-between; padding:20px 46px; gap:18px;
  border-bottom:1px solid var(--hair); position:sticky; top:0; backdrop-filter:blur(12px);
  background:rgba(10,9,7,.82); z-index:40; min-height:69px;
}
.crumb{font-family:var(--ui); font-size:12.5px; color:var(--ink-3); display:flex; gap:9px; align-items:center; font-weight:500; flex-wrap:wrap}
.crumb b{color:var(--ink-2); font-weight:600}
.crumb .sep{color:var(--hair)}
.crumb a{cursor:pointer; transition:color .15s}
.crumb a:hover{color:var(--gold-soft)}
.actions{display:flex; gap:10px; flex-shrink:0}
.hamburger{display:none; background:var(--card); border:1px solid var(--hair); border-radius:8px; width:40px; height:40px; color:var(--ink-2); font-size:18px; cursor:pointer; align-items:center; justify-content:center}

.btn{font-family:var(--ui); font-weight:600; font-size:13px; padding:9px 16px; border-radius:8px; cursor:pointer; border:1px solid var(--hair); background:var(--card); color:var(--ink-2); transition:all .18s; display:inline-flex; align-items:center; gap:7px; white-space:nowrap}
.btn:hover{border-color:#3a3325; color:var(--ink); transform:translateY(-1px)}
.btn:disabled{opacity:.5; cursor:not-allowed; transform:none}
.btn.primary{background:linear-gradient(180deg,var(--gold),var(--gold-deep)); color:#1a1408; border:none; box-shadow:0 4px 16px rgba(185,138,46,.22)}
.btn.primary:hover{box-shadow:0 6px 22px rgba(185,138,46,.34)}
.btn.ox{background:linear-gradient(180deg,var(--ox-bright),var(--ox)); color:#fff; border:none}
.btn.sm{padding:6px 12px; font-size:12px}
.btn.ghost{background:transparent}

.content{padding:46px 46px 90px; max-width:980px; width:100%; margin:0 auto}
.content.wide{max-width:1180px}

/* entrance animation */
.rise{opacity:0; transform:translateY(16px); animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1; transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.21s}.d4{animation-delay:.29s}.d5{animation-delay:.37s}.d6{animation-delay:.45s}.d7{animation-delay:.53s}.d8{animation-delay:.61s}

/* headings */
.eyebrow{font-family:var(--ui); font-size:11px; font-weight:700; letter-spacing:2.6px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; display:flex; align-items:center; gap:10px}
.eyebrow::before{content:""; width:24px; height:1px; background:var(--gold); opacity:.6}
.title{font-family:var(--display); font-weight:700; font-size:48px; letter-spacing:-1px; line-height:1.04; color:var(--ink); margin-bottom:8px}
.title.lg{font-size:54px}
.subtitle{font-family:var(--mono); font-size:13px; color:var(--ink-3); margin-bottom:30px; letter-spacing:.5px}
.lede{font-family:var(--serif); font-size:18px; color:var(--ink-2); line-height:1.7; margin-bottom:34px; max-width:680px}

/* section */
.sec{margin-bottom:38px}
.sec-h{font-family:var(--ui); font-size:11px; font-weight:700; letter-spacing:2.4px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; display:flex; align-items:center; gap:9px}
.sec-h .hr{flex:1; height:1px; background:linear-gradient(90deg,var(--hair),transparent)}
.sec p{font-size:17px; line-height:1.78; color:var(--ink); font-weight:400}
.sec p + p{margin-top:14px}

/* cards & grids */
.card{background:var(--card-2); border:1px solid var(--hair); border-radius:var(--radius); padding:24px; transition:all .2s}
.card.hover:hover{border-color:var(--gold-deep); transform:translateY(-2px); box-shadow:var(--shadow)}
.grid{display:grid; gap:16px}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}

/* stat tiles (Inicio) */
.stat{background:var(--card-2); border:1px solid var(--hair); border-radius:var(--radius); padding:22px 24px}
.stat .sv{font-family:var(--display); font-weight:700; font-size:38px; color:var(--ink); line-height:1; letter-spacing:-.5px}
.stat .sv .u{font-size:15px; color:var(--ink-3); font-family:var(--ui); margin-left:6px}
.stat .sl{font-family:var(--ui); font-size:11px; letter-spacing:1.6px; text-transform:uppercase; color:var(--ink-3); font-weight:700; margin-top:10px}

/* quick-action cards (Inicio) */
.qa{background:var(--card-2); border:1px solid var(--hair); border-radius:var(--radius); padding:24px; cursor:pointer; transition:all .2s; display:flex; flex-direction:column; gap:10px; position:relative; overflow:hidden}
.qa::after{content:""; position:absolute; inset:0; background:linear-gradient(120deg,rgba(185,138,46,.07),transparent 60%); opacity:0; transition:opacity .25s}
.qa:hover{border-color:var(--gold-deep); transform:translateY(-3px); box-shadow:var(--shadow)}
.qa:hover::after{opacity:1}
.qa .qi{font-size:22px; color:var(--gold); position:relative}
.qa .qt{font-family:var(--display); font-weight:600; font-size:21px; color:var(--ink); position:relative}
.qa .qd{font-family:var(--ui); font-size:13px; color:var(--ink-2); line-height:1.55; position:relative}

/* ============ FORMS ============ */
.field{margin-bottom:20px}
.field > label, .lbl{display:block; font-family:var(--ui); font-size:11px; font-weight:700; letter-spacing:1.6px; text-transform:uppercase; color:var(--ink-2); margin-bottom:9px}
.field .hint{font-family:var(--ui); font-size:12px; color:var(--ink-3); margin-top:7px; line-height:1.5}
input[type=text], input[type=search], input[type=email], input[type=number], input[type=date], textarea, select{
  width:100%; background:var(--bg-2); border:1px solid var(--hair); border-radius:9px;
  color:var(--ink); font-family:var(--serif); font-size:15px; padding:12px 15px; transition:all .18s; outline:none;
}
textarea{resize:vertical; min-height:120px; line-height:1.65}
input:focus, textarea:focus, select:focus{border-color:var(--gold-deep); box-shadow:0 0 0 3px rgba(185,138,46,.1); background:#100E0A}
input::placeholder, textarea::placeholder{color:var(--ink-3)}
select{appearance:none; cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23A39782'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px}
.row{display:flex; gap:16px; flex-wrap:wrap}
.row > .field{flex:1; min-width:200px}

/* search bar (big) */
.searchbar{display:flex; gap:12px; margin-bottom:26px}
.searchbar .sw{flex:1; position:relative}
.searchbar .sw input{font-size:17px; padding:15px 18px 15px 46px; border-radius:11px}
.searchbar .sw::before{content:"⌕"; position:absolute; left:16px; top:50%; transform:translateY(-50%); color:var(--ink-3); font-size:18px}

/* filters */
.filters{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:30px; align-items:center}
.filter-chip{font-family:var(--ui); font-size:12.5px; font-weight:500; color:var(--ink-2); background:var(--card); border:1px solid var(--hair); padding:7px 14px; border-radius:30px; cursor:pointer; transition:all .18s; user-select:none}
.filter-chip:hover{border-color:var(--gold-deep); color:var(--ink)}
.filter-chip.on{background:rgba(185,138,46,.14); border-color:var(--gold); color:var(--gold-soft)}

/* pills (read-only tags) */
.pills{display:flex; flex-wrap:wrap; gap:9px; margin-bottom:34px}
.pill{font-family:var(--ui); font-size:12.5px; font-weight:500; color:var(--ink-2); background:var(--card); border:1px solid var(--hair); padding:7px 14px; border-radius:30px; transition:all .18s}
.pill:hover{border-color:var(--gold-deep); color:var(--gold-soft)}

/* ============ RESULT LIST (Buscar) ============ */
.results{display:flex; flex-direction:column; gap:14px}
.result{background:var(--card-2); border:1px solid var(--hair); border-radius:var(--radius); padding:20px 22px; cursor:pointer; transition:all .2s; border-left:4px solid var(--hair); position:relative}
.result:hover{border-color:var(--hair); border-left-color:var(--gold); transform:translateX(3px); box-shadow:var(--shadow)}
.result .r-top{display:flex; align-items:center; gap:12px; margin-bottom:9px; flex-wrap:wrap}
.result .r-id{font-family:var(--mono); font-size:13px; color:var(--gold-soft); font-weight:600}
.result .r-date{font-family:var(--ui); font-size:12px; color:var(--ink-3)}
.result .r-score{margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--ink-3)}
.result .r-title{font-family:var(--display); font-size:20px; color:var(--ink); font-weight:600; line-height:1.25; margin-bottom:8px}
.result .r-sum{font-family:var(--serif); font-size:14.5px; color:var(--ink-2); line-height:1.6; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.result .r-meta{display:flex; gap:8px; flex-wrap:wrap; margin-top:11px}
.result.fav{border-left-color:var(--green)}
.result.neg{border-left-color:var(--ox-bright)}

/* desenlace badge (small, inline) */
.badge{font-family:var(--ui); font-size:11px; font-weight:700; letter-spacing:.6px; text-transform:uppercase; padding:4px 10px; border-radius:6px; display:inline-flex; align-items:center; gap:5px}
.badge.fav{color:var(--green-bright); background:rgba(31,107,58,.14); border:1px solid rgba(31,107,58,.35)}
.badge.neg{color:#E8B9B9; background:rgba(139,14,14,.14); border:1px solid rgba(139,14,14,.35)}
.badge.warn{color:var(--amber-bright); background:rgba(184,133,33,.14); border:1px solid rgba(184,133,33,.35)}
.badge.neu{color:var(--ink-2); background:var(--card); border:1px solid var(--hair)}
.tag{font-family:var(--ui); font-size:11.5px; color:var(--ink-3); background:var(--card); border:1px solid var(--hair-soft); padding:3px 9px; border-radius:20px}

/* ============ FICHA ============ */
.verdict{
  border-radius:var(--radius); padding:20px 24px; margin-bottom:34px; display:flex; align-items:center; gap:18px;
  border:1px solid var(--hair); border-left:5px solid var(--ink-3);
}
.verdict.neg{background:linear-gradient(100deg,rgba(139,14,14,.16),rgba(139,14,14,.03) 60%,transparent); border-color:rgba(139,14,14,.3); border-left-color:var(--ox-bright)}
.verdict.fav{background:linear-gradient(100deg,rgba(31,107,58,.16),rgba(31,107,58,.03) 60%,transparent); border-color:rgba(31,107,58,.3); border-left-color:var(--green-bright)}
.verdict.warn{background:linear-gradient(100deg,rgba(184,133,33,.16),rgba(184,133,33,.03) 60%,transparent); border-color:rgba(184,133,33,.3); border-left-color:var(--amber-bright)}
.verdict .vmark{font-size:26px; line-height:1}
.verdict .vtext .vl{font-family:var(--ui); font-size:10.5px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-3); font-weight:700}
.verdict .vtext .vv{font-family:var(--display); font-weight:700; font-size:25px; letter-spacing:.3px; margin-top:3px}
.verdict.neg .vv{color:#E8B9B9}
.verdict.fav .vv{color:#A9D9BC}
.verdict.warn .vv{color:#E7CD8E}
.verdict.neu .vv{color:var(--ink)}

.meta{display:flex; gap:0; margin-bottom:30px; border:1px solid var(--hair); border-radius:var(--radius); overflow:hidden; background:var(--card-2); flex-wrap:wrap}
.meta .cell{flex:1; min-width:160px; padding:16px 22px; border-right:1px solid var(--hair-soft)}
.meta .cell:last-child{border-right:none}
.meta .ml{font-family:var(--ui); font-size:10px; letter-spacing:1.6px; text-transform:uppercase; color:var(--ink-3); font-weight:700; margin-bottom:6px}
.meta .mv{font-family:var(--serif); font-size:15px; color:var(--ink); font-weight:500}

.ratio{border-left:3px solid var(--gold); background:linear-gradient(100deg,rgba(185,138,46,.06),transparent 70%); padding:22px 28px; border-radius:0 10px 10px 0}
.ratio p{font-family:var(--serif); font-style:italic; font-size:18px; line-height:1.74; color:var(--ink)}

.chips{display:flex; flex-wrap:wrap; gap:10px}
.chip{font-family:var(--mono); font-size:12.5px; color:var(--gold-soft); background:var(--card); border:1px solid var(--hair); padding:8px 13px; border-radius:7px; cursor:pointer; transition:all .18s}
.chip:hover{background:rgba(185,138,46,.1); border-color:var(--gold-deep); transform:translateY(-1px)}
.chip .ar{color:var(--ink-3); margin-left:6px}

.cita{margin-top:14px; background:var(--bg-2); border:1px solid var(--hair); border-radius:10px; padding:18px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px}
.cita .ct{font-family:var(--mono); font-size:13px; color:var(--ink-2); line-height:1.5}
.cita .ct b{color:var(--ink)}
.copy{font-family:var(--ui); font-size:11.5px; font-weight:600; color:var(--gold); background:rgba(185,138,46,.1); border:1px solid var(--gold-deep); padding:7px 14px; border-radius:7px; cursor:pointer; white-space:nowrap; transition:all .18s}
.copy:hover{background:rgba(185,138,46,.2)}

.foot-note{margin-top:44px; padding-top:22px; border-top:1px solid var(--hair-soft); font-family:var(--ui); font-size:11.5px; color:var(--ink-3); line-height:1.6; display:flex; gap:10px; align-items:flex-start}
.foot-note .scale{color:var(--gold-deep); font-size:14px}

/* ============ GENERATED DOCUMENT OUTPUT ============ */
.doc-out{background:#100E0A; border:1px solid var(--hair); border-radius:var(--radius); padding:32px 36px; font-family:var(--serif); font-size:15.5px; line-height:1.85; color:var(--ink); white-space:pre-wrap; word-wrap:break-word; max-height:620px; overflow-y:auto}
.doc-out .complete{background:rgba(184,133,33,.16); color:var(--amber-bright); padding:1px 5px; border-radius:4px; font-family:var(--mono); font-size:13px}

/* diagnostico verdict box */
.diag{border-radius:var(--radius); padding:26px 30px; margin-bottom:26px; border:1px solid var(--hair); border-left:5px solid var(--ink-3)}
.diag.ok{border-left-color:var(--green-bright); background:linear-gradient(100deg,rgba(31,107,58,.1),transparent 70%)}
.diag.warn{border-left-color:var(--amber-bright); background:linear-gradient(100deg,rgba(184,133,33,.1),transparent 70%)}
.diag.bad{border-left-color:var(--ox-bright); background:linear-gradient(100deg,rgba(139,14,14,.1),transparent 70%)}
.diag .dv{font-family:var(--display); font-weight:700; font-size:30px; line-height:1.1; margin-bottom:6px}
.diag .dp{font-family:var(--ui); font-size:12px; letter-spacing:1.4px; text-transform:uppercase; color:var(--ink-2); font-weight:700}
.list{list-style:none; display:flex; flex-direction:column; gap:10px}
.list li{font-family:var(--serif); font-size:15px; line-height:1.6; color:var(--ink); padding-left:24px; position:relative}
.list li::before{content:"›"; position:absolute; left:4px; color:var(--gold); font-family:var(--display); font-weight:700}
.list.check li::before{content:"✓"; color:var(--green-bright); font-size:13px}
.list.warn li::before{content:"▲"; color:var(--amber-bright); font-size:11px}

/* ============ TABLE (casos / plazos) ============ */
.tbl{width:100%; border-collapse:collapse; background:var(--card-2); border:1px solid var(--hair); border-radius:var(--radius); overflow:hidden}
.tbl th{font-family:var(--ui); font-size:10.5px; letter-spacing:1.4px; text-transform:uppercase; color:var(--ink-3); font-weight:700; text-align:left; padding:14px 18px; border-bottom:1px solid var(--hair); background:var(--bg-2)}
.tbl td{font-family:var(--serif); font-size:14.5px; color:var(--ink); padding:15px 18px; border-bottom:1px solid var(--hair-soft)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(185,138,46,.03)}

/* ============ STATES ============ */
.empty{text-align:center; padding:70px 30px; color:var(--ink-3)}
.empty .ei{font-size:42px; color:var(--gold-deep); margin-bottom:18px; opacity:.7}
.empty .et{font-family:var(--display); font-size:24px; color:var(--ink-2); margin-bottom:10px}
.empty .ed{font-family:var(--ui); font-size:14px; color:var(--ink-3); max-width:420px; margin:0 auto; line-height:1.6}

.spinner{width:34px; height:34px; border:3px solid var(--hair); border-top-color:var(--gold); border-radius:50%; animation:spin .8s linear infinite; margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.loading{text-align:center; padding:64px 20px}
.loading .lt{font-family:var(--ui); font-size:13px; letter-spacing:1.5px; text-transform:uppercase; color:var(--ink-3); margin-top:20px; font-weight:600}
.skeleton{background:linear-gradient(90deg,var(--card-2),var(--card),var(--card-2)); background-size:200% 100%; animation:shimmer 1.4s infinite; border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* pro-gate / paywall */
.gate{text-align:center; padding:60px 40px; background:var(--card-2); border:1px solid var(--hair); border-radius:var(--radius); position:relative; overflow:hidden}
.gate::before{content:""; position:absolute; inset:0; background:radial-gradient(80% 60% at 50% 0%, rgba(185,138,46,.08), transparent 70%)}
.gate .gl{font-size:34px; color:var(--gold); margin-bottom:18px; position:relative}
.gate .gt{font-family:var(--display); font-size:28px; color:var(--ink); margin-bottom:12px; position:relative}
.gate .gd{font-family:var(--serif); font-size:16px; color:var(--ink-2); max-width:480px; margin:0 auto 26px; line-height:1.7; position:relative}

/* ============ TOAST ============ */
.toast-wrap{position:fixed; bottom:28px; right:28px; z-index:10000; display:flex; flex-direction:column; gap:10px}
.toast{background:var(--card); border:1px solid var(--hair); border-left:3px solid var(--gold); border-radius:9px; padding:13px 18px; font-family:var(--ui); font-size:13.5px; color:var(--ink); box-shadow:var(--shadow); min-width:220px; max-width:360px; animation:toastIn .3s cubic-bezier(.2,.7,.2,1)}
.toast.ok{border-left-color:var(--green-bright)}
.toast.err{border-left-color:var(--ox-bright)}
@keyframes toastIn{from{opacity:0; transform:translateX(30px)}to{opacity:1; transform:none}}

/* divider */
.divider{height:1px; background:linear-gradient(90deg,transparent,var(--hair),transparent); margin:38px 0}

/* ============ RESPONSIVE ============ */
.scrim{display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:45; backdrop-filter:blur(2px)}
@media (max-width:1080px){
  .grid.c4{grid-template-columns:repeat(2,1fr)}
  .grid.c3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .side{position:fixed; left:0; top:0; transform:translateX(-100%); transition:transform .28s cubic-bezier(.2,.7,.2,1); box-shadow:0 0 40px rgba(0,0,0,.6)}
  body.nav-open .side{transform:none}
  body.nav-open .scrim{display:block}
  .hamburger{display:inline-flex}
  .topbar{padding:16px 20px}
  .content{padding:32px 20px 80px}
  .actions .btn span.lbl{display:none}
  .actions .btn{padding:9px 12px}
  .title{font-size:38px}
  .title.lg{font-size:42px}
  .grid.c2, .grid.c3, .grid.c4{grid-template-columns:1fr}
  .meta{flex-direction:column}
  .meta .cell{border-right:none; border-bottom:1px solid var(--hair-soft)}
  .meta .cell:last-child{border-bottom:none}
  .crumb{font-size:11.5px}
  .toast-wrap{left:16px; right:16px; bottom:16px}
  .toast{max-width:none}
}
@media (max-width:560px){
  .topbar .actions{display:none}
  .searchbar{flex-direction:column}
  .doc-out{padding:22px 20px}
}
