/* ═══════════════════════════════════════════════════════════════
   ZeroFIR — Shared Stylesheet
   Tricolor: White · Deep Crimson · Ashoka Blue
   Fonts: Libre Baskerville · Outfit · DM Mono
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Outfit:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

:root {
  --red:#B91C1C; --red-deep:#7F1D1D; --red-mid:#DC2626;
  --red-pale:#FEF2F2; --red-brd:#FECACA; --red-lt:#FCA5A5;
  --blue:#1E3A8A; --blue-mid:#1D4ED8; --blue-pale:#EFF6FF;
  --blue-brd:#BFDBFE; --blue-lt:#93C5FD;
  --white:#FFFFFF; --off:#FAFAF8; --ink:#0F172A; --ink2:#1E293B;
  --muted:#64748B; --rule:#E2E8F0;
  --gold:#B45309; --gold-pale:#FFFBEB; --gold-brd:#FDE68A;
  --purple:#7C3AED; --prp-pale:#F5F3FF; --prp-brd:#DDD6FE;
  --green:#15803D; --green-pale:#F0FDF4; --green-brd:#BBF7D0;
  --r:12px; --rl:20px;
  --shadow:0 4px 24px rgba(15,23,42,.08);
  --shadow-lg:0 16px 56px rgba(15,23,42,.13);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--white);color:var(--ink);overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:'Outfit',sans-serif}
input,textarea,select{font-family:'Outfit',sans-serif;outline:none}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-thumb{background:var(--rule);border-radius:3px}

/* ─── TRICOLOR STRIPE ─── */
.tristripe{height:5px;position:fixed;top:0;left:0;right:0;z-index:300;
  background:linear-gradient(90deg,var(--red) 0%,var(--red) 33.33%,var(--white) 33.33%,var(--white) 66.66%,var(--blue) 66.66%,var(--blue) 100%)}

/* ─── NAV ─── */
.nav{position:fixed;top:5px;left:0;right:0;z-index:200;height:62px;
  background:rgba(255,255,255,.96);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--rule);padding:0 6%;
  display:flex;align-items:center;justify-content:space-between}
.nav-brand{display:flex;align-items:center;gap:12px;cursor:pointer}
.nav-emblem{width:38px;height:38px;border-radius:9px;background:var(--blue);
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.nav-emblem::after{content:'';position:absolute;bottom:0;left:0;right:0;height:35%;background:var(--red)}
.nav-emblem-z{font-family:'Libre Baskerville',serif;font-size:18px;font-weight:700;color:var(--white);position:relative;z-index:1}
.nav-name{font-family:'Libre Baskerville',serif;font-size:21px;font-weight:700;color:var(--ink)}
.nav-name em{color:var(--red);font-style:normal}
.nav-tag{font-size:10px;color:var(--muted);font-family:'DM Mono',monospace;letter-spacing:.5px;text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;gap:2px}
.nav-link{background:none;border:none;padding:8px 14px;font-size:14px;font-weight:500;color:var(--muted);border-radius:8px;transition:all .2s}
.nav-link:hover,.nav-link.active{background:var(--off);color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:10px}
.flag-mini{display:flex;height:24px;width:38px;border-radius:5px;overflow:hidden;border:1px solid var(--rule)}
.flag-s{flex:1}
.btn-nav-cta{padding:9px 22px;background:var(--red);color:var(--white);border:none;border-radius:8px;font-size:14px;font-weight:600;transition:all .2s}
.btn-nav-cta:hover{background:var(--red-deep);transform:translateY(-1px);box-shadow:0 6px 20px rgba(185,28,28,.3)}
.nav-hamburger{display:none;background:none;border:none;font-size:22px;color:var(--ink);padding:4px}
.mobile-menu{display:none;position:fixed;top:67px;left:0;right:0;z-index:199;
  background:var(--white);border-bottom:1px solid var(--rule);padding:10px 5%;flex-direction:column;gap:4px}
.mobile-menu.open{display:flex}
.mobile-menu .nav-link{text-align:left}

/* ─── PAGE PADDING ─── */
.page-body{padding-top:67px}

/* ─── BUTTONS ─── */
.btn-red{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;
  background:var(--red);color:var(--white);border:none;border-radius:var(--r);
  font-size:15px;font-weight:600;letter-spacing:.2px;transition:all .25s}
.btn-red:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 10px 32px rgba(185,28,28,.28)}
.btn-red .arr{transition:transform .2s}
.btn-red:hover .arr{transform:translateX(4px)}
.btn-red:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

.btn-blue-out{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;
  background:transparent;color:var(--blue);border:1.5px solid var(--blue);
  border-radius:var(--r);font-size:15px;font-weight:500;transition:all .25s}
.btn-blue-out:hover{background:var(--blue-pale)}

.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;
  background:transparent;color:var(--ink);border:1.5px solid var(--rule);
  border-radius:var(--r);font-size:14px;font-weight:500;transition:all .2s}
.btn-outline:hover{border-color:var(--ink);background:var(--off)}

.btn-white{padding:13px 28px;background:var(--white);color:var(--blue);
  border:none;border-radius:var(--r);font-size:15px;font-weight:600;transition:all .25s}
.btn-white:hover{background:var(--blue-pale);transform:translateY(-2px)}

.btn-ghost-w{padding:13px 22px;background:transparent;color:var(--white);
  border:1.5px solid rgba(255,255,255,.28);border-radius:var(--r);font-size:15px;font-weight:500;transition:all .25s}
.btn-ghost-w:hover{background:rgba(255,255,255,.1)}

/* ─── SECTION ─── */
.sec{padding:88px 6%}
.sec-off{background:var(--off)}
.sec-blue{background:var(--blue);padding:88px 6%}
.sec-ink{background:var(--ink)}
.sec-red-deep{background:var(--red-deep)}

.eyebrow{font-family:'DM Mono',monospace;font-size:11px;font-weight:500;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--red);
  margin-bottom:14px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--red)}
.eyebrow-lt{color:var(--blue-lt)}
.eyebrow-lt::before{background:var(--blue-lt)}
.eyebrow-center{justify-content:center}
.eyebrow-center::before{display:none}

.h2{font-family:'Libre Baskerville',serif;font-size:clamp(28px,3.4vw,46px);
  font-weight:700;color:var(--ink);line-height:1.13;letter-spacing:-1px;margin-bottom:16px}
.h2 em{color:var(--red);font-style:italic}
.h2-white{color:var(--white)}
.h2-white em{color:var(--red-lt)}
.h2-center{text-align:center}

.sub{font-size:17px;color:var(--muted);line-height:1.8;max-width:570px}
.sub-white{color:rgba(255,255,255,.55)}
.sub-center{text-align:center;margin:0 auto}

/* ─── CHIPS ─── */
.chip{display:inline-block;font-size:11px;font-family:'DM Mono',monospace;
  font-weight:500;padding:4px 10px;border-radius:6px;border:1px solid;white-space:nowrap}
.chip-r{background:var(--red-pale);color:var(--red-deep);border-color:var(--red-brd)}
.chip-b{background:var(--blue-pale);color:var(--blue);border-color:var(--blue-brd)}
.chip-g{background:var(--gold-pale);color:var(--gold);border-color:var(--gold-brd)}
.chip-p{background:var(--prp-pale);color:var(--purple);border-color:var(--prp-brd)}
.chip-gn{background:var(--green-pale);color:var(--green);border-color:var(--green-brd)}

/* ─── FORMS ─── */
.form-group{margin-bottom:18px}
.form-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;display:block;margin-bottom:6px}
.form-input,.form-textarea,.form-select{
  width:100%;background:var(--off);border:1.5px solid var(--rule);border-radius:var(--r);
  padding:11px 14px;font-size:14px;color:var(--ink);transition:border-color .2s}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--blue);background:var(--white)}
.form-textarea{resize:vertical;min-height:80px;line-height:1.6}

/* ─── TICKER ─── */
.ticker{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:14px 0;overflow:hidden;background:var(--off)}
.ticker-inner{display:flex;animation:tick 22s linear infinite;width:max-content}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tick-item{display:flex;align-items:center;gap:14px;padding:0 26px;font-size:15px;color:var(--muted);white-space:nowrap}
.tick-item b{color:var(--ink);font-weight:600}
.tick-sep{color:var(--red);font-weight:700;font-size:17px;opacity:.35}

/* ─── TYPING DOTS ─── */
.typing{display:flex;gap:4px;align-items:center;padding:4px 0}
.tydot{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:ty 1.2s infinite}
.tydot:nth-child(2){animation-delay:.2s}
.tydot:nth-child(3){animation-delay:.4s}
@keyframes ty{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-5px);opacity:1}}

/* ─── TOAST ─── */
.toast{position:fixed;bottom:24px;right:24px;z-index:9999;
  background:var(--ink);color:var(--white);padding:13px 20px;border-radius:var(--r);
  font-size:14px;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);
  display:flex;align-items:center;gap:10px;animation:slideUp .3s ease;max-width:360px}
.toast.success{background:var(--green)}
.toast.error{background:var(--red)}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ─── REVEAL ─── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.rv.vis{opacity:1;transform:translateY(0)}
.rv1{transition-delay:.1s}.rv2{transition-delay:.2s}.rv3{transition-delay:.3s}.rv4{transition-delay:.4s}

/* ─── FOOTER ─── */
.footer{background:var(--white);border-top:1px solid var(--rule);padding:56px 6% 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.fb-logo{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.fb-mark{width:32px;height:32px;background:var(--blue);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Libre Baskerville',serif;font-size:15px;font-weight:700;color:var(--white)}
.fb-name{font-family:'Libre Baskerville',serif;font-size:19px;font-weight:700;color:var(--ink)}
.fb-name em{color:var(--red);font-style:normal}
.fb-desc{font-size:13px;color:var(--muted);line-height:1.8;max-width:252px;margin-bottom:18px}
.ftri{display:flex;height:4px;width:72px;border-radius:2px;overflow:hidden;gap:1px}
.ftri-s{flex:1}
.fc-title{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--ink);margin-bottom:16px;font-family:'DM Mono',monospace}
.fl{display:block;font-size:13px;color:var(--muted);margin-bottom:9px;transition:color .2s;cursor:pointer}
.fl:hover{color:var(--red)}
.footer-bot{border-top:1px solid var(--rule);padding-top:22px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-bot p{font-size:12px;color:var(--muted);font-family:'DM Mono',monospace}
.fbadges{display:flex;gap:7px}
.fbadge{font-size:10px;font-family:'DM Mono',monospace;border:1px solid var(--rule);color:var(--muted);padding:3px 9px;border-radius:5px}

/* ═══════════════════════════════════════
   APP PAGE — Chat Interface
   ═══════════════════════════════════════ */
.app-layout{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start;padding:24px 4%}
.app-sidebar{background:var(--white);border:1px solid var(--rule);border-radius:var(--rl);overflow:hidden;position:sticky;top:84px}
.sidebar-top{background:var(--blue);padding:20px}
.sidebar-top-title{font-size:14px;font-weight:600;color:var(--white);margin-bottom:3px}
.sidebar-top-sub{font-size:12px;color:rgba(255,255,255,.5);font-family:'DM Mono',monospace}
.sidebar-body{padding:16px}
.stage-list{display:flex;flex-direction:column;gap:3px}
.stage-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;transition:background .2s}
.stage-item.active{background:var(--red-pale)}
.stage-item.done{background:var(--green-pale)}
.stage-icon{width:28px;height:28px;border-radius:50%;background:var(--off);
  border:1.5px solid var(--rule);display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;color:var(--muted);transition:all .3s}
.stage-item.active .stage-icon{background:var(--red);border-color:var(--red);color:var(--white)}
.stage-item.done  .stage-icon{background:var(--green);border-color:var(--green);color:var(--white)}
.stage-text{font-size:13px;color:var(--muted);line-height:1.4}
.stage-item.active .stage-text{color:var(--ink);font-weight:500}
.stage-item.done  .stage-text{color:var(--green)}
.progress-wrap{padding:16px;border-top:1px solid var(--rule)}
.progress-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:7px}
.progress-track{height:6px;background:var(--off);border-radius:3px;overflow:hidden}
.progress-fill{height:6px;background:var(--red);border-radius:3px;transition:width .6s ease;width:2%}
.sidebar-disclaimer{padding:14px 16px;border-top:1px solid var(--rule);
  font-size:11px;color:var(--muted);line-height:1.7;background:var(--off)}

/* Chat panel */
.chat-panel{background:var(--white);border:1px solid var(--rule);border-radius:var(--rl);
  overflow:hidden;display:flex;flex-direction:column;min-height:600px}
.chat-panel-top{background:var(--ink);padding:16px 20px;
  display:flex;align-items:center;justify-content:space-between}
.chat-panel-title{font-size:14px;font-weight:600;color:var(--white)}
.chat-lang-sel{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);font-family:'Outfit',sans-serif;font-size:12px;
  padding:5px 10px;border-radius:6px;cursor:pointer}
.chat-lang-sel option{color:var(--ink);background:var(--white)}
.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;min-height:400px;max-height:500px}
.msg{display:flex;gap:10px;max-width:88%}
.msg.msg-user{align-self:flex-end;flex-direction:row-reverse}
.msg.msg-ai{align-self:flex-start}
.msg-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;margin-top:3px}
.msg-ai .msg-av{background:var(--blue);color:var(--white);font-family:'DM Mono',monospace}
.msg-user .msg-av{background:var(--red);color:var(--white)}
.msg-bubble{padding:11px 15px;border-radius:12px;font-size:14px;line-height:1.65}
.msg-ai .msg-bubble{background:var(--off);color:var(--ink);border-bottom-left-radius:4px}
.msg-user .msg-bubble{background:var(--blue);color:var(--white);border-bottom-right-radius:4px}
.quick-chips{display:none;flex-wrap:wrap;gap:8px;padding:0 20px 12px}
.quick-chip{background:var(--white);border:1.5px solid var(--rule);border-radius:20px;
  padding:7px 16px;font-family:'Outfit',sans-serif;font-size:13px;cursor:pointer;
  transition:all .2s;color:var(--ink)}
.quick-chip:hover{border-color:var(--red);background:var(--red-pale);color:var(--red)}
.chat-input-row{padding:12px 16px;border-top:1px solid var(--rule);background:var(--white);display:flex;gap:10px;align-items:flex-end}
.chat-input{flex:1;background:var(--off);border:1.5px solid var(--rule);border-radius:10px;
  padding:10px 14px;font-size:14px;color:var(--ink);resize:none;min-height:42px;max-height:120px;
  transition:border-color .2s;line-height:1.5}
.chat-input:focus{border-color:var(--blue);background:var(--white)}
.send-btn{width:42px;height:42px;background:var(--blue);border:none;border-radius:10px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}
.send-btn:hover{background:var(--blue-mid)}
.send-btn:disabled{opacity:.4;cursor:not-allowed}
.send-btn svg{width:18px;height:18px;fill:var(--white)}

/* Welcome pane */
.welcome-pane{padding:28px 22px;display:flex;flex-direction:column;gap:20px}
.welcome-pane h2{font-family:'Libre Baskerville',serif;font-size:22px;font-weight:700;color:var(--ink)}
.welcome-pane p{font-size:14px;color:var(--muted);line-height:1.7}
.lang-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.lang-btn{background:var(--off);border:1.5px solid var(--rule);border-radius:10px;
  padding:10px 6px;text-align:center;cursor:pointer;transition:all .2s}
.lang-btn:hover,.lang-btn.sel{border-color:var(--red);background:var(--red-pale)}
.lang-btn .ln{font-size:16px;font-weight:700;color:var(--ink);display:block}
.lang-btn .le{font-size:10px;color:var(--muted);display:block;margin-top:2px}
.crime-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.crime-btn{background:var(--off);border:1.5px solid var(--rule);border-radius:9px;
  padding:10px 8px;text-align:center;cursor:pointer;transition:all .2s;
  font-family:'Outfit',sans-serif;font-size:12px;color:var(--ink);display:flex;flex-direction:column;gap:4px}
.crime-btn:hover,.crime-btn.sel{border-color:var(--blue);background:var(--blue-pale)}
.crime-btn .ci{font-size:20px}

/* FIR Output */
.hidden{display:none!important}
.fir-field{display:flex;flex-direction:column}
.fir-sec-list{display:flex;flex-direction:column}
.fir-sec-info{flex:1;min-width:0}
.fir-view{padding:24px;overflow-y:auto}
.fir-doc{border:1.5px solid var(--rule);border-radius:var(--rl);background:var(--white);overflow:hidden;margin-bottom:20px}
.fir-header{background:var(--blue);padding:22px 26px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.fir-stamp-title{font-family:'Libre Baskerville',serif;font-size:28px;font-weight:700;color:var(--white);letter-spacing:4px}
.fir-stamp-sub{font-size:13px;color:rgba(255,255,255,.65);margin-top:3px}
.fir-stamp-ref{font-size:11px;color:rgba(255,255,255,.45);margin-top:4px;font-family:'DM Mono',monospace}
.fir-header-right{text-align:right;flex-shrink:0}
.fir-section{padding:20px 24px;border-bottom:1px solid var(--rule)}
.fir-section:last-child{border-bottom:none}
.fir-section-title{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  font-family:'DM Mono',monospace;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid}
.fst-red{color:var(--red);border-color:var(--red-brd)}
.fst-blue{color:var(--blue);border-color:var(--blue-brd)}
.fir-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fir-field-full{grid-column:1/-1}
.fir-field-label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px;font-family:'DM Mono',monospace}
.fir-field-val{font-size:14px;color:var(--ink)}
.fir-narrative{background:var(--off);padding:16px;border-radius:9px;font-size:13px;line-height:1.85;color:var(--ink);border-left:3px solid var(--red)}
.fir-narrative p+p{margin-top:12px}
.fir-sec-row{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--rule);align-items:flex-start}
.fir-sec-row:last-child{border-bottom:none}
.fir-sec-badges{display:flex;flex-direction:column;gap:4px;flex-shrink:0;min-width:120px}
.fir-sec-name{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px}
.fir-sec-desc{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:6px}
.fir-sec-meta{display:flex;flex-wrap:wrap;gap:5px}
.fir-sec-punishment{font-size:11px;color:var(--red);font-style:italic;width:100%;margin-top:2px}
.fir-case-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;background:var(--off);border-radius:9px;padding:14px}
.fir-meta-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;font-family:'DM Mono',monospace;margin-bottom:3px}
.fir-meta-val{font-size:13px;font-weight:600;color:var(--ink)}
.fir-list-item{font-size:13px;color:var(--ink);padding:3px 0;line-height:1.5}
.fir-legal-note{margin:0 24px 20px;background:var(--gold-pale);border:1px solid var(--gold-brd);border-radius:9px;padding:14px 16px}
.fir-action-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:0 24px 20px}
.fac{background:var(--off);border:1px solid var(--rule);border-radius:var(--r);padding:18px;display:flex;gap:14px;align-items:flex-start;transition:all .2s}
.fac:hover{border-color:var(--blue);background:var(--blue-pale)}
.fac-icon{font-size:24px;flex-shrink:0}
.fac-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}
.fac-desc{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:8px}
.fac-link{font-size:13px;font-weight:600;color:var(--blue);transition:color .2s}
.fac-link:hover{color:var(--red)}
.fir-actions{display:flex;gap:10px;flex-wrap:wrap;margin:0 24px 16px}
.fir-disclaimer{font-size:11px;color:var(--muted);text-align:center;margin:0 24px 20px;line-height:1.7;padding:12px;background:var(--off);border-radius:8px}

/* ═══════════════════════════════════════
   KNOW YOUR RIGHTS PAGE
   ═══════════════════════════════════════ */
.rights-hero{background:var(--blue);padding:60px 6% 50px;text-align:center}
.rights-hero h1{font-family:'Libre Baskerville',serif;font-size:clamp(30px,4vw,50px);font-weight:700;color:var(--white);margin-bottom:14px}
.rights-hero p{font-size:17px;color:rgba(255,255,255,.6);max-width:520px;margin:0 auto}
.rights-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.rfbtn{padding:8px 18px;border-radius:20px;border:1.5px solid var(--rule);background:var(--white);font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;color:var(--ink)}
.rfbtn.active,.rfbtn:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}
.rights-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.right-card{background:var(--white);border:1px solid var(--rule);border-radius:var(--rl);padding:26px;transition:all .25s;cursor:pointer}
.right-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.right-card-icon{font-size:26px;margin-bottom:12px}
.right-card-tag{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;padding:3px 9px;border-radius:20px;margin-bottom:10px}
.tag-const{background:var(--blue-pale);color:var(--blue)}
.tag-crpc{background:var(--green-pale);color:var(--green)}
.tag-ipc{background:var(--red-pale);color:var(--red)}
.tag-it{background:var(--prp-pale);color:var(--purple)}
.tag-pocso{background:var(--gold-pale);color:var(--gold)}
.right-card h3{font-size:16px;font-weight:600;color:var(--ink);margin-bottom:8px}
.right-card p{font-size:13px;color:var(--muted);line-height:1.7}
.right-card-secs{display:flex;flex-wrap:wrap;gap:5px;margin-top:12px}
.rcs{font-family:'DM Mono',monospace;font-size:10px;background:var(--off);color:var(--muted);padding:3px 8px;border-radius:5px;border:1px solid var(--rule)}

/* ═══════════════════════════════════════
   POLICE STATION FINDER PAGE
   ═══════════════════════════════════════ */
.ps-hero{background:var(--blue);padding:50px 6%;text-align:center}
.ps-hero h1{font-family:'Libre Baskerville',serif;font-size:clamp(28px,4vw,46px);font-weight:700;color:var(--white);margin-bottom:12px}
.ps-hero p{font-size:16px;color:rgba(255,255,255,.55);max-width:480px;margin:0 auto 26px}
.ps-search{max-width:480px;margin:0 auto;display:flex;gap:10px}
.ps-search input{flex:1;padding:13px 18px;border-radius:10px;border:none;font-family:'Outfit',sans-serif;font-size:15px;outline:none;color:var(--ink)}
.ps-search button{padding:13px 20px;background:var(--red);color:var(--white);border:none;border-radius:10px;font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}
.ps-search button:hover{background:var(--red-deep)}
.ps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ps-card{background:var(--white);border:1px solid var(--rule);border-radius:var(--rl);padding:22px;transition:all .25s}
.ps-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.ps-type{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;padding:3px 10px;border-radius:20px;margin-bottom:12px}
.pst-local{background:var(--red-pale);color:var(--red)}
.pst-cyber{background:var(--blue-pale);color:var(--blue)}
.pst-women{background:var(--gold-pale);color:var(--gold)}
.pst-eco{background:var(--green-pale);color:var(--green)}
.ps-card h3{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px}
.ps-card-addr{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.ps-meta{display:flex;gap:12px;font-size:12px;color:var(--muted);margin-bottom:12px;flex-wrap:wrap}
.ps-actions{display:flex;gap:8px}
.psa-btn{flex:1;padding:8px;border-radius:8px;font-family:'Outfit',sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:5px;border:1px solid}
.psa-call{background:var(--green-pale);color:var(--green);border-color:var(--green-brd)}
.psa-dir{background:var(--blue-pale);color:var(--blue);border-color:var(--blue-brd)}
.psa-call:hover{background:#bbf7d0}
.psa-dir:hover{background:#bfdbfe}

/* ═══════════════════════════════════════
   PRINT STYLES
   ═══════════════════════════════════════ */
@media print {
  .tristripe,.nav,.app-sidebar,.fir-actions,.fir-action-cards,.fir-disclaimer,.mobile-menu{display:none!important}
  .chat-panel{box-shadow:none;border:none}
  .fir-view{padding:0}
  body{background:white}
  .fir-doc{border:1px solid #ccc}
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width:1024px){
  .app-layout{grid-template-columns:1fr}
  .app-sidebar{position:static}
  .rights-grid{grid-template-columns:1fr}
  .ps-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-hamburger{display:flex;align-items:center}
  .sec{padding:64px 5%}
  .sec-blue{padding:64px 5%}
  .footer-grid{grid-template-columns:1fr}
  .fir-fields-grid{grid-template-columns:1fr}
  .fir-action-cards{grid-template-columns:1fr}
  .fir-case-meta{grid-template-columns:1fr 1fr}
  .ps-grid{grid-template-columns:1fr}
  .lang-grid{grid-template-columns:repeat(4,1fr)}
  .crime-grid{grid-template-columns:repeat(2,1fr)}
  .rights-grid{grid-template-columns:1fr}
}
