/* Disaster Risk Report — grounded field-almanac / risk-index aesthetic
   Bricolage Grotesque (display) + Public Sans (body) + IBM Plex Mono (data)
   Warm oat paper, ink, terracotta accent, green→amber→red risk scale */

:root {
  --paper: #f4efe4;
  --paper-2: #ece4d5;
  --card: #fbf8f1;
  --ink: #211d18;
  --ink-soft: #574f43;
  --ink-faint: #8b8070;
  --clay: #b8502e;
  --clay-deep: #97401f;
  --line: #ddd2bd;
  --line-soft: #e7decd;
  --r-vlow: #2f7d54;
  --r-low: #5a9663;
  --r-mod: #c2902b;
  --r-high: #cf5a2a;
  --r-vhigh: #b0242b;
  --shadow: rgba(33, 29, 24, 0.13);
}
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; font-family:'Public Sans',system-ui,sans-serif; background:var(--paper); color:var(--ink); font-size:16.5px; line-height:1.62; -webkit-font-smoothing:antialiased; }
.wrap { width:100%; max-width:1120px; margin:0 auto; padding:0 26px; }
a { color:var(--clay-deep); text-decoration:none; } a:hover { color:var(--ink); }
h1,h2,h3 { font-family:'Bricolage Grotesque','Public Sans',sans-serif; font-weight:700; letter-spacing:-0.015em; color:var(--ink); line-height:1.08; }
.mono { font-family:'IBM Plex Mono',ui-monospace,monospace; }

/* masthead */
.masthead { background:rgba(244,239,228,0.9); backdrop-filter:blur(7px); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:50; }
.masthead .wrap { display:flex; justify-content:space-between; align-items:center; padding:13px 26px; }
.brand { display:flex; align-items:center; gap:11px; }
.brand-mark { width:38px; height:38px; object-fit:contain; display:block; }
.brand-name { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:1.12rem; color:var(--ink); letter-spacing:-0.02em; }
.brand-dot { color:var(--clay); }
.nav-desktop { display:flex; gap:23px; align-items:center; }
.nav-desktop a { font-family:'Public Sans',sans-serif; font-weight:500; font-size:0.94rem; color:var(--ink-soft); }
.nav-desktop a:hover { color:var(--clay-deep); }
.nav-desktop a.nav-cta { color:#fff; background:var(--clay); padding:9px 16px; border-radius:7px; font-weight:600; }
.nav-desktop a.nav-cta:hover { color:#fff; background:var(--clay-deep); }
.nav-toggle { display:none; } .nav-mobile { display:none; }
@media (max-width:770px){
  .nav-desktop{display:none;}
  .nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;margin-right:-8px;background:none;border:0;cursor:pointer;padding:11px;}
  .nav-toggle span{display:block;height:2.5px;width:100%;background:var(--ink);border-radius:3px;transition:transform .25s,opacity .2s;}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
  .nav-mobile{display:block;border-top:1px solid var(--line);background:var(--paper);}
  .nav-mobile[hidden]{display:none;}
  .nav-mobile a{display:block;padding:15px 26px;font-size:1.05rem;font-weight:500;color:var(--ink);border-top:1px solid var(--line-soft);}
  .nav-mobile a.nav-mobile-cta{color:#fff;background:var(--clay);font-weight:700;}
}

/* hero */
.hero { position:relative; overflow:hidden; padding:60px 0 68px; border-bottom:1px solid var(--line);
  background:
    repeating-linear-gradient(0deg, transparent 0 33px, rgba(33,29,24,0.028) 33px 34px),
    var(--paper);
}
.hero .wrap { position:relative; }
.eyebrow { font-family:'IBM Plex Mono',monospace; font-size:0.72rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--clay-deep); font-weight:600; margin-bottom:15px; }
.hero h1 { font-size:clamp(2.3rem,5.4vw,3.85rem); margin:0 0 18px; max-width:15ch; }
.hero h1 em { font-style:normal; color:var(--clay); }
.lede { font-size:1.17rem; line-height:1.55; max-width:40ch; color:var(--ink-soft); margin:0 0 26px; }
.hero-grid { display:grid; grid-template-columns:1.02fr 0.98fr; gap:38px; align-items:start; }
@media (max-width:870px){ .hero-grid{grid-template-columns:1fr; gap:30px;} .lede{max-width:52ch;} }
.chips { display:flex; flex-wrap:wrap; gap:8px 17px; margin-top:22px; }
.chip { font-size:0.9rem; color:var(--ink-soft); display:inline-flex; align-items:center; gap:7px; }
.chip .dot { width:7px; height:7px; border-radius:2px; background:var(--clay); }

/* order card */
.order-card { background:var(--card); border:1px solid var(--line); border-radius:14px; padding:25px; box-shadow:0 22px 46px -26px var(--shadow); }
.order-card h2 { font-size:1.28rem; margin:0 0 4px; }
.order-card .sub { color:var(--ink-faint); font-size:0.92rem; margin:0 0 17px; }
.orderform label { display:block; font-weight:600; font-size:0.88rem; margin:13px 0 5px; color:var(--ink); }
.orderform label .opt { color:var(--ink-faint); font-weight:400; }
.orderform input { width:100%; padding:12px 13px; border:1.5px solid var(--line); border-radius:9px; font-size:1rem; font-family:inherit; background:var(--paper); color:var(--ink); }
.orderform input:focus { outline:none; border-color:var(--clay); box-shadow:0 0 0 3px rgba(184,80,46,0.16); background:#fff; }
.btn { display:inline-block; border:0; cursor:pointer; font-family:'Public Sans',sans-serif; font-weight:700; text-decoration:none; border-radius:9px; transition:transform .12s,box-shadow .2s,background .2s; }
.btn.primary { background:var(--clay); color:#fff; box-shadow:0 4px 0 var(--clay-deep); }
.btn.primary:hover { color:#fff; transform:translateY(1px); box-shadow:0 3px 0 var(--clay-deep); }
.btn.big { padding:15px 28px; font-size:1.04rem; }
.btn.ink { background:var(--ink); color:var(--paper); box-shadow:0 4px 0 #000; }
.btn.ink:hover { color:var(--paper); transform:translateY(1px); box-shadow:0 3px 0 #000; }
.submit-row { margin-top:19px; }
.submit-row .btn { width:100%; text-align:center; }
.subnote { display:block; text-align:center; font-size:0.82rem; color:var(--ink-faint); margin-top:10px; }
.order-status { margin-top:12px; padding:10px 13px; border-radius:8px; font-size:0.9rem; background:var(--paper-2); }
.order-status.err { background:#f7e4de; color:#8f2f18; }
.cta-row { display:flex; align-items:center; gap:17px; flex-wrap:wrap; }

/* sections */
section.band { padding:64px 0; border-bottom:1px solid var(--line); }
section.band.ink { background:var(--ink); color:#d9cfbf; }
section.band.ink h2 { color:var(--paper); } section.band.ink .intro { color:#c1b6a3; }
.kicker { font-family:'IBM Plex Mono',monospace; font-size:0.72rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--clay-deep); font-weight:600; }
section.band.ink .kicker { color:#e0a07f; }
.band h2 { font-size:clamp(1.7rem,3.3vw,2.5rem); margin:11px 0 14px; max-width:21ch; }
.band .intro { font-size:1.08rem; color:var(--ink-soft); max-width:62ch; margin:0 0 28px; }
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.card { background:var(--card); border:1px solid var(--line); border-radius:12px; padding:21px; }
section.band.ink .card { background:#2c2721; border-color:#40382e; }
.card .num { font-family:'IBM Plex Mono',monospace; color:var(--clay-deep); font-weight:600; font-size:0.78rem; }
section.band.ink .card .num { color:#e0a07f; }
.card h3 { font-size:1.12rem; margin:8px 0 6px; } section.band.ink .card h3 { color:var(--paper); }
.card p { margin:0; color:var(--ink-soft); font-size:0.95rem; } section.band.ink .card p { color:#c1b6a3; }
@media (max-width:800px){ .cards{grid-template-columns:1fr;} }

/* hazard grid (sample) */
.hazgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-top:6px; }
@media (max-width:600px){ .hazgrid{grid-template-columns:repeat(2,1fr);} }
.haz { background:var(--card); border:1px solid var(--line); border-radius:9px; padding:11px 13px; }
.haz .h-name { font-size:0.9rem; font-weight:600; color:var(--ink); }
.haz .h-rate { font-family:'IBM Plex Mono',monospace; font-size:0.76rem; font-weight:600; margin-top:3px; }
.r-vlow{color:var(--r-vlow);} .r-low{color:var(--r-low);} .r-mod{color:var(--r-mod);} .r-high{color:var(--r-high);} .r-vhigh{color:var(--r-vhigh);} .r-na{color:var(--ink-faint);}
.haz.hot { border-color:var(--r-high); }

/* sample card */
.sample { background:var(--card); border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:0 18px 38px -26px var(--shadow); }
.sample-head { background:var(--ink); color:var(--paper); padding:15px 20px; display:flex; justify-content:space-between; align-items:baseline; }
.sample-head .a { font-family:'Bricolage Grotesque',sans-serif; font-weight:600; font-size:0.98rem; }
.sample-head .p { font-family:'IBM Plex Mono',monospace; font-size:0.8rem; color:#e0a07f; }
.sample-body { padding:18px 20px; }
.sample-overall { display:flex; justify-content:space-between; align-items:baseline; padding-bottom:12px; border-bottom:1px solid var(--line-soft); margin-bottom:12px; }
.sample-overall .big { font-family:'Bricolage Grotesque',sans-serif; font-size:1.5rem; font-weight:700; }

/* article */
.article { max-width:720px; }
.article h2 { font-size:1.5rem; margin:30px 0 10px; } .article h3 { font-size:1.16rem; margin:22px 0 6px; }
.article p, .article li { color:var(--ink-soft); } .article ul { padding-left:1.2rem; }
.article a { text-decoration:underline; text-decoration-color:var(--clay); text-underline-offset:3px; }
.faq-q { font-family:'Bricolage Grotesque',sans-serif; font-weight:600; font-size:1.12rem; color:var(--ink); margin:24px 0 6px; }
.callout { background:var(--paper-2); border:1px solid var(--line); border-left:4px solid var(--clay); border-radius:10px; padding:15px 19px; margin:20px 0; }
.callout p { margin:0; color:var(--ink); }

/* footer */
.footer { background:var(--ink); color:#a99e8c; padding:48px 0 28px; }
.footer .wrap { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:28px; }
@media (max-width:700px){ .footer .wrap{grid-template-columns:1fr; gap:22px;} .footer{padding:38px 0 24px;} }
.footer h4 { font-family:'IBM Plex Mono',monospace; font-size:0.7rem; letter-spacing:0.15em; text-transform:uppercase; color:#e0a07f; margin:0 0 11px; }
.footer a { display:block; color:#a99e8c; padding:3px 0; } .footer a:hover { color:var(--paper); }
.foot-brand { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:1.14rem; color:var(--paper); }
.foot-bottom { grid-column:1/-1; border-top:1px solid #40382e; margin-top:20px; padding-top:17px; font-size:0.82rem; color:#7d7362; }

/* address autocomplete */
.ac-wrap { position:relative; }
.ac-list { position:absolute; left:0; right:0; top:calc(100% + 4px); z-index:40; list-style:none; margin:0; padding:6px; background:#fff; border:1.5px solid var(--line); border-radius:10px; box-shadow:0 18px 40px -22px var(--shadow); max-height:290px; overflow:auto; }
.ac-item { padding:10px 12px; border-radius:7px; font-size:0.93rem; cursor:pointer; color:var(--ink-soft); }
.ac-item:hover, .ac-item.active { background:var(--paper-2); color:var(--ink); }
