/* ownable.css — Shared styles for Ownable suite
 * Included by: save.html, hunt.html, close.html
 * Page-specific styles remain in each file's <style> block
 */

/* ── Design Tokens ─────────────────────────────────────── */
:root{
  --teal:#044C66;
  --teal-dark:#02303F;
  --teal-mid:#0A6A8A;
  --mint:#EBF8F7;
  --divider:#A8E0DD;
  --white:#FFFFFF;
  --off-white:#F5F9F9;
  --text:#09191F;
  --muted:#6B8A90;
  --light:#E2ECEE;
  --red:#B83232;
  --red-light:#FEE8E8;
  --green:#0A6650;
  --green-light:#D4F0EA;
  --amber:#7A4A0A;
  --amber-light:#FEF3C7;
  --radius:16px;
  --radius-sm:10px
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--off-white);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Fraunces',serif}

/* ── Suite Nav ─────────────────────────────────────────── */
.suite-nav{background:var(--teal-dark);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.suite-brand{font-family:'Fraunces',serif;color:var(--white);font-size:1.25rem;font-weight:700;text-decoration:none}
.suite-brand span{color:var(--divider)}
.suite-pills{display:flex;gap:4px;align-items:center}
.suite-pill{display:inline-flex;align-items:center;padding:4px 8px;font-size:.85rem;font-weight:400;text-decoration:none;color:rgba(255,255,255,.45);transition:opacity .2s}
.suite-pill.active{background:var(--divider);color:var(--teal-dark);border-radius:20px;padding:6px 14px;font-weight:600}
.suite-pill:not(.active):hover{opacity:.7}

/* ── Header ────────────────────────────────────────────── */
header{background:linear-gradient(135deg,var(--teal-dark),var(--teal-mid));color:var(--white);padding:2rem 1.5rem 1.5rem;text-align:center}
.header-inner{max-width:720px;margin:0 auto}
header h1{font-size:2.4rem;font-weight:700;margin-bottom:.5rem}
header h1 em{font-weight:300;font-style:italic;color:var(--divider)}
.sub{font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:1.25rem}
.header-badges{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:4px;padding:5px 14px;border-radius:20px;font-size:.8rem;font-weight:600}
.badge.free{background:rgba(168,224,221,.2);color:var(--divider)}
.badge.tip{background:rgba(255,255,255,.15);color:var(--white);text-decoration:none;transition:background .2s}
.badge.tip:hover{background:rgba(255,255,255,.25)}

/* ── Progress Bar ──────────────────────────────────────── */
.prog-wrap{background:var(--white);border-bottom:1px solid var(--light);padding:1.25rem 1.5rem;position:sticky;top:48px;z-index:99}
.prog-steps{display:flex;align-items:center;justify-content:center;gap:0;max-width:500px;margin:0 auto;position:relative}
.prog-step{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:1;flex:1}
.p-dot{width:32px;height:32px;border-radius:50%;border:2px solid var(--light);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--muted);transition:all .3s;cursor:pointer}
.p-dot.active{border-color:var(--teal);background:var(--teal);color:var(--white)}
.p-dot.done{border-color:var(--green);background:var(--green-light);color:var(--green)}
.p-lbl{font-size:.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.prog-line{flex:1;height:2px;background:var(--light);position:relative;top:-10px;z-index:0}
.prog-line.done{background:var(--green)}

/* ── Cards ─────────────────────────────────────────────── */
.card{background:var(--white);border-radius:var(--radius);box-shadow:0 1px 4px rgba(0,0,0,.06);overflow:hidden;margin-bottom:1.5rem}
.card-hdr{padding:1.25rem 1.5rem;border-bottom:1px solid var(--light);display:flex;align-items:center;gap:12px}
.s-num{width:28px;height:28px;border-radius:50%;background:var(--teal);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}
.card-hdr h2{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;flex:1}
.chk{width:22px;height:22px;border-radius:50%;border:2px solid var(--light);display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .3s;flex-shrink:0}
.chk.done{border-color:var(--green);background:var(--green-light);color:var(--green)}
.card-body{padding:1.5rem}

/* ── Field Grid ────────────────────────────────────────── */
.fg{display:grid;gap:1rem}
.f{display:flex;flex-direction:column;gap:4px}
.f label{font-size:.82rem;font-weight:600;color:var(--text)}
.f .hint{font-size:.75rem;color:var(--muted)}
.iw{display:flex;align-items:center;border:1.5px solid var(--light);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .2s;background:var(--white)}
.iw:focus-within{border-color:var(--teal)}
.pre{padding:0 10px;font-size:.85rem;color:var(--muted);background:var(--off-white);height:44px;display:flex;align-items:center;border-right:1px solid var(--light)}
.suf{padding:0 10px;font-size:.85rem;color:var(--muted);background:var(--off-white);height:44px;display:flex;align-items:center;border-left:1px solid var(--light)}
.iw input{flex:1;border:none;outline:none;padding:0 12px;height:44px;font-size:.95rem;font-family:inherit;background:transparent;min-width:0}
.iw input::-webkit-outer-spin-button,.iw input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.iw input[type=number]{-moz-appearance:textfield}
.iw select{flex:1;border:none;outline:none;padding:0 12px;height:44px;font-size:.95rem;font-family:inherit;background:transparent;min-width:0;cursor:pointer}

/* ── Partner Fields ────────────────────────────────────── */
.partner-fields{display:none;margin-top:1rem}
.partner-fields.show{display:block}
.partner-card{background:var(--mint);border-radius:var(--radius-sm);padding:1rem;margin-bottom:.75rem}
.partner-card h4{font-size:.85rem;font-weight:600;margin-bottom:.75rem;color:var(--teal)}

/* ── Big Number Card ───────────────────────────────────── */
.bnum-card{background:var(--white);border-radius:var(--radius);box-shadow:0 1px 4px rgba(0,0,0,.06);padding:1.25rem;margin-bottom:1rem}
.bn{text-align:center}
.bnl{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:4px}
.bnv{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:700;line-height:1.2}
.bns{font-size:.8rem;color:var(--muted);margin-top:2px}

/* ── Verdict ───────────────────────────────────────────── */
.verdict{border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;text-align:center}
.verdict.green{background:var(--green-light);color:var(--green)}
.verdict.amber{background:var(--amber-light);color:var(--amber)}
.verdict.red{background:var(--red-light);color:var(--red)}
.verdict h3{font-size:1rem;margin-bottom:4px}
.verdict p{font-size:.82rem;opacity:.85}

/* ── Split Grid ────────────────────────────────────────── */
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}
.split-tile{background:var(--white);border-radius:var(--radius);box-shadow:0 1px 4px rgba(0,0,0,.06);padding:1rem;text-align:center}
.split-tile h4{font-size:.78rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.split-tile .val{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:700;color:var(--teal)}
.split-tile .pct{font-size:.78rem;color:var(--muted);margin-top:2px}

/* ── Tip Card ──────────────────────────────────────────── */
.tip-card{background:var(--mint);border-radius:var(--radius);padding:1.25rem;text-align:center;margin-bottom:1rem}
.tip-card p{font-size:.85rem;color:var(--text);margin-bottom:.75rem;line-height:1.5}
.tip-card a{display:inline-block;padding:8px 20px;border-radius:var(--radius-sm);background:var(--teal);color:var(--white);text-decoration:none;font-size:.85rem;font-weight:600;transition:background .2s}
.tip-card a:hover{background:var(--teal-mid)}

/* ── Mobile FAB + Drawer ───────────────────────────────── */
.mobile-fab{display:none;position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--teal);color:var(--white);border:none;font-size:1.4rem;cursor:pointer;box-shadow:0 4px 16px rgba(4,76,102,.35);z-index:200;transition:transform .2s}
.mobile-fab:hover{transform:scale(1.08)}
.drawer{display:none;position:fixed;inset:0;z-index:300}
.drawer.open{display:flex;flex-direction:column}
.drawer-overlay{flex:1;background:rgba(0,0,0,.4);min-height:80px}
.drawer-body{background:var(--off-white);border-radius:var(--radius) var(--radius) 0 0;padding:1.5rem;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.drawer-handle{width:40px;height:4px;background:var(--light);border-radius:2px;margin:0 auto 1rem}

/* ── Animations ────────────────────────────────────────── */
@keyframes dotPop { 0%{transform:scale(1)} 40%{transform:scale(1.35)} 70%{transform:scale(0.9)} 100%{transform:scale(1)} }
.p-dot.pop{animation:dotPop .4s ease forwards}
@keyframes panelReveal { 0%{opacity:0;transform:translateY(16px)} 100%{opacity:1;transform:translateY(0)} }
.panel-reveal{animation:panelReveal .5s cubic-bezier(.22,1,.36,1) forwards}

/* ── Responsive ────────────────────────────────────────── */
@media(max-width:920px){
  .suite-brand{font-size:1.05rem}
  .suite-pills{gap:4px}
  .suite-pill{font-size:.78rem}
  header h1{font-size:1.8rem}
}
