/* ============================================================
   HulloShips Exchange — owner-direct vessel marketplace
   Aesthetic: "Deep-Ocean Editorial" — ivory paper, deep harbour
   teal, nautical brass, Cormorant Garamond display. Built on the
   OFS component system, reskinned to the HulloShips brand.
   ============================================================ */
:root{
  --ink:#13282c; --ink-soft:#33474b; --mute:#62787c;
  --jade:#0d6e74; --jade-deep:#063b46; --jade-bright:#1f9aae;
  --brass:#c2933a; --brass-deep:#9d7322; --brass-soft:#e7cf95;
  --sand:#f1ead9; --paper:#fbf8f0; --paper-2:#f5efe2; --card:#fffdf8;
  --line:rgba(19,40,44,.14); --line-2:rgba(19,40,44,.08);
  --gold-line:rgba(159,115,34,.32);
  --shadow:0 1px 2px rgba(13,40,44,.06), 0 14px 40px -18px rgba(13,40,44,.28);
  --shadow-lg:0 30px 80px -32px rgba(6,59,70,.45);
  --r:16px; --r-sm:10px; --maxw:1240px;
  --disp:"Cormorant Garamond",Georgia,serif;
  --body:"Jost",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--body); color:var(--ink); background:var(--paper);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1200px 520px at 88% -8%, rgba(22,135,111,.12), transparent 60%),
    radial-gradient(900px 480px at -6% 4%, rgba(194,147,58,.10), transparent 55%);
  background-attachment:fixed;
}
/* fine paper grain */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:var(--jade);text-decoration:none}
a:hover{color:var(--jade-deep)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,42px)}
h1,h2,h3,h4{font-family:var(--disp);font-weight:600;line-height:1.05;letter-spacing:-.01em;color:var(--ink);margin:0}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:1.3rem;line-height:1.2}
.serif-i{font-style:italic;font-family:var(--disp)}
.kick{font:600 .74rem/1 var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--brass-deep);display:inline-flex;align-items:center;gap:.55em}
.kick::before{content:"";width:26px;height:1px;background:var(--brass)}
.lead{font-size:1.18rem;color:var(--ink-soft);max-width:62ch}
.center{text-align:center}.center .lead{margin-inline:auto}.center .kick{justify-content:center}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font:600 1rem/1 var(--body);
  padding:.92em 1.5em;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .18s ease, box-shadow .25s ease, background .2s ease, color .2s;text-align:center}
.btn:active{transform:translateY(1px)}
.btn-pri{background:var(--jade);color:#fdfcf6;box-shadow:0 10px 26px -12px rgba(15,96,80,.7)}
.btn-pri:hover{background:var(--jade-deep);color:#fff;transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(9,58,48,.8)}
.btn-gold{background:linear-gradient(180deg,var(--brass),var(--brass-deep));color:#1d1404}
.btn-gold:hover{filter:brightness(1.07);transform:translateY(-2px);color:#1d1404}
.btn-ghost{background:transparent;border-color:var(--gold-line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--brass);background:rgba(194,147,58,.08)}
.btn-lg{padding:1.05em 1.9em;font-size:1.05rem}
.btn-sm{padding:.6em 1em;font-size:.9rem}

/* ---------- top promo / nav ---------- */
.hx-promo{background:var(--jade-deep);color:#e9f3ee;text-align:center;font:500 .85rem/1.4 var(--body);
  padding:8px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.hx-promo b{color:var(--brass-soft)}
header.nav{position:sticky;top:0;z-index:50;background:rgba(251,248,240,.82);
  backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line-2)}
.nav .in{display:flex;align-items:center;gap:24px;height:70px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-weight:600;font-size:1.5rem;letter-spacing:-.02em;color:var(--ink)}
.brand .mk{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:linear-gradient(150deg,var(--jade-bright),var(--jade-deep));color:#fff;
  font-family:var(--disp);font-weight:600;font-size:1.15rem;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.18)}
.brand small{font:600 .62rem/1 var(--mono);letter-spacing:.2em;color:var(--brass-deep);text-transform:uppercase;display:block;margin-top:3px}
.nav .links{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav .links a{padding:.55em .8em;border-radius:8px;color:var(--ink-soft);font-weight:500;font-size:.97rem;transition:.15s}
.nav .links a:hover{color:var(--ink);background:rgba(22,36,31,.05)}
.nav .links a.cta{margin-left:8px}
.burger{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:9px;width:44px;height:42px;cursor:pointer}
.burger span{display:block;width:20px;height:2px;background:var(--ink);margin:4px auto;border-radius:2px}
@media(max-width:920px){
  .nav .links{position:fixed;inset:118px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);padding:14px clamp(18px,4vw,42px) 22px;gap:2px;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s;box-shadow:var(--shadow)}
  .nav .links.open{transform:none;opacity:1;pointer-events:auto}
  .nav .links a{padding:.8em .6em;font-size:1.05rem;border-bottom:1px solid var(--line-2)}
  .nav .links a.cta{margin:8px 0 0}
  .burger{display:block}
}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 120% at 80% -10%, rgba(22,135,111,.20), transparent 50%),
  radial-gradient(90% 90% at 0% 110%, rgba(194,147,58,.16), transparent 55%);
  border-bottom:1px solid var(--line-2)}
.hero .wrap{padding-top:clamp(46px,7vw,92px);padding-bottom:clamp(40px,6vw,76px)}
.hero h1{max-width:16ch}
.hero h1 em{color:var(--jade);font-style:italic}
.hero .deck{font-size:clamp(1.1rem,1.8vw,1.32rem);color:var(--ink-soft);max-width:54ch;margin:1.1rem 0 0}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.pill{display:inline-flex;align-items:center;gap:.5em;background:var(--card);border:1px solid var(--gold-line);
  border-radius:999px;padding:.5em .95em;font:600 .82rem/1 var(--body);color:var(--ink-soft);box-shadow:var(--shadow)}
.pill b{color:var(--jade);font-family:var(--mono);font-weight:600}
.hero-deco{position:absolute;right:-60px;top:-40px;width:min(40vw,460px);opacity:.5;pointer-events:none}

/* ---------- hero dual CTA (List → Browse) ---------- */
.hero-cta{display:flex;flex-direction:column;gap:14px;margin:28px 0 6px;max-width:820px}
.bigcta{display:flex;align-items:center;gap:18px;padding:20px 24px;border-radius:18px;text-decoration:none;
  transition:transform .2s ease, box-shadow .25s, border-color .2s;border:1px solid transparent;position:relative;overflow:hidden}
.bigcta .ic{font-size:1.9rem;flex:none;width:58px;height:58px;display:grid;place-items:center;border-radius:15px}
.bigcta .tx{flex:1;min-width:0}
.bigcta .tx b{display:block;font-family:var(--disp);font-weight:600;font-size:1.5rem;line-height:1.08}
.bigcta .tx span{font-size:.96rem;opacity:.92;display:block;margin-top:2px}
.bigcta .go{font-weight:700;white-space:nowrap;font-size:1.02rem;display:inline-flex;align-items:center;gap:.3em}
.bigcta.list{background:linear-gradient(135deg,#e3c878,var(--brass) 45%,var(--brass-deep));color:#1d1404;box-shadow:var(--shadow-lg)}
.bigcta.list .ic{background:rgba(255,255,255,.28)}
.bigcta.list::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 120px at 90% -20%,rgba(255,255,255,.45),transparent 70%);pointer-events:none}
.bigcta.list:hover{transform:translateY(-3px);box-shadow:0 34px 80px -30px rgba(157,115,34,.7)}
.bigcta.browse{background:var(--card);border-color:var(--gold-line);color:var(--ink);box-shadow:var(--shadow)}
.bigcta.browse .ic{background:var(--jade);color:#fff}
.bigcta.browse:hover{transform:translateY(-3px);border-color:var(--brass);color:var(--ink)}
.bigcta.browse .go{color:var(--jade-deep)}
@media(max-width:560px){.bigcta{flex-wrap:wrap}.bigcta .tx{flex:1 1 auto}.bigcta .go{width:100%;justify-content:center;margin-top:6px}}

/* ---------- search bar ---------- */
.searchbar{background:var(--card);border:1px solid var(--gold-line);border-radius:var(--r);
  box-shadow:var(--shadow-lg);padding:14px;margin-top:30px;display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr auto;gap:10px;align-items:end}
.searchbar .f{display:flex;flex-direction:column;gap:5px;text-align:left}
.searchbar label{font:600 .68rem/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;color:var(--mute)}
.searchbar input,.searchbar select{font-family:var(--body);font-size:.98rem;padding:.72em .8em;
  border:1px solid var(--line);border-radius:10px;background:var(--paper);color:var(--ink);width:100%}
.searchbar input:focus,.searchbar select:focus,.field:focus,.fld:focus{outline:2px solid var(--jade-bright);outline-offset:1px;border-color:transparent}
.searchbar .btn{height:48px;white-space:nowrap}
.seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:4px;gap:2px;margin-bottom:14px}
.seg button{border:none;background:none;font:600 .92rem/1 var(--body);color:var(--ink-soft);padding:.6em 1.15em;border-radius:999px;cursor:pointer;transition:.15s}
.seg button.on{background:var(--jade);color:#fff;box-shadow:0 6px 14px -8px rgba(15,96,80,.8)}
@media(max-width:860px){.searchbar{grid-template-columns:1fr 1fr}.searchbar .f.wide,.searchbar .btn{grid-column:1/-1}}

/* ---------- section rhythm ---------- */
section{padding:clamp(48px,7vw,96px) 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:34px;flex-wrap:wrap}
.sec-head .lead{margin-top:.5rem}
.dark{background:linear-gradient(170deg,var(--jade-deep),#072a23);color:#dceae3;position:relative;overflow:hidden}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark .kick{color:var(--brass-soft)}.dark .kick::before{background:var(--brass-soft)}
.dark .lead,.dark p{color:#bcd2c9}
.dark a{color:var(--brass-soft)}

/* ---------- category tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.tile{position:relative;border-radius:var(--r);overflow:hidden;min-height:188px;display:flex;flex-direction:column;
  justify-content:flex-end;padding:18px;color:#fff;border:1px solid rgba(255,255,255,.12);
  background:var(--jade);box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);color:#fff}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(7,30,24,.78));z-index:1}
.tile .glyph{position:absolute;top:14px;right:14px;z-index:2;font-size:1.6rem;opacity:.9}
.tile span,.tile b{position:relative;z-index:2}
.tile b{font-family:var(--disp);font-weight:500;font-size:1.35rem;line-height:1.05}
.tile span{font:600 .8rem/1.3 var(--body);opacity:.86;margin-top:4px}
.tile .ct{position:absolute;top:14px;left:14px;z-index:2;font:600 .72rem/1 var(--mono);background:rgba(0,0,0,.28);
  padding:.45em .7em;border-radius:999px;backdrop-filter:blur(4px)}

/* ---------- listing cards ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:24px}
.card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s;position:relative}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.card .ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,var(--jade-bright),var(--jade-deep))}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .ph img{transform:scale(1.06)}
.card .tags{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;z-index:2}
.tag{font:600 .68rem/1 var(--mono);letter-spacing:.04em;padding:.45em .65em;border-radius:7px;background:rgba(251,248,240,.94);color:var(--ink);text-transform:uppercase;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.tag.gold{background:linear-gradient(180deg,var(--brass),var(--brass-deep));color:#1d1404}
.tag.jade{background:var(--jade);color:#fff}
.card .fav{position:absolute;top:10px;right:10px;z-index:2;width:36px;height:36px;border-radius:50%;border:none;
  background:rgba(251,248,240,.92);cursor:pointer;font-size:1.05rem;display:grid;place-items:center;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:.15s}
.card .fav:hover{transform:scale(1.1)}
.card .fav.on{background:var(--brass);color:#1d1404}
.card .bd{padding:16px 17px 18px;display:flex;flex-direction:column;gap:9px;flex:1}
.card .price{font-family:var(--disp);font-weight:600;font-size:1.5rem;color:var(--jade-deep);line-height:1}
.card .price small{font-family:var(--mono);font-size:.72rem;color:var(--mute);font-weight:500;margin-left:.4em}
.card .ttl{font-family:var(--disp);font-weight:500;font-size:1.16rem;line-height:1.15;color:var(--ink)}
.card .loc{font-size:.9rem;color:var(--mute);display:flex;align-items:center;gap:.4em}
.card .specs{display:flex;flex-wrap:wrap;gap:14px;margin-top:auto;padding-top:11px;border-top:1px solid var(--line-2);font:600 .85rem/1 var(--body);color:var(--ink-soft)}
.card .specs i{font-style:normal;color:var(--mute);font-weight:500}
.card .who{font:500 .8rem/1 var(--body);color:var(--mute);margin-top:2px}
.card .who b{color:var(--brass-deep);font-weight:600}

/* ---------- browse layout ---------- */
.browse{display:grid;grid-template-columns:288px 1fr;gap:30px;align-items:start}
.filters{position:sticky;top:90px;background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.filters h4{font-family:var(--disp);font-size:1.15rem;margin-bottom:6px}
.fgroup{padding:16px 0;border-top:1px solid var(--line-2)}
.fgroup:first-of-type{border-top:none}
.fgroup>label{display:block;font:600 .72rem/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;color:var(--mute);margin-bottom:10px}
.fld{width:100%;font-family:var(--body);font-size:.95rem;padding:.62em .7em;border:1px solid var(--line);border-radius:9px;background:var(--paper);color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font:600 .82rem/1 var(--body);padding:.5em .8em;border-radius:999px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--brass)}
.chip.on{background:var(--jade);color:#fff;border-color:var(--jade)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.browse-top{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.browse-top .count{font:600 1rem/1 var(--body);color:var(--ink-soft)}
.browse-top .count b{color:var(--jade-deep);font-family:var(--disp);font-size:1.2rem}
.filters-toggle{display:none}
@media(max-width:900px){
  .browse{grid-template-columns:1fr}
  .filters{position:relative;top:0;display:none}
  .filters.open{display:block}
  .filters-toggle{display:inline-flex}
}

/* ---------- listing detail ---------- */
.gallery{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:10px;border-radius:var(--r);overflow:hidden;max-height:520px}
.gallery img{width:100%;height:100%;object-fit:cover;cursor:zoom-in;background:var(--jade)}
.gallery .g0{grid-row:1/3}
.gallery img:nth-child(n+5){display:none}
@media(max-width:760px){.gallery{grid-template-columns:1fr;grid-template-rows:auto;max-height:none}.gallery .g0{grid-row:auto}.gallery img:nth-child(n+3){display:none}}
.det{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start;margin-top:30px}
.det .specbar{display:flex;flex-wrap:wrap;gap:26px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:22px 0}
.det .specbar .s b{font-family:var(--disp);font-size:1.4rem;color:var(--jade-deep);display:block;line-height:1}
.det .specbar .s span{font:600 .76rem/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--mute)}
.featlist{columns:2;column-gap:30px;margin:18px 0 0;padding:0;list-style:none}
.featlist li{break-inside:avoid;padding:.4em 0 .4em 1.5em;position:relative;color:var(--ink-soft)}
.featlist li::before{content:"";position:absolute;left:0;top:.72em;width:8px;height:8px;border-radius:2px;background:var(--brass);transform:rotate(45deg)}
@media(max-width:560px){.featlist{columns:1}}
.aside{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}
.contact-card{background:var(--card);border:1px solid var(--gold-line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-lg)}
.contact-card .price{font-family:var(--disp);font-weight:600;font-size:2.1rem;color:var(--jade-deep);line-height:1}
.contact-card .usd{font-family:var(--mono);font-size:.85rem;color:var(--mute)}
.owner-row{display:flex;align-items:center;gap:12px;margin:16px 0;padding:14px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.owner-row .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(150deg,var(--jade-bright),var(--jade-deep));color:#fff;display:grid;place-items:center;font-family:var(--disp);font-size:1.2rem;font-weight:600}
.owner-row b{display:block;font-size:1rem}.owner-row span{font-size:.82rem;color:var(--mute)}
form .field{width:100%;font-family:var(--body);font-size:.98rem;padding:.78em .85em;border:1px solid var(--line);border-radius:10px;background:var(--paper);color:var(--ink);margin-bottom:10px}
textarea.field{resize:vertical;min-height:92px}
.note-ok{background:rgba(22,135,111,.1);border:1px solid var(--jade-bright);color:var(--jade-deep);padding:.8em 1em;border-radius:10px;font-weight:600;font-size:.92rem}
.det .desc{font-size:1.05rem;color:var(--ink-soft);white-space:pre-line}
@media(max-width:880px){.det{grid-template-columns:1fr}.aside{position:relative;top:0}}

/* ---------- steps / how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;counter-reset:s}
.step{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:26px 22px;box-shadow:var(--shadow);position:relative}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-18px;left:22px;width:42px;height:42px;border-radius:12px;
  background:linear-gradient(180deg,var(--brass),var(--brass-deep));color:#1d1404;font-family:var(--disp);font-weight:600;font-size:1.3rem;display:grid;place-items:center;box-shadow:var(--shadow)}
.step h3{margin:14px 0 8px}
.step p{color:var(--ink-soft);font-size:.97rem;margin:0}

/* ---------- pricing ---------- */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;align-items:start}
.plan{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:28px 24px;box-shadow:var(--shadow);position:relative;display:flex;flex-direction:column;gap:14px}
.plan.feat{border:1.5px solid var(--brass);box-shadow:var(--shadow-lg);transform:translateY(-6px)}
.plan .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(180deg,var(--brass),var(--brass-deep));color:#1d1404;font:700 .72rem/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;padding:.55em .9em;border-radius:999px}
.plan h3{font-size:1.4rem}
.plan .amt{font-family:var(--disp);font-weight:600;font-size:2.6rem;color:var(--jade-deep);line-height:1}
.plan .amt small{font-size:.95rem;color:var(--mute);font-family:var(--mono);font-weight:500}
.plan ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;flex:1}
.plan li{padding-left:1.7em;position:relative;color:var(--ink-soft);font-size:.96rem}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--jade-bright);font-weight:700}
.plan li.no{color:var(--mute)}.plan li.no::before{content:"–";color:var(--mute)}

/* ---------- generic content / guide ---------- */
.prose{max-width:74ch}
.prose h2{margin:1.6em 0 .5em}.prose h3{margin:1.4em 0 .4em;font-size:1.25rem}
.prose p{margin:.7em 0;color:var(--ink-soft)}
.prose ul{padding-left:1.2em;color:var(--ink-soft)}.prose li{margin:.3em 0}
.callout{background:var(--paper-2);border-left:3px solid var(--brass);border-radius:0 12px 12px 0;padding:16px 20px;margin:18px 0;font-size:.97rem}
.callout b{color:var(--brass-deep)}
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;padding:16px 0;font-family:var(--disp);font-size:1.15rem;display:flex;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brass);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{margin:0 0 16px;color:var(--ink-soft)}

/* ---------- stats strip ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:24px;text-align:center}
.stats .st b{font-family:var(--disp);font-weight:600;font-size:clamp(2rem,4vw,2.8rem);display:block;line-height:1;color:#fff}
.dark .stats .st b{color:var(--brass-soft)}
.stats .st span{font:600 .8rem/1.3 var(--body);color:var(--mute)}
.dark .stats .st span{color:#9fbbb0}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--jade),var(--jade-deep));color:#fff;border-radius:24px;padding:clamp(34px,5vw,60px);text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.cta-band h2{color:#fff;max-width:18ch;margin-inline:auto}
.cta-band p{color:#cfe3da;max-width:50ch;margin:14px auto 24px}
.cta-band .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- wizard ---------- */
.wizard{background:var(--card);border:1px solid var(--gold-line);border-radius:var(--r);box-shadow:var(--shadow-lg);padding:clamp(22px,3.5vw,38px);max-width:780px;margin:0 auto}
.wsteps{display:flex;gap:8px;margin-bottom:26px;flex-wrap:wrap}
.wsteps .ws{flex:1;min-width:110px;font:600 .76rem/1.2 var(--body);color:var(--mute);padding:10px 0;border-top:3px solid var(--line);text-align:center}
.wsteps .ws.on{color:var(--jade-deep);border-top-color:var(--brass)}
.wsteps .ws b{display:block;font-family:var(--mono);font-size:.72rem;color:var(--brass-deep)}
.wpane{display:none}.wpane.on{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}
.flbl{display:block;font:600 .76rem/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin:4px 0 6px}
.drop{border:2px dashed var(--gold-line);border-radius:12px;padding:26px;text-align:center;color:var(--mute);cursor:pointer;transition:.2s;background:var(--paper)}
.drop:hover,.drop.over{border-color:var(--brass);background:rgba(194,147,58,.06);color:var(--ink)}
.thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.thumbs img{width:78px;height:62px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.wnav{display:flex;justify-content:space-between;margin-top:24px;gap:12px}
.featgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:8px;margin:4px 0 10px}
.featchip{display:flex;align-items:center;gap:9px;padding:.62em .8em;border:1px solid var(--line);border-radius:10px;background:var(--paper);cursor:pointer;font-size:.9rem;transition:border-color .15s,background .15s;user-select:none}
.featchip:hover{border-color:var(--brass)}
.featchip input{width:17px;height:17px;accent-color:var(--jade);cursor:pointer;flex:none}
.featchip:has(input:checked){background:rgba(22,135,111,.1);border-color:var(--jade-bright);font-weight:600;color:var(--jade-deep)}

/* ---------- footer ---------- */
footer.ft{background:var(--jade-deep);color:#bcd2c9;padding:56px 0 30px;margin-top:30px}
footer.ft h4{color:#fff;font-family:var(--disp);font-size:1.05rem;margin-bottom:14px}
.ftcols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
footer.ft a{color:#bcd2c9;display:block;padding:5px 0;font-size:.93rem}
footer.ft a:hover{color:var(--brass-soft)}
.ftbar{border-top:1px solid rgba(255,255,255,.12);margin-top:36px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.84rem;color:#8fada2}
@media(max-width:760px){.ftcols{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.ftcols{grid-template-columns:1fr}}

/* ---------- misc ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
.skeleton{background:linear-gradient(100deg,var(--paper-2) 30%,#fff 50%,var(--paper-2) 70%);background-size:200% 100%;animation:sh 1.3s infinite;border-radius:var(--r);min-height:340px}
@keyframes sh{to{background-position:-200% 0}}
.empty{text-align:center;padding:60px 20px;color:var(--mute)}
.empty b{font-family:var(--disp);font-size:1.4rem;color:var(--ink);display:block;margin-bottom:8px}
.lightbox{position:fixed;inset:0;background:rgba(7,30,24,.94);z-index:200;display:none;place-items:center;padding:30px}
.lightbox.on{display:grid}
.lightbox img{max-width:94vw;max-height:88vh;border-radius:10px;object-fit:contain}
.lightbox .x{position:absolute;top:18px;right:24px;color:#fff;font-size:2rem;cursor:pointer;background:none;border:none}
.lightbox .nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);border:none;color:#fff;font-size:1.6rem;width:52px;height:52px;border-radius:50%;cursor:pointer}
.lightbox .prev{left:20px}.lightbox .next{right:20px}
