/* =====================================================================
   Shared styles — Justice for Gurdeep Singh Saluja
   One file controls the look of every page. Edit colours/fonts here once.
===================================================================== */

:root{
  --paper:#f6f2ea;
  --paper-2:#efe8da;
  --ink:#1c1814;
  --ink-soft:#4d453c;
  --ink-faint:#7c7266;
  --line:#d9cfbd;
  --line-strong:#c4b8a2;
  --accent:#8a2b2b;
  --accent-deep:#5d1c1c;
  --shadow:rgba(40,30,20,.10);
  --maxw:760px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Spectral',Georgia,serif;
  font-size:18px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:radial-gradient(var(--line) .5px,transparent .5px);
  background-size:4px 4px;mix-blend-mode:multiply;
}
.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 24px;}

a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(138,43,43,.35);}
a:hover{border-color:var(--accent);}

.kicker{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;}
.label{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.08;letter-spacing:-.01em;}

/* ---------- NAV ---------- */
.topbar{border-bottom:1px solid var(--line);background:rgba(246,242,234,.85);backdrop-filter:saturate(120%) blur(6px);position:sticky;top:0;z-index:30;}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:54px;flex-wrap:wrap;gap:6px;}
.topbar .brand{font-family:'Fraunces';font-size:16px;font-weight:600;border:none;}
.nav{display:flex;gap:4px;align-items:center;flex-wrap:wrap;}
.nav a{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border:none;padding:6px 9px;border-radius:2px;}
.nav a:hover{background:var(--paper-2);color:var(--ink);}
.nav a.active{color:var(--accent);}
.nav .share{background:var(--ink);color:var(--paper);cursor:pointer;border:none;}
.nav .share:hover{background:var(--accent-deep);color:var(--paper);}

/* ---------- BUTTONS ---------- */
.btn-row{display:flex;flex-wrap:wrap;gap:12px;}
.btn{font-family:'IBM Plex Mono',monospace;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;padding:13px 20px;border-radius:2px;cursor:pointer;border:1px solid var(--ink);background:var(--ink);color:var(--paper);transition:.15s;display:inline-flex;align-items:center;gap:8px;}
.btn:hover{background:var(--accent-deep);border-color:var(--accent-deep);}
.btn.ghost{background:transparent;color:var(--ink);}
.btn.ghost:hover{background:var(--ink);color:var(--paper);}

/* ---------- HERO ---------- */
.hero{padding:60px 0 40px;animation:rise .9s ease both;}
.hero .kicker{margin-bottom:22px;display:block;}
.portrait{width:148px;height:188px;object-fit:cover;border-radius:2px;border:1px solid var(--line-strong);box-shadow:0 14px 34px var(--shadow);filter:grayscale(.15) contrast(1.02);margin-bottom:26px;display:block;}
.portrait.placeholder{display:flex;align-items:center;justify-content:center;background:var(--paper-2);color:var(--ink-faint);font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.08em;text-align:center;padding:10px;line-height:1.5;}
.hero h1{font-size:clamp(40px,8.5vw,68px);margin-bottom:14px;}
.hero .dates{font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:.12em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:26px;}
.hero .dates .sep{color:var(--line-strong);margin:0 10px;}
.lede{font-size:clamp(21px,3.4vw,27px);line-height:1.45;font-weight:400;max-width:600px;}
.lede strong{color:var(--accent);font-weight:600;}

/* ---------- SECTIONS ---------- */
section{padding:46px 0;border-top:1px solid var(--line);}
section .kicker{margin-bottom:18px;display:block;}
section h2{font-size:clamp(27px,5vw,38px);margin-bottom:22px;}
p{margin-bottom:18px;color:var(--ink-soft);}
p.tight{color:var(--ink);}
.page-head{padding:54px 0 8px;}
.page-head h1{font-size:clamp(34px,7vw,54px);margin:14px 0 16px;}

/* ---------- TL;DR / PANELS ---------- */
.summary{background:var(--paper-2);border:1px solid var(--line);border-radius:3px;padding:28px 26px;}
.summary p:last-child{margin-bottom:0;}

/* ---------- EXPLORE TILES (home) ---------- */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.tile{display:block;border:1px solid var(--line-strong);background:var(--paper-2);border-radius:3px;padding:24px 22px;color:var(--ink);transition:.15s;}
.tile:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px);}
.tile:hover .tile-sub,.tile:hover .tile-arrow{color:var(--paper);}
.tile .tile-k{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}
.tile:hover .tile-k{color:#e0b3b3;}
.tile h3{font-size:23px;margin-bottom:8px;}
.tile .tile-sub{font-size:15px;color:var(--ink-faint);line-height:1.5;}
.tile .tile-arrow{font-family:'IBM Plex Mono',monospace;font-size:13px;margin-top:14px;display:inline-block;color:var(--accent);}

/* ---------- TIMELINE ---------- */
.tl{position:relative;margin-top:8px;padding-left:30px;}
.tl::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--line-strong);}
.tl-item{position:relative;padding-bottom:30px;}
.tl-item::before{content:"";position:absolute;left:-30px;top:6px;width:13px;height:13px;border-radius:50%;background:var(--paper);border:2px solid var(--accent);}
.tl-item.end::before{background:var(--accent);}
.tl-date{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.06em;color:var(--accent);margin-bottom:4px;}
.tl-item h3{font-size:20px;margin-bottom:6px;}
.tl-item p{font-size:16.5px;margin-bottom:0;}

/* ---------- RECORD CARDS ---------- */
.cards{display:grid;gap:16px;}
.card{border:1px solid var(--line);border-left:3px solid var(--accent);background:var(--paper-2);border-radius:3px;padding:22px 22px 20px;}
.card .src{margin-bottom:10px;display:block;}
.card h3{font-size:19px;margin-bottom:8px;}
.card p{font-size:16.5px;margin-bottom:0;}

/* ---------- STATUS BOX ---------- */
.status{border:1px solid var(--line-strong);border-radius:3px;overflow:hidden;}
.status .row{display:flex;border-bottom:1px solid var(--line);}
.status .row:last-child{border-bottom:none;}
.status .k{flex:0 0 130px;background:var(--paper-2);padding:14px 16px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);display:flex;align-items:center;}
.status .v{padding:14px 16px;font-size:16px;color:var(--ink);}

/* ---------- PDF READER ---------- */
.pdf-actions{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 18px;}
.pdf-frame{width:100%;height:82vh;min-height:540px;border:1px solid var(--line-strong);border-radius:3px;background:var(--paper-2);overflow:hidden;}
.pdf-frame iframe{width:100%;height:100%;border:none;}
.pdf-fallback{font-size:14px;color:var(--ink-faint);margin-top:12px;}

/* ---------- GALLERIES ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:6px;}
.gallery.docs{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}
.shot{position:relative;aspect-ratio:3/4;border:1px solid var(--line-strong);border-radius:2px;overflow:hidden;background:var(--paper-2);display:block;}
.shot img{width:100%;height:100%;object-fit:cover;display:block;}
.shot .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ink-faint);font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.06em;line-height:1.6;padding:12px;}
.shot .cap{position:absolute;left:0;right:0;bottom:0;background:rgba(28,24,20,.78);color:var(--paper);font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.04em;padding:7px 9px;line-height:1.4;}
.shot.graphic img{filter:blur(22px);transition:filter .35s;}
.shot.graphic.revealed img{filter:none;}
.cw{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:rgba(28,24,20,.74);color:var(--paper);cursor:pointer;text-align:center;padding:14px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.08em;line-height:1.6;transition:.25s;}
.shot.revealed .cw{opacity:0;pointer-events:none;}
.cw .warn{font-size:18px;}

/* ---------- CTA ---------- */
.cta-block{background:var(--ink);color:var(--paper);border-radius:4px;padding:40px 30px;text-align:center;}
.cta-block .kicker{color:#e0b3b3;}
.cta-block h2{color:var(--paper);margin-bottom:14px;}
.cta-block p{color:#cfc6b8;max-width:520px;margin:0 auto 26px;}
.cta-block .btn-row{justify-content:center;}
.cta-block .btn{background:var(--paper);color:var(--ink);border-color:var(--paper);}
.cta-block .btn:hover{background:var(--accent);color:var(--paper);border-color:var(--accent);}
.cta-block .btn.ghost{background:transparent;color:var(--paper);border-color:rgba(246,242,234,.4);}
.cta-block .btn.ghost:hover{background:var(--paper);color:var(--ink);}

/* ---------- DISCLAIMER + FOOTER ---------- */
.disclaimer{font-size:14px;line-height:1.65;color:var(--ink-faint);border:1px dashed var(--line-strong);border-radius:3px;padding:20px 22px;background:var(--paper);}
.disclaimer strong{color:var(--ink-soft);}
footer{padding:40px 0 70px;border-top:1px solid var(--line);text-align:center;}
footer .name{font-family:'Fraunces';font-size:22px;margin-bottom:6px;}
footer .label{display:block;margin-bottom:18px;}

@keyframes rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

#toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--paper);padding:12px 20px;border-radius:3px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.05em;opacity:0;pointer-events:none;transition:.3s;z-index:50;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

@media(max-width:560px){
  body{font-size:17px;}
  .tiles{grid-template-columns:1fr;}
  .status .k{flex-basis:104px;font-size:10px;}
  .nav a{padding:6px 7px;font-size:11px;}
}
