/* Shheletar — site styles (kit-local). Tokens come from ds/styles.css.
   Warm civic newsprint, rubber-stamp red for curfew breaches, scope-green. */

*{ box-sizing:border-box; }
.mk-site{ background:var(--paper); color:var(--ink); }
.mk-container{ max-width:var(--content-max); margin:0 auto; padding:0 var(--s-6); }

/* ---- Logo lockup ---- */
.mk-logo{ display:inline-flex; align-items:center; gap:var(--s-3); text-decoration:none; }
.mk-logo__word{ display:flex; flex-direction:column; gap:1px; line-height:1; }
.mk-logo__name{ font-family:var(--font-display); font-weight:var(--w-bold); font-size:1.4rem; letter-spacing:-.02em; color:var(--green); }
.mk-logo__name b{ color:var(--stamp); }
.mk-logo__sub{ font-family:var(--font-mono); font-size:.5rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint); white-space:nowrap; }

/* ---- Nav ---- */
.mk-nav{ position:sticky; top:0; z-index:20; background:color-mix(in srgb,var(--paper) 88%,transparent); backdrop-filter:blur(8px); border-bottom:var(--bw-hair) solid var(--border); }
.mk-nav__inner{ display:flex; align-items:center; justify-content:space-between; height:68px; gap:var(--s-5); }
.mk-nav__links{ display:flex; gap:var(--s-6); }
.mk-nav__links a{ font-family:var(--font-serif); font-size:var(--t-small); color:var(--ink-soft); text-decoration:none; }
.mk-nav__links a:hover,.mk-nav__links a.is-active{ color:var(--green-deep); }
.mk-nav__cta{ display:flex; align-items:center; gap:var(--s-2); }
.mk-nav__cta .shh-btn--ghost{ display:none; }

/* ---- Mobile menu (no-JS <details>; revealed ≤720px) ---- */
.mk-menu{ display:none; }
.mk-menu__btn{ display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px;
  border:var(--bw-hair) solid var(--border-strong); border-radius:var(--r-sm); background:var(--paper-panel);
  color:var(--ink-soft); cursor:pointer; list-style:none; -webkit-tap-highlight-color:transparent; }
.mk-menu__btn::-webkit-details-marker{ display:none; }
.mk-menu__btn:hover{ color:var(--green-deep); }
.mk-menu__panel{ position:absolute; right:0; top:100%; margin-top:var(--s-2); min-width:220px;
  display:flex; flex-direction:column; background:var(--paper-panel); border:var(--bw-hair) solid var(--border-strong);
  border-radius:var(--r-md); box-shadow:var(--shadow-md); padding:var(--s-2); z-index:30; }
.mk-menu__panel a{ font-family:var(--font-serif); font-size:var(--t-small); color:var(--ink-soft); text-decoration:none;
  padding:var(--s-3) var(--s-3); border-radius:var(--r-sm); min-height:44px; display:flex; align-items:center; }
.mk-menu__panel a:hover,.mk-menu__panel a.is-active{ color:var(--green-deep); background:var(--paper-deep); }
.mk-menu__act{ margin-top:var(--s-1); border-top:var(--bw-hair) solid var(--rule); color:var(--green-deep)!important; font-weight:var(--w-semibold); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding:var(--s-8) 0 var(--s-8); border-bottom:var(--bw-hair) solid var(--border); }
.hero__grid{ display:grid; grid-template-columns:0.92fr 1.08fr; gap:var(--s-8); align-items:center; min-width:0; }
.hero__grid > *{ min-width:0; }
.hero__title{ font-family:var(--font-display); font-weight:var(--w-bold); font-size:clamp(2.5rem,4.2vw,3.7rem); line-height:1.04; letter-spacing:-.025em; margin:var(--s-4) 0 var(--s-4); color:var(--ink); text-wrap:balance; }
.hero__title b{ color:var(--green); }
.hero__lede{ font-family:var(--font-serif); font-size:var(--t-lede); line-height:1.45; color:var(--ink-soft); max-width:42ch; margin:0 0 var(--s-6); text-wrap:pretty; }

/* signup */
.signup{ display:flex; align-items:flex-end; gap:var(--s-3); max-width:460px; }
.signup__field{ flex:1; }
.signup__note{ font-family:var(--font-mono); font-size:var(--t-caption); color:var(--ink-faint); margin:var(--s-3) 0 0; letter-spacing:.01em; }
.signup__ok{ font-family:var(--font-serif); font-size:var(--t-small); color:var(--green-deep); margin:var(--s-3) 0 0; }
.signup__ok b{ color:var(--green); }

/* ---- Approach scene (synthetic hero backdrop: planes landing at Seletar) ---- */
.scope{ position:relative; background:var(--paper-deep); border:var(--bw-rule) solid var(--border-strong); border-radius:var(--r-lg); box-shadow:var(--shadow-md); overflow:hidden; min-width:0; }
.scope__svg{ display:block; width:100%; max-width:100%; height:auto; }
.scope__sel{ font-family:var(--font-mono); font-size:13px; font-weight:var(--w-bold); letter-spacing:.1em; fill:var(--green-deep); }
.scope__plane{ filter:drop-shadow(0 1px 1px rgba(33,31,26,.18)); }
.scope__sg{ fill:var(--green-deep); opacity:.07; }
.scope__ring{ fill:none; stroke:var(--green-bright); stroke-width:1; opacity:.16; }
.scope__pulse{ stroke:var(--green-bright); stroke-width:1.5; }

/* hero note replacing the old signup line */
.hero__note{ font-family:var(--font-mono); font-size:var(--t-caption); color:var(--ink-faint); margin:var(--s-4) 0 0; letter-spacing:.01em; }
.hero__note a{ color:var(--green-deep); }

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.section{ padding:var(--s-9) 0; }
.section--sunk{ background:var(--paper-deep); border-top:var(--bw-hair) solid var(--border); border-bottom:var(--bw-hair) solid var(--border); }
.section__title{ font-family:var(--font-display); font-weight:var(--w-bold); font-size:var(--t-h1); line-height:1.08; letter-spacing:-.02em; margin:var(--s-3) 0 0; max-width:20ch; color:var(--ink); text-wrap:balance; }
.section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--s-5); margin-bottom:var(--s-7); }
.section__sub{ font-family:var(--font-serif); font-size:var(--t-body); color:var(--ink-soft); max-width:52ch; margin:var(--s-4) 0 0; text-wrap:pretty; }

/* ---- How it works ---- */
.how__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-6); }
.how__step{ border-top:var(--bw-strong) solid var(--green); padding-top:var(--s-4); }
.how__num{ font-family:var(--font-mono); font-weight:var(--w-bold); font-size:var(--t-h3); color:var(--green-bright); }
.how__t{ font-family:var(--font-display); font-size:var(--t-h3); margin:var(--s-3) 0 var(--s-2); color:var(--ink); }
.how__d{ font-family:var(--font-serif); font-size:var(--t-body); color:var(--ink-soft); line-height:1.5; text-wrap:pretty; }
.how__note{ margin-top:var(--s-7); display:flex; gap:var(--s-4); align-items:flex-start; padding:var(--s-5); background:var(--paper-panel); border:var(--bw-hair) solid var(--border-strong); border-left:var(--bw-strong) solid var(--amber); border-radius:var(--r-md); }
.how__note svg{ color:var(--amber-deep); flex:none; margin-top:2px; }
.how__note p{ margin:0; font-family:var(--font-serif); font-size:var(--t-small); color:var(--ink-soft); line-height:1.55; max-width:80ch; }
.how__note b{ color:var(--ink); }
.how__note-body{ min-width:0; }
.how__fn-ref{ text-decoration:none; color:var(--amber-deep); font-weight:var(--w-bold); }
.how__fn-ref sup{ font-size:.72em; padding-left:1px; }
.how__note .how__fn{ margin-top:var(--s-3); font-family:var(--font-mono); font-size:var(--t-caption); color:var(--ink-faint); line-height:1.5; }
.how__note .how__fn a{ color:inherit; text-decoration:underline; text-underline-offset:2px; }
.how__note .how__fn a:hover{ color:var(--amber-deep); }

/* ============================================================
   RECENT MOVEMENTS — violation cards with route map
   ============================================================ */
.recent__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-5); }
.vcard{ display:flex; flex-direction:column; background:var(--paper-panel); border:var(--bw-hair) solid var(--border); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); text-decoration:none; color:inherit; transition:border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out); }
.vcard:hover{ border-color:var(--green); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.vcard__top{ display:flex; align-items:flex-start; justify-content:space-between; gap:var(--s-3); padding:var(--s-4) var(--s-4) var(--s-3); }
.vcard__time{ display:flex; flex-direction:column; gap:.2em; }
.vcard__time b{ font-family:var(--font-mono); font-weight:var(--w-bold); font-size:1.5rem; line-height:1.05; color:var(--stamp); font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.vcard__time span{ font-family:var(--font-mono); font-size:10px; letter-spacing:.06em; color:var(--ink-faint); text-transform:uppercase; }
.vcard__past{ display:flex; flex-direction:column; align-items:flex-end; gap:var(--s-2); }
.vcard__pastnum{ text-align:right; }
.vcard__past b{ font-family:var(--font-mono); font-weight:var(--w-bold); font-size:var(--t-body); color:var(--stamp); font-variant-numeric:tabular-nums; }
.vcard__past span{ display:block; font-family:var(--font-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); }
.vcard__id{ padding:0 var(--s-4) var(--s-3); border-bottom:var(--bw-hair) solid var(--rule); }
.vcard__tail{ font-family:var(--font-mono); font-weight:var(--w-bold); font-size:var(--t-body); letter-spacing:.04em; color:var(--ink); }
.vcard__meta{ font-family:var(--font-serif); font-size:var(--t-caption); color:var(--ink-faint); margin-top:2px; }
.vcard__body{ display:flex; gap:var(--s-4); padding:var(--s-4); align-items:center; }
.vcard__rows{ flex:1; display:flex; flex-direction:column; }
.vcard__rows > div{ display:flex; justify-content:space-between; gap:var(--s-3); padding:var(--s-2) 0; border-bottom:var(--bw-hair) solid var(--rule); font-family:var(--font-mono); font-size:var(--t-caption); }
.vcard__rows > div:last-child{ border-bottom:0; }
.vcard__rows span{ color:var(--ink-faint); }
.vcard__rows b{ color:var(--ink); font-variant-numeric:tabular-nums; text-align:right; }

/* ---- Route map ---- */
.rm{ flex:none; width:128px; }
.rm--compact{ width:96px; }
.rm__svg{ display:block; width:100%; height:auto; border:var(--bw-hair) solid var(--border-strong); border-radius:var(--r-sm); }
.rm__ends{ display:flex; align-items:center; justify-content:center; gap:.4em; margin-top:4px; font-family:var(--font-mono); font-size:9px; letter-spacing:.06em; color:var(--ink-faint); }
.rm__ends .rm__arrow{ color:var(--stamp); }

.recent__foot{ display:flex; align-items:center; justify-content:space-between; gap:var(--s-4); margin-top:var(--s-6); }
.recent__note{ font-family:var(--font-mono); font-size:var(--t-caption); color:var(--ink-faint); }

/* ============================================================
   OFFENDERS
   ============================================================ */
.offenders__cols{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-6); align-items:start; }
.offenders__col{ display:flex; flex-direction:column; gap:var(--s-3); min-width:0; }
.offenders__collabel{ display:block; }
.shh-off--port{ grid-template-columns:auto 1fr auto; }
/* offender_row is an <a>: keep the grid layout, drop the link chrome, add affordance. */
.shh-off--link{ text-decoration:none; color:inherit; }
.shh-off--link:hover .shh-off__tail{ color:var(--green-deep); }
.offenders__foot{ font-family:var(--font-mono); font-size:var(--t-caption); color:var(--ink-faint); margin-top:var(--s-4); }

/* ============================================================
   THE RECORD teaser
   ============================================================ */
.record__grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-8); align-items:center; }
.record__d{ font-family:var(--font-serif); font-size:var(--t-body); color:var(--ink-soft); margin:var(--s-4) 0; line-height:1.55; text-wrap:pretty; }
.record__list{ list-style:none; padding:0; margin:0 0 var(--s-6); display:flex; flex-direction:column; gap:var(--s-2); }
.record__list li{ font-family:var(--font-serif); font-size:var(--t-small); color:var(--ink-soft); padding-left:var(--s-4); position:relative; }
.record__list li::before{ content:""; position:absolute; left:0; top:.62em; width:6px; height:6px; background:var(--stamp); border-radius:1px; }
.record__acts{ display:flex; gap:var(--s-3); }
.record__doc{ position:relative; background:var(--paper-panel); border:var(--bw-hair) solid var(--border-strong); border-top:4px solid var(--green); border-radius:var(--r-sm); box-shadow:var(--shadow-md); padding:var(--s-6); }
.record__stamp{ position:absolute; right:var(--s-5); top:var(--s-5); pointer-events:none; }
.record__dochead{ display:flex; flex-direction:column; gap:var(--s-1); padding-bottom:var(--s-4); border-bottom:var(--bw-rule) solid var(--ink); margin-bottom:var(--s-4); }
.record__docname{ font-family:var(--font-display); font-weight:var(--w-bold); font-size:1.4rem; color:var(--green); letter-spacing:-.02em; }
.record__docname b{ color:var(--stamp); }
.record__docsub{ font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.record__mini{ width:100%; border-collapse:collapse; font-family:var(--font-mono); font-size:11px; font-variant-numeric:tabular-nums; }
.record__mini th{ text-align:left; font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); padding:0 var(--s-2) var(--s-2); border-bottom:var(--bw-rule) solid var(--ink); }
.record__mini td{ padding:var(--s-2); border-bottom:var(--bw-hair) solid var(--rule); color:var(--ink-soft); white-space:nowrap; }
.record__mini .t{ color:var(--stamp); font-weight:var(--w-bold); }
.record__mini .tail{ color:var(--ink); font-weight:var(--w-semibold); }

/* ============================================================
   CTA + Footer
   ============================================================ */
.cta{ background:var(--green); color:var(--paper); }
.cta__inner{ display:flex; align-items:center; gap:var(--s-7); padding:var(--s-8) var(--s-6); }
.cta__inner > .cta__copy{ flex:1; }
.cta__title{ font-family:var(--font-display); color:var(--paper); font-size:var(--t-h1); margin:0; letter-spacing:-.02em; }
.cta__d{ color:var(--green-line); font-family:var(--font-serif); font-size:var(--t-lede); margin:var(--s-3) 0 var(--s-5); max-width:46ch; }
.cta__form{ display:flex; gap:var(--s-3); max-width:520px; align-items:flex-end; }
.cta__form .signup__field{ flex:1; }
.cta__ok{ color:#e9b9a6; font-family:var(--font-serif); font-size:var(--t-body); margin:0; }
.cta .shh-field__label{ color:var(--green-line); }
.cta .shh-input{ background:color-mix(in srgb,var(--paper) 12%,var(--green-deep)); border-color:color-mix(in srgb,var(--green-line) 40%,transparent); box-shadow:none; }
.cta .shh-input input{ color:var(--paper); }
.cta .shh-input input::placeholder{ color:color-mix(in srgb,var(--green-line) 80%,transparent); }
.cta__note{ color:color-mix(in srgb,var(--green-line) 80%,transparent); font-family:var(--font-mono); font-size:var(--t-caption); margin:var(--s-3) 0 0; }

.mk-footer{ background:var(--green-deep); color:var(--green-line); padding:var(--s-8) 0 var(--s-6); }
.mk-footer__inner{ display:flex; justify-content:space-between; gap:var(--s-7); padding-bottom:var(--s-7); border-bottom:var(--bw-hair) solid color-mix(in srgb,var(--green-line) 22%,transparent); }
.mk-footer__cols{ display:flex; gap:var(--s-8); }
.mk-footer__cols > div{ display:flex; flex-direction:column; gap:var(--s-2); }
.mk-footer__cols span{ font-family:var(--font-mono); font-size:var(--t-eyebrow); letter-spacing:.16em; text-transform:uppercase; color:var(--paper); margin-bottom:var(--s-1); }
.mk-footer__cols a{ font-family:var(--font-serif); font-size:var(--t-small); color:var(--green-line); text-decoration:none; }
.mk-footer__cols a:hover{ color:var(--paper); }
.mk-footer__legal{ display:flex; justify-content:space-between; gap:var(--s-5); padding-top:var(--s-5); font-family:var(--font-mono); font-size:var(--t-caption); color:color-mix(in srgb,var(--green-line) 70%,transparent); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .hero__grid,.record__grid{ grid-template-columns:1fr; }
  .recent__grid{ grid-template-columns:repeat(2,1fr); }
  .offenders__cols{ grid-template-columns:1fr; }
  .how__grid{ grid-template-columns:1fr; }
  .cta__inner{ flex-direction:column; align-items:flex-start; }
}
@media(max-width:720px){
  .mk-nav__links{ display:none; }
  .mk-nav__cta{ display:none; }
  .mk-menu{ display:block; position:relative; }
  .recent__grid{ grid-template-columns:1fr; }
  .section__head{ flex-direction:column; align-items:flex-start; }
  .hero{ padding:var(--s-7) 0; }
  .section{ padding:var(--s-8) 0; }
  .cta__inner{ gap:var(--s-5); padding:var(--s-7) 0; }
  .cta__form{ flex-direction:column; align-items:stretch; gap:var(--s-4); }
  .signup{ flex-direction:column; align-items:stretch; gap:var(--s-4); }
  .signup__field{ max-width:none; }
  .mk-footer__inner{ flex-direction:column; gap:var(--s-6); }
  .mk-footer__cols{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-5) var(--s-6); }
  .mk-footer__legal{ flex-direction:column; gap:var(--s-3); }
  .record__acts{ flex-wrap:wrap; }
}
@media(max-width:480px){
  .mk-container{ padding:0 var(--s-4); }
}
