
:root{
  --forest:#152219;--pine:#1e3829;--sage:#32784e;--leaf:#42b068;
  --mint:#cceada;--mint-lt:#eaf6ef;--cream:#f5f0e7;--gold:#bd7e2c;
  --gold-lt:#fdf4e3;--body:#354e3c;--muted:#73957d;--border:#cfe3d6;--white:#fff;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Outfit',sans-serif;background:var(--cream);color:var(--forest);min-height:100vh;}
nav{background:rgba(245,240,231,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;height:64px;}
.nav-logo{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;color:var(--forest);text-decoration:none;}
.nav-logo span{color:var(--sage);}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-link{font-size:14px;font-weight:500;color:var(--body);text-decoration:none;padding:8px 14px;border-radius:50px;transition:background .15s;background:none;border:none;font-family:'Outfit',sans-serif;cursor:pointer;}
.nav-link:hover{background:var(--mint-lt);color:var(--sage);}
.nav-link-active{background:var(--mint-lt);color:var(--sage) !important;font-weight:600;}
.nav-cta{background:var(--forest);color:var(--cream);font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;border:none;border-radius:50px;padding:9px 22px;cursor:pointer;text-decoration:none;}
.nav-cta:hover{background:var(--pine);}
.nav-toggle{display:none;background:transparent;border:1.5px solid var(--border);width:42px;height:42px;border-radius:12px;align-items:center;justify-content:center;cursor:pointer;padding:0;color:var(--forest);transition:background .2s,border-color .2s,color .2s;}
.nav-toggle:hover{background:var(--mint-lt);border-color:var(--sage);color:var(--sage);}
.nav-toggle span{position:relative;display:block;width:20px;height:2px;background:currentColor;border-radius:2px;transition:background .2s;}
.nav-toggle span::before,.nav-toggle span::after{content:'';position:absolute;left:0;width:20px;height:2px;background:currentColor;border-radius:2px;transition:transform .25s ease,top .25s ease;}
.nav-toggle span::before{top:-6px;}
.nav-toggle span::after{top:6px;}
nav.open .nav-toggle span{background:transparent;}
nav.open .nav-toggle span::before{top:0;transform:rotate(45deg);}
nav.open .nav-toggle span::after{top:0;transform:rotate(-45deg);}
@media(max-width:900px){
  .nav-link{padding:7px 10px;font-size:13px;}
  nav{padding:0 4vw;}
}
@media(max-width:820px){
  .nav-toggle{display:inline-flex;}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:8px;
    padding:16px 5vw 20px;
    background:rgba(245,240,231,.99);
    backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    box-shadow:0 14px 32px rgba(21,34,25,.12);
    transform:translateY(-10px);
    opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .25s ease,opacity .2s ease,visibility .2s;
  }
  nav.open .nav-links{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto;}
  .nav-links > *{width:100%;text-align:center;padding:12px 16px;font-size:15px;display:block;}
  .nav-links .nav-link{display:block;font-size:15px;padding:12px 16px;}
}
.hero{background:var(--forest);padding:52px 5vw 44px;text-align:center;}
.badge{display:inline-flex;align-items:center;gap:7px;background:rgba(50,120,78,.18);border:1px solid rgba(50,120,78,.35);color:var(--leaf);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 14px;border-radius:50px;margin-bottom:18px;}
.hero h1{font-family:'Fraunces',serif;font-size:clamp(24px,4vw,40px);font-weight:700;color:var(--white);line-height:1.2;letter-spacing:-.02em;margin-bottom:12px;}
.hero h1 em{font-style:italic;color:var(--leaf);}
.hero p{color:rgba(245,240,231,.6);font-size:15px;font-weight:300;max-width:480px;margin:0 auto;}
.gold-line{height:3px;background:linear-gradient(90deg,transparent,var(--sage),var(--gold),var(--sage),transparent);}
.main{max-width:780px;margin:0 auto;padding:36px 20px 80px;}
.card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:28px 32px;margin-bottom:24px;}
.card h2{font-family:'Fraunces',serif;font-size:18px;font-weight:600;color:var(--forest);margin-bottom:4px;}
.card-sub{font-size:13px;color:var(--muted);margin-bottom:22px;}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;}
.field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:6px;}
.input-wrap{position:relative;}
.input-wrap .pre{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--muted);pointer-events:none;}
.input-wrap input[type="number"]{width:100%;font-family:'Outfit',sans-serif;font-size:15px;color:var(--forest);background:var(--mint-lt);border:1px solid var(--border);border-radius:9px;padding:11px 12px 11px 28px;outline:none;transition:border-color .18s;-moz-appearance:textfield;}
.input-wrap input[type="number"]:focus{border-color:var(--sage);background:var(--white);}
.input-wrap input[type="number"]::-webkit-outer-spin-button,
.input-wrap input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;}
.field-hint{font-size:12px;color:var(--muted);margin-top:5px;}
.calc-row{display:flex;justify-content:flex-end;}
.calc-btn{background:var(--leaf);color:var(--forest);font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;border:none;border-radius:50px;padding:13px 36px;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:8px;}
.calc-btn:hover{background:#52c97a;transform:translateY(-1px);}
.results{display:none;}
.results.show{display:block;}
.gap-banner{border-radius:12px;padding:22px 26px;margin-bottom:24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.gap-banner.gold{background:rgba(189,126,44,.08);border:1px solid rgba(189,126,44,.25);}
.gap-banner.green{background:rgba(66,176,104,.1);border:1px solid rgba(66,176,104,.3);}
.gap-big{font-family:'Fraunces',serif;font-size:42px;font-weight:700;line-height:1;white-space:nowrap;}
.gap-banner.gold .gap-big{color:var(--gold);}
.gap-banner.green .gap-big{color:var(--leaf);}
.gap-lbl{font-size:12px;color:var(--muted);margin-top:3px;}
.gap-text{font-size:14px;color:var(--body);line-height:1.75;}
.gap-text strong{color:var(--forest);}
.pp-head{font-family:'Fraunces',serif;font-size:17px;font-weight:600;color:var(--forest);margin-bottom:4px;}
.pp-sub{font-size:13px;color:var(--muted);margin-bottom:20px;}
.pp-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
.pp-card{border:2px solid var(--border);border-radius:13px;padding:22px 18px;text-align:center;}
.pp-card.c1{border-color:var(--sage);background:var(--mint-lt);}
.pp-card.c2{border-color:var(--leaf);background:rgba(66,176,104,.06);}
.pp-card.c3{border-color:var(--gold);background:var(--gold-lt);}
.pp-tier-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:10px;}
.pp-rate-wrap{position:relative;margin-bottom:4px;}
.pp-rate-wrap .rpre{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--muted);pointer-events:none;font-weight:500;}
.pp-rate-wrap input{width:100%;font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--forest);background:rgba(255,255,255,.75);border:1.5px solid var(--border);border-radius:9px;padding:9px 9px 9px 26px;outline:none;transition:border-color .18s;-moz-appearance:textfield;}
.pp-rate-wrap input::-webkit-outer-spin-button,
.pp-rate-wrap input::-webkit-inner-spin-button{-webkit-appearance:none;}
.pp-rate-wrap input:focus{border-color:var(--sage);}
.pp-mo{font-size:11px;color:var(--muted);margin-bottom:16px;text-align:left;padding-left:2px;}
.pp-divider{height:1px;background:var(--border);margin-bottom:14px;}
.pp-count{font-family:'Fraunces',serif;font-size:54px;font-weight:700;line-height:1;}
.pp-card.c1 .pp-count,.pp-card.c2 .pp-count{color:var(--leaf);}
.pp-card.c3 .pp-count{color:var(--gold);}
.pp-count-lbl{font-size:12px;color:var(--muted);margin-bottom:14px;}
.pp-info{font-size:12px;color:var(--body);background:rgba(255,255,255,.65);border-radius:8px;padding:9px 11px;text-align:left;line-height:1.6;}
.pp-info strong{color:var(--forest);}
.tl-head{font-family:'Fraunces',serif;font-size:17px;font-weight:600;color:var(--forest);margin-bottom:4px;}
.tl-sub{font-size:13px;color:var(--muted);margin-bottom:18px;}
table{width:100%;border-collapse:collapse;}
thead th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:10px 14px;text-align:left;border-bottom:2px solid var(--mint);}
tbody td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:14px;color:var(--body);}
tbody tr:last-child td{border-bottom:none;}
tbody td:first-child{font-weight:600;color:var(--forest);}
.tv{font-weight:600;color:var(--sage);}
.tv.now{color:var(--leaf);}
.cta-card{background:var(--forest);border-radius:14px;padding:36px 40px;text-align:center;margin-top:0;}
.cta-card h3{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--white);margin-bottom:10px;}
.cta-card p{font-size:14px;color:rgba(245,240,231,.6);margin-bottom:24px;max-width:400px;margin-left:auto;margin-right:auto;line-height:1.7;}
.cta-btn{display:inline-block;background:var(--leaf);color:var(--forest);font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;border:none;border-radius:50px;padding:14px 36px;cursor:pointer;text-decoration:none;transition:all .18s;}
.cta-btn:hover{background:#52c97a;transform:translateY(-1px);}
@media(max-width:600px){
  .fields{grid-template-columns:1fr;}
  .pp-cards{grid-template-columns:1fr;}
  .card{padding:20px 16px;}
  .cta-card{padding:28px 20px;}
}
/* ── FOOTER ── */
footer{background:var(--forest);padding:48px 5vw 30px;position:relative;overflow:hidden;}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(66,176,104,.3),transparent);}
footer .fi2{max-width:1060px;margin:0 auto;}
footer .ft{display:flex;justify-content:space-between;gap:36px;flex-wrap:wrap;padding-bottom:28px;border-bottom:1px solid rgba(204,234,218,.1);margin-bottom:22px;}
footer .fb{max-width:270px;}
footer .flogo{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;color:var(--cream);margin-bottom:10px;}
footer .flogo span{color:var(--leaf);}
footer .fb p{font-size:13px;color:rgba(245,240,231,.4);line-height:1.7;font-weight:300;}
footer .fc h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(204,234,218,.4);margin-bottom:13px;}
footer .fc ul{list-style:none;padding:0;margin:0;}
footer .fc li{margin-bottom:9px;color:rgba(245,240,231,.5);font-size:13px;line-height:1.55;}
footer .fc a{color:rgba(245,240,231,.5);text-decoration:none;font-size:13px;transition:color .15s;}
footer .fc a:hover{color:var(--leaf);}
footer .fcontact li{color:rgba(245,240,231,.55);}
footer .fvanity{color:rgba(245,240,231,.3);font-size:11px;letter-spacing:.04em;}
footer .fbot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
footer .fbot p{font-size:12px;color:rgba(245,240,231,.25);}


/* ═══════════════════════════════════════════════════════════════════
   WORDPRESS SHARED-HEADER COMPATIBILITY
   The original planner page used .nav-link / .nav-cta / .nav-logo /
   .nav-links for nav structure. The WordPress version uses the shared
   header.php which outputs .logo, .nav-r, .btn, .btn-ghost, .btn-sm,
   and .btn-green. These rules style those classes to match the
   original planner page's nav appearance.
═══════════════════════════════════════════════════════════════════ */
.logo {
  font-family: 'Fraunces', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--forest);
  text-decoration: none;
}
.logo span { color: var(--sage); }
.nav-r {
  display: flex;
  align-items: center;
  gap: 6px;
}
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Outfit', sans-serif; font-weight: 600;
  border-radius: 50px; cursor: pointer; border: none;
  transition: all .18s ease; text-decoration: none; white-space: nowrap;
}
.btn-sm { font-size: 14px; padding: 8px 14px; }
.btn-ghost {
  background: transparent;
  color: var(--body);
  font-weight: 500;
}
.btn-ghost:hover {
  background: var(--mint-lt);
  color: var(--sage);
}
.btn-ghost.active,
.btn-ghost.nav-tool-link.active {
  background: var(--mint-lt);
  color: var(--sage) !important;
  font-weight: 600;
}
.btn-green {
  background: var(--forest);
  color: var(--cream);
  padding: 9px 22px;
  font-size: 14px;
  font-weight: 600;
}
.btn-green:hover { background: var(--pine); }
