/* =====================================================================
   PawWorth — pet insurance tools (cozy, friendly design system)
   Warm cream + coral + sage-teal · rounded fonts · gentle animation
   Built on the same dependency-free engine as the legal-calc studio.
   ===================================================================== */
:root{
  --cream:#FFF8F1; --card:#FFFFFF; --ink:#3A302B; --ink-2:#6B5D54; --muted:#9C8D82;
  --primary:#F2845C; --primary-deep:#E06B41; --primary-soft:#FFE8DC;
  --teal:#2FA89F; --teal-deep:#1F8A82; --teal-soft:#DCF2EF;
  --line:#F0E3D6; --soft:#FBF3EB; --good:#2FA89F; --warn:#D98324; --bad:#D45D5D;
  --shadow:0 1px 2px rgba(127,86,52,.05), 0 14px 34px rgba(127,86,52,.10);
  --shadow-lg:0 22px 60px rgba(127,86,52,.18);
  --ease:cubic-bezier(.16,1,.3,1);
  --radius:18px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
body{
  margin:0; color:var(--ink);
  font-family:'Nunito',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:17px; line-height:1.7; overflow-wrap:break-word;
  background:
    radial-gradient(140% 90% at 12% -8%, #FFEFE4 0%, transparent 42%),
    radial-gradient(120% 80% at 100% 0%, #E4F4F1 0%, transparent 38%),
    var(--cream) fixed;
}
h1,h2,h3,.brand,.calc-btn,.eyebrow,.cnt,.badge{font-family:'Quicksand','Nunito',sans-serif}
.wrap{max-width:740px; margin:0 auto; padding:30px 20px 80px; position:relative}
a{color:var(--primary-deep)}

/* floating paw decorations (hero / page background) */
.paws{position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0}
.paws .paw{position:absolute; color:var(--primary); opacity:.10; animation:float 9s ease-in-out infinite}
.paws .paw svg{width:100%; height:100%}
.paws .paw:nth-child(1){width:42px; height:42px; left:6%; top:8%; animation-delay:0s}
.paws .paw:nth-child(2){width:30px; height:30px; left:84%; top:14%; color:var(--teal); opacity:.12; animation-delay:1.4s}
.paws .paw:nth-child(3){width:24px; height:24px; left:18%; top:60%; animation-delay:2.6s}
.paws .paw:nth-child(4){width:36px; height:36px; left:90%; top:62%; color:var(--teal); animation-delay:.8s}
.paws .paw:nth-child(5){width:20px; height:20px; left:50%; top:4%; animation-delay:3.4s}
@keyframes float{0%,100%{transform:translateY(0) rotate(-8deg)} 50%{transform:translateY(-16px) rotate(8deg)}}

.back{display:inline-flex; align-items:center; gap:6px; color:var(--muted); text-decoration:none;
  font-weight:800; font-size:.92rem; margin-bottom:16px; position:relative; z-index:1}
.back:hover{color:var(--primary-deep)}

/* ---------- header ---------- */
header{text-align:center; margin-bottom:18px; animation:rise .7s var(--ease) both; position:relative; z-index:1}
.eyebrow{font-size:.8rem; letter-spacing:.12em; color:var(--primary-deep); font-weight:800;
  text-transform:uppercase; margin-bottom:10px}
header h1{font-weight:700; font-size:2.1rem; margin:.1em 0 .35em; letter-spacing:-.01em; line-height:1.22}
header p{color:var(--ink-2); margin:0 auto; font-size:1.02rem; max-width:30em}
.rule{width:48px; height:4px; background:linear-gradient(90deg,var(--primary),var(--teal)); border-radius:4px; margin:16px auto 0}

.note{background:var(--primary-soft); border:1px solid #F8D6C4; border-radius:14px; padding:15px 18px;
  margin:18px 0 0; font-size:.94rem; color:#7a4a30; line-height:1.65; position:relative; z-index:1;
  animation:rise .7s var(--ease) both .05s}
.note b{color:var(--primary-deep); font-weight:800}
.lead{background:var(--soft); border:1px solid var(--line); border-radius:14px; padding:16px 18px;
  font-size:.97rem; color:var(--ink-2); line-height:1.65}

/* ---------- cards ---------- */
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px;
  margin:18px 0; box-shadow:var(--shadow); animation:rise .7s var(--ease) both .08s; position:relative; z-index:1}
.card-title{font-weight:700; font-size:1.3rem; margin:0 0 6px; display:flex; align-items:center; gap:10px}
.card-title .no{display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px;
  border-radius:10px; background:var(--primary-soft); color:var(--primary-deep); font-size:.92rem; flex:0 0 auto}
.card-sub{color:var(--muted); font-size:.95rem; margin:0 0 4px}

label{display:block; font-size:1rem; color:var(--ink); margin:20px 0 4px; font-weight:800}
.qhint{font-size:.88rem; color:var(--muted); margin:0 0 9px; font-weight:500; line-height:1.55}

input[type=number], input[type=text], input[type=date], select{
  width:100%; padding:14px 16px; background:var(--soft); border:1.5px solid var(--line);
  border-radius:12px; color:var(--ink); font-size:1.08rem; font-family:inherit; outline:none;
  transition:border-color .15s, box-shadow .15s; font-variant-numeric:tabular-nums}
input:focus, select:focus{border-color:var(--primary); box-shadow:0 0 0 3px rgba(242,132,92,.16)}

.money-field{display:flex; align-items:center; background:var(--soft); border:1.5px solid var(--line);
  border-radius:12px; overflow:hidden; transition:border-color .15s, box-shadow .15s}
.money-field:focus-within{border-color:var(--primary); box-shadow:0 0 0 3px rgba(242,132,92,.16)}
.money-field .cur{padding:0 6px 0 14px; color:var(--muted); font-size:1.05rem}
.money-field input{flex:1; min-width:0; border:0; background:transparent; outline:none; box-shadow:none;
  padding:13px 14px 13px 4px; font-size:1.08rem; color:var(--ink); font-family:inherit;
  text-align:left; font-variant-numeric:tabular-nums}

.row{display:flex; gap:14px; flex-wrap:wrap}
.row > div{flex:1; min-width:150px; display:flex; flex-direction:column}
.row > div > input, .row > div > .money-field, .row > div > select, .row > div > .seg{margin-top:auto}

/* segmented choice */
.seg{display:flex; gap:8px; margin-top:6px; flex-wrap:wrap}
.seg button{flex:1; min-width:84px; padding:12px 10px; border:1.5px solid var(--line); background:var(--soft);
  color:var(--ink-2); border-radius:12px; cursor:pointer; font-size:.98rem; font-weight:700;
  font-family:inherit; transition:all .15s; line-height:1.3}
.seg button:hover{border-color:var(--primary)}
.seg button.on{background:var(--primary); border-color:var(--primary); color:#fff; box-shadow:0 6px 16px rgba(242,132,92,.28)}
.seg.tags button{flex:0 0 auto; min-width:0}

.calc-btn{width:100%; margin-top:24px; padding:17px; border:0; border-radius:14px;
  background:linear-gradient(135deg,var(--primary),var(--primary-deep)); color:#fff; font-size:1.12rem;
  font-weight:700; font-family:inherit; cursor:pointer; transition:transform .12s, box-shadow .2s;
  box-shadow:0 10px 24px rgba(224,107,65,.32); letter-spacing:.01em}
.calc-btn:hover{box-shadow:0 14px 30px rgba(224,107,65,.4); transform:translateY(-1px)}
.calc-btn:active{transform:translateY(1px)}
.reset-btn{width:100%; margin-top:10px; padding:13px; border:1.5px solid var(--line); border-radius:12px;
  background:transparent; color:var(--muted); font-size:1rem; font-weight:800; font-family:inherit;
  cursor:pointer; transition:border-color .15s, color .15s}
.reset-btn:hover{border-color:var(--primary); color:var(--primary-deep)}
.err{color:var(--bad); font-size:.92rem; margin-top:14px; display:none; line-height:1.5; font-weight:600}

/* ---------- results ---------- */
.result{display:none}
.result.shown{animation:rise .6s var(--ease) both}
.sum{font-size:.92rem; color:var(--muted); line-height:1.6}
.verdict{margin-top:6px; padding:18px 20px; border-radius:14px; font-size:1.05rem; line-height:1.6;
  background:var(--teal-soft); border:1px solid #BEE6E2; color:#185b56; font-weight:700}
.verdict.lean-yes{background:var(--teal-soft); border-color:#BEE6E2; color:#185b56}
.verdict.lean-maybe{background:#FFF3DD; border-color:#F4DFB0; color:#8a5a16}
.verdict .big-emoji{font-size:1.4rem}

.scenarios{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:16px}
.scn{background:var(--soft); border:1.5px solid var(--line); border-radius:14px; padding:16px 14px; text-align:center}
.scn .lbl{font-size:.78rem; font-weight:800; letter-spacing:.03em; text-transform:uppercase; color:var(--muted)}
.scn .ico{font-size:1.5rem; margin:6px 0 4px}
.scn .you{font-size:1.25rem; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; margin-top:4px}
.scn .cap{font-size:.78rem; color:var(--muted); margin-top:4px; line-height:1.4}
.scn.win{border-color:var(--teal); background:var(--teal-soft)}
.scn.win .you{color:var(--teal-deep)}

.table-wrap{overflow-x:auto; -webkit-overflow-scrolling:touch}
table{width:100%; border-collapse:collapse; margin-top:14px; font-size:1rem}
th,td{text-align:right; padding:13px 8px; border-bottom:1px solid var(--line)}
thead th{color:var(--primary-deep); font-weight:800; font-size:.8rem; letter-spacing:.02em;
  text-transform:uppercase; border-bottom:2px solid var(--primary-soft)}
td:first-child, th:first-child{text-align:left}
tbody tr:last-child td{border-bottom:0}
.who{font-weight:800; color:var(--ink)}
.amt{font-variant-numeric:tabular-nums}
.pill{display:inline-block; font-size:.8rem; padding:3px 10px; border-radius:8px;
  background:var(--primary-soft); color:var(--primary-deep); font-weight:800}
.pill.teal{background:var(--teal-soft); color:var(--teal-deep)}

.stat{display:flex; justify-content:space-between; align-items:center; margin-top:14px;
  padding:14px 18px; background:var(--soft); border:1px solid var(--line); border-radius:12px}
.stat .k{color:var(--muted); font-size:.95rem; font-weight:700}
.stat .v{font-size:1.15rem; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums}
.big{margin-top:16px; padding:24px 20px; border-radius:16px; text-align:center;
  background:linear-gradient(135deg,var(--primary),var(--primary-deep)); color:#fff; position:relative; overflow:hidden}
.big::after{content:""; position:absolute; right:-20px; bottom:-20px; width:120px; height:120px;
  background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%)}
.big .k{font-size:.95rem; opacity:.94; font-weight:700}
.big .v{font-size:1.95rem; font-weight:800; margin-top:6px; font-variant-numeric:tabular-nums; line-height:1.2; position:relative}
.big .vsub{font-size:.9rem; opacity:.92; margin-top:8px; position:relative; line-height:1.5}
.big.teal{background:linear-gradient(135deg,var(--teal),var(--teal-deep))}

.disc{font-size:.86rem; color:var(--muted); margin-top:20px; padding:16px 18px;
  background:rgba(255,255,255,.6); border:1px solid var(--line); border-radius:12px; line-height:1.6}

/* ---------- guide / SEO body ---------- */
.guide{line-height:1.78}
.guide h2.card-title{margin-bottom:14px}
.guide h3{font-size:1.12rem; font-weight:700; color:var(--ink); margin:26px 0 8px; padding-left:14px;
  border-left:4px solid var(--primary); line-height:1.45; border-radius:2px}
.guide h3:first-of-type{margin-top:6px}
.guide p{margin:0 0 12px; color:var(--ink-2); font-size:.98rem}
.guide ul{margin:0 0 14px; padding-left:2px; list-style:none}
.guide ul li{position:relative; padding-left:22px; margin-bottom:8px; color:var(--ink-2); font-size:.98rem}
.guide ul li::before{content:"🐾"; position:absolute; left:0; top:0; font-size:.78rem; opacity:.7}
.guide b, .guide strong{color:var(--ink); font-weight:800}
.guide .ex{background:var(--teal-soft); border:1px solid #BEE6E2; border-radius:14px; padding:16px 18px;
  margin:14px 0; font-size:.95rem; color:#27605b; line-height:1.7}
.guide .ex .ex-t{font-weight:800; color:var(--teal-deep); font-size:.88rem; margin-bottom:6px; letter-spacing:.02em}
.guide .src{font-size:.85rem; color:var(--muted); margin-top:18px; padding-top:14px; border-top:1px solid var(--line)}
.guide .src a{color:var(--muted); text-decoration:underline}

/* ---------- FAQ accordion ---------- */
.acc{margin-top:6px}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item:first-child{border-top:1px solid var(--line)}
.acc-q{width:100%; text-align:left; background:none; border:0; cursor:pointer; font-size:1.08rem;
  font-weight:800; color:var(--ink); font-family:inherit; padding:18px 40px 18px 2px; position:relative; line-height:1.5}
.acc-q:hover{color:var(--primary-deep)}
.acc-q::after{content:""; position:absolute; right:6px; top:50%; width:15px; height:15px; transform:translateY(-50%);
  background:
    linear-gradient(var(--primary),var(--primary)) center/100% 2.4px no-repeat,
    linear-gradient(var(--primary),var(--primary)) center/2.4px 100% no-repeat;
  transition:transform .4s var(--ease)}
.acc-item.open .acc-q::after{transform:translateY(-50%) rotate(45deg)}
.acc-a{max-height:0; overflow:hidden; transition:max-height .42s var(--ease)}
.acc-item.open .acc-a{max-height:600px}
.acc-a p{margin:0 2px 18px; color:var(--ink-2); line-height:1.75; font-size:1rem}

/* ---------- home: hero ---------- */
.hero{text-align:center; padding:30px 0 6px; animation:rise .8s var(--ease) both; position:relative; z-index:1}
.hero .badge{display:inline-block; background:#fff; border:1.5px solid var(--line); color:var(--primary-deep);
  font-weight:800; font-size:.78rem; padding:7px 15px; border-radius:999px; letter-spacing:.02em; box-shadow:var(--shadow)}
.hero h1{font-size:2.6rem; font-weight:700; letter-spacing:-.02em; margin:18px 0 14px; line-height:1.18}
.hero h1 .pt{color:var(--primary-deep); position:relative; white-space:nowrap}
.hero h1 .pt::after{content:""; position:absolute; left:0; right:0; bottom:2px; height:10px; z-index:-1;
  background:var(--primary-soft); border-radius:6px}
.hero p{color:var(--ink-2); font-size:1.1rem; max-width:30em; margin:0 auto; line-height:1.7}
.hero-pet{width:130px; height:130px; margin:6px auto 0; display:block; animation:bob 3.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)}}

.picker-label{text-align:center; color:var(--muted); font-weight:800; font-size:.92rem; letter-spacing:.03em; margin:34px 0 0; position:relative; z-index:1}

/* tool cards (home) */
.toolgrid{display:flex; flex-direction:column; gap:14px; margin-top:18px; position:relative; z-index:1}
.tcard{display:flex; align-items:center; gap:18px; text-decoration:none; color:inherit;
  background:var(--card); border:1.5px solid var(--line); border-radius:var(--radius); padding:20px 22px;
  box-shadow:var(--shadow); transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s;
  position:relative; overflow:hidden; animation:rise .55s var(--ease) both}
.toolgrid .tcard:nth-child(1){animation-delay:.04s} .toolgrid .tcard:nth-child(2){animation-delay:.1s}
.toolgrid .tcard:nth-child(3){animation-delay:.16s} .toolgrid .tcard:nth-child(4){animation-delay:.22s}
.tcard::before{content:""; position:absolute; left:0; top:0; width:5px; height:100%;
  background:linear-gradient(var(--primary),var(--teal)); opacity:0; transition:opacity .2s}
.tcard:hover{transform:translateY(-3px); box-shadow:var(--shadow-lg); border-color:var(--primary)}
.tcard:hover::before{opacity:1}
.tcard.soon{opacity:.72}
.tcard.soon:hover{transform:none; box-shadow:var(--shadow); border-color:var(--line); cursor:default}
.tico{flex:0 0 auto; width:58px; height:58px; border-radius:16px; background:var(--primary-soft);
  display:flex; align-items:center; justify-content:center; color:var(--primary-deep); transition:transform .25s var(--ease)}
.tcard:nth-child(even) .tico{background:var(--teal-soft); color:var(--teal-deep)}
.tcard:hover .tico{transform:scale(1.08) rotate(-6deg)}
.tico svg{width:32px; height:32px}
.ttxt{flex:1; min-width:0}
.ttxt .t{display:block; font-size:1.22rem; font-weight:700; letter-spacing:-.01em; font-family:'Quicksand',sans-serif}
.ttxt .d{display:block; color:var(--muted); font-size:.92rem; margin-top:4px; line-height:1.5}
.tcard .tag{flex:0 0 auto; font-size:.72rem; font-weight:800; color:var(--primary-deep); background:var(--primary-soft);
  padding:5px 11px; border-radius:999px; letter-spacing:.02em}
.tcard.soon .tag{color:var(--muted); background:var(--soft)}
.arrow{flex:0 0 auto; color:var(--primary); font-size:1.4rem; font-weight:800; transition:transform .2s var(--ease)}
.tcard:hover .arrow{transform:translateX(4px)}

/* trust strip */
.trust{display:flex; justify-content:center; gap:22px; flex-wrap:wrap; margin-top:40px; color:var(--muted); font-size:.92rem; position:relative; z-index:1}
.trust span{display:inline-flex; align-items:center; gap:6px} .trust b{color:var(--primary-deep)}
.trust-note{text-align:center; color:var(--muted); font-size:.84rem; margin-top:12px; line-height:1.6; max-width:36em; margin:12px auto 0; position:relative; z-index:1}

/* ---------- share ---------- */
.share-wrap{text-align:center; margin-top:22px; position:relative; z-index:1}
.share-btn{display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--primary-deep);
  border:1.5px solid var(--line); border-radius:999px; padding:12px 22px; font-weight:800; font-size:.98rem;
  font-family:inherit; cursor:pointer; transition:background .15s, transform .12s, border-color .15s; box-shadow:var(--shadow)}
.share-btn:hover{border-color:var(--primary); transform:translateY(-1px)} .share-btn:active{transform:translateY(1px)}
.share-btn svg{width:18px; height:18px}
.toast{position:fixed; left:50%; bottom:32px; transform:translateX(-50%) translateY(20px); opacity:0;
  background:var(--ink); color:#fff; padding:13px 22px; border-radius:12px; font-size:.95rem; font-weight:700;
  z-index:80; transition:opacity .25s, transform .25s; pointer-events:none; box-shadow:var(--shadow-lg)}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}

/* ---------- footer ---------- */
footer.site{text-align:center; margin-top:28px; padding-top:20px; border-top:1px solid var(--line);
  color:var(--muted); font-size:.88rem; position:relative; z-index:1; line-height:2}
footer.site a{color:var(--primary-deep); text-decoration:none; font-weight:800}
footer.site a:hover{text-decoration:underline}

/* ---------- global nav (top-right) ---------- */
.navmenu{position:fixed; top:14px; right:14px; z-index:70}
.navmenu-btn{width:46px; height:46px; border-radius:14px; border:1.5px solid var(--line);
  background:var(--card); box-shadow:var(--shadow); cursor:pointer; display:flex; align-items:center;
  justify-content:center; color:var(--primary-deep); padding:0; transition:transform .15s var(--ease), border-color .2s}
.navmenu-btn:hover{border-color:var(--primary)} .navmenu-btn:active{transform:translateY(1px)}
.navmenu-btn svg{width:23px; height:23px}
.navmenu-panel{position:absolute; top:54px; right:0; width:min(260px, calc(100vw - 28px)); max-height:76vh;
  overflow-y:auto; background:var(--card); border:1.5px solid var(--line); border-radius:18px;
  box-shadow:var(--shadow-lg); padding:8px; opacity:0; transform:translateY(-8px) scale(.97);
  transform-origin:top right; pointer-events:none; transition:opacity .22s var(--ease), transform .22s var(--ease)}
.navmenu.open .navmenu-panel{opacity:1; transform:none; pointer-events:auto}
.navmenu .gh{font-size:.72rem; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); padding:10px 10px 4px}
.navmenu a{display:flex; align-items:center; gap:11px; padding:10px; border-radius:12px;
  text-decoration:none; color:var(--ink); font-weight:700; font-size:.96rem; transition:background .15s, color .15s}
.navmenu a:hover{background:var(--soft); color:var(--primary-deep)}
.navmenu a.cur{background:var(--primary-soft); color:var(--primary-deep)}
.navmenu .nd{height:1px; background:var(--line); margin:6px}

/* ---------- ad slot — content end only, height reserved (CLS-safe) ---------- */
.ad-slot{margin:32px auto 6px; min-height:120px; text-align:center; clear:both}
.ad-slot::before{content:'Advertisement'; display:block; font-size:.68rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--muted); opacity:.6; margin-bottom:8px}
.ad-slot ins{margin:0 auto}

/* ---------- animations ---------- */
@keyframes rise{from{opacity:0; transform:translateY(14px)} to{opacity:1; transform:none}}
@keyframes fade{from{opacity:0} to{opacity:1}}
@keyframes pop{from{opacity:0; transform:translateY(16px) scale(.96)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important; transition:none !important; scroll-behavior:auto !important}
}

/* ---------- responsive ---------- */
@media (max-width:560px){
  .wrap{padding:24px 14px 60px}
  .hero h1{font-size:2rem} .hero p{font-size:1rem}
  header h1{font-size:1.62rem}
  .card{padding:22px 18px}
  .card-title{font-size:1.18rem}
  body{font-size:16px}
  .scenarios{grid-template-columns:1fr; gap:10px}
  .scn{display:flex; align-items:center; gap:12px; text-align:left; padding:13px 16px}
  .scn .ico{margin:0; font-size:1.3rem} .scn .you{margin:0}
  .scn .lbl{flex:0 0 70px}
  .big .v{font-size:1.62rem}
  .trust{gap:14px}
  .tcard{padding:17px; gap:14px} .tico{width:50px; height:50px} .tico svg{width:27px; height:27px}
  .ttxt .t{font-size:1.1rem} .ttxt .d{font-size:.88rem}
  .navmenu{top:10px; right:10px} .navmenu-btn{width:42px; height:42px; border-radius:12px}
  th,td{padding:11px 5px; font-size:.93rem}
}
