@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&display=swap');

:root{
  --pine:#2E6B4E; --pine-dark:#235440; --pine-deep:#1C3A2A; --forest:#13281C;
  --cream:#F7F2E8; --paper:#FFFFFF; --sand:#EFE7D7;
  --gold:#C9A24B; --gold-soft:#E5C272;
  --ink:#1F2B24; --muted:#5D6C62; --line:#E5DECC;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --shadow-sm:0 1px 2px rgba(28,42,34,.05),0 2px 8px rgba(28,42,34,.07);
  --shadow-md:0 6px 18px rgba(28,42,34,.10),0 2px 6px rgba(28,42,34,.06);
  --shadow-lg:0 18px 40px rgba(19,40,28,.18),0 6px 14px rgba(19,40,28,.08);
  --ease:cubic-bezier(.2,.7,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);background:var(--cream);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:var(--pine);text-decoration:none}
a:hover{text-decoration:underline}
a:focus-visible,button:focus-visible,input:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.12}

/* ---------- nav ---------- */
header.nav{position:sticky;top:0;z-index:20;background:rgba(247,242,232,.88);
  backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid rgba(28,42,34,.08)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:700;font-size:21px;letter-spacing:-.2px;color:var(--ink);flex-shrink:0}
.brand:hover{text-decoration:none}
.brand img{width:34px;height:34px;border-radius:9px;box-shadow:0 1px 4px rgba(28,42,34,.25)}
.nav nav{display:flex;align-items:center}
.nav nav a{position:relative;color:var(--ink);font-weight:600;font-size:15px;margin-left:26px;white-space:nowrap}
.nav nav a:not(.nav-app){padding:4px 0}
.nav nav a:not(.nav-app)::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--gold);transition:right .25s var(--ease)}
.nav nav a:not(.nav-app):hover::after{right:0}
.nav nav a:hover{color:var(--pine-dark);text-decoration:none}
.nav-app{background:var(--pine);color:#fff !important;padding:10px 22px;border-radius:999px;font-weight:600;line-height:1;white-space:nowrap;flex:0 0 auto;
  box-shadow:0 2px 8px rgba(46,107,78,.35);transition:transform .15s var(--ease),box-shadow .15s var(--ease),background .15s var(--ease)}
.nav-app:hover{background:var(--pine-dark);transform:translateY(-1px);box-shadow:0 6px 16px rgba(46,107,78,.4);text-decoration:none}

/* ---------- buttons ---------- */
.btn,.allguides-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:16px;
  padding:14px 28px;border-radius:999px;text-decoration:none;cursor:pointer;
  transition:transform .15s var(--ease),box-shadow .2s var(--ease),background .15s var(--ease)}
.btn:hover,.allguides-btn:hover{text-decoration:none;transform:translateY(-2px)}
.allguides-btn,.btn-pine{background:var(--pine);color:#fff;box-shadow:0 4px 14px rgba(46,107,78,.32)}
.allguides-btn:hover,.btn-pine:hover{background:var(--pine-dark);box-shadow:0 10px 26px rgba(46,107,78,.38)}
.btn-gold{background:var(--gold);color:#22301F;box-shadow:0 4px 16px rgba(0,0,0,.28)}
.btn-gold:hover{background:#D5B05E;box-shadow:0 10px 28px rgba(0,0,0,.32)}
.allguides-btn--lg,.btn-lg{padding:16px 32px;font-size:17px}

/* ---------- hero ---------- */
.hero-photo{
  position:relative;color:#fff;
  background:
    linear-gradient(180deg,rgba(19,40,28,.52) 0%,rgba(19,40,28,.28) 38%,rgba(19,40,28,.62) 78%,rgba(19,40,28,.82) 100%),
    url('images/hero-park.jpg') center 38%/cover no-repeat;
  min-height:580px;display:flex;align-items:center;
}
.hero-photo .wrap{padding-top:72px;padding-bottom:64px;width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(19,40,28,.45);
  border:1px solid rgba(229,194,114,.55);color:#F3E3BC;padding:8px 16px;border-radius:999px;
  font-size:13.5px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;margin-bottom:22px;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-soft)}
.hero-photo h1{color:#fff;font-size:clamp(40px,5.6vw,68px);font-weight:600;letter-spacing:-.5px;max-width:820px;
  text-shadow:0 2px 28px rgba(0,0,0,.45);text-wrap:balance}
.hero-photo .lead{color:rgba(255,255,255,.94);font-size:clamp(17px,2vw,21px);max-width:600px;margin:22px 0 32px;
  text-shadow:0 1px 14px rgba(0,0,0,.4)}
.hero-search{display:flex;gap:10px;max-width:600px;margin-top:4px}
.hero-search input{flex:1;min-width:0;padding:16px 24px;border-radius:999px;border:1.5px solid rgba(255,255,255,.4);
  background:rgba(255,255,255,.97);font-size:16px;font-family:var(--sans);color:var(--ink);
  box-shadow:0 10px 30px rgba(0,0,0,.28);transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.hero-search input::placeholder{color:#7B8A80}
.hero-search input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,162,75,.4)}
.hero-search .btn{flex:0 0 auto}
.hero-popular{margin-top:20px;font-size:14.5px;color:rgba(255,255,255,.82);display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;
  text-shadow:0 1px 10px rgba(0,0,0,.4)}
.hero-popular a{color:#fff;font-weight:600;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:1px}
.hero-popular a:hover{color:var(--gold-soft);border-color:var(--gold-soft);text-decoration:none}

/* ---------- sections ---------- */
section.block{padding:88px 0}
.kicker{color:var(--gold);font-weight:700;letter-spacing:2.2px;text-transform:uppercase;font-size:13px;margin-bottom:12px;display:flex;align-items:center;gap:12px}
.kicker::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
h2{font-size:clamp(30px,3.6vw,42px);letter-spacing:-.4px;margin-bottom:16px;text-wrap:balance}
.section-lead{color:var(--muted);font-size:18px;max-width:640px}

/* ---------- guide showcase ---------- */
.guide{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.guide-grid--four{grid-template-columns:repeat(4,1fr)}
.guide-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;
  color:inherit;text-decoration:none;box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.guide-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:#D8CFB8;text-decoration:none}
.guide-card .img-wrap, .guide-card > img{overflow:hidden}
.guide-card img{width:100%;height:170px;object-fit:cover;display:block;transition:transform .45s var(--ease)}
.guide-card:hover img{transform:scale(1.05)}
.guide-card .gc-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.guide-card h3{font-size:19.5px;margin-bottom:6px;letter-spacing:-.2px}
.guide-card p{font-size:14.5px;color:var(--muted);line-height:1.55}
.guide-card .gc-body::after{content:"Read the guide →";margin-top:auto;padding-top:14px;font-size:14px;font-weight:600;color:var(--pine);
  transition:color .2s var(--ease)}
.guide-card:hover .gc-body::after{color:var(--gold)}
.guide-browse{text-align:center;margin:44px 0 8px}

/* ---------- planning principles ---------- */
.tips-head{font-size:clamp(24px,2.6vw,30px);margin-top:80px;margin-bottom:8px}
.tips-sub{color:var(--muted);font-size:17px;margin-bottom:28px}
.tips-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.tip{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:24px 26px;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.tip:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.tip-num{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--gold);letter-spacing:1px;display:block;margin-bottom:10px}
.tip h4{font-size:18px;font-weight:700;margin-bottom:6px;letter-spacing:-.2px}
.tip p{color:var(--muted);font-size:15.5px}

/* ---------- app showcase ---------- */
.appshow{position:relative;background:linear-gradient(175deg,var(--pine-deep) 0%,var(--forest) 100%);color:#F5F0E4;overflow:hidden}
.appshow::before{content:"";position:absolute;top:-220px;right:-160px;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,75,.16) 0%,rgba(201,162,75,0) 70%);pointer-events:none}
.appshow .kicker{color:var(--gold-soft)}
.appshow .kicker::before{background:var(--gold-soft)}
.appshow h2{color:#FBF7EC}
.appshow-lead{max-width:660px;color:rgba(245,240,228,.88);font-size:18px}
.appshots{display:flex;gap:20px;overflow-x:auto;padding:36px 0 26px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.appshots::-webkit-scrollbar{height:8px}
.appshots::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:8px}
.appshots::-webkit-scrollbar-thumb{background:rgba(229,194,114,.5);border-radius:8px}
.appshots img{height:500px;width:auto;border-radius:24px;flex:0 0 auto;scroll-snap-align:center;
  box-shadow:0 24px 48px rgba(0,0,0,.42),0 4px 12px rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.14);
  transition:transform .3s var(--ease)}
.appshots img:hover{transform:translateY(-6px)}
.appshow-foot{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:18px}
.appstore-badge{display:inline-block;border-radius:11px;transition:transform .15s var(--ease),box-shadow .2s var(--ease)}
.appstore-badge:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.4)}
.appstore-badge svg{display:block}

/* ---------- footer ---------- */
footer{background:var(--forest);color:#AFC4B4;padding:56px 0 36px;font-size:14.5px}
footer a{color:#E9F1EA}
footer a:hover{color:var(--gold-soft);text-decoration:none}
footer .wrap{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center}
footer .links a{margin-left:20px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;width:100%;align-items:start;margin-bottom:40px}
.foot-brand .brand{color:#FBF7EC;font-size:20px;margin-bottom:14px}
.foot-brand p{font-size:14.5px;line-height:1.6;color:#9DB3A3;max-width:34ch}
.foot-col h4{font-family:var(--sans);font-size:12.5px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:#7E957F;margin-bottom:14px}
.foot-col a{display:block;margin-bottom:10px;font-size:15px}
.foot-bottom{width:100%;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;font-size:13.5px;color:#84997F;
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}

/* ---------- reveal on scroll ---------- */
.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal:nth-child(2){transition-delay:.07s}
.js .reveal:nth-child(3){transition-delay:.14s}
.js .reveal:nth-child(4){transition-delay:.21s}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition-duration:.01ms !important;animation-duration:.01ms !important}
  .js .reveal{opacity:1;transform:none}
}

/* ---------- guides hub: pillars, search, related ---------- */
.pillars{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0}
.pillars a{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:9px 17px;font-size:14px;font-weight:600;color:var(--ink);text-decoration:none;
  transition:border-color .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease)}
.pillars a:hover{border-color:var(--pine);color:var(--pine);box-shadow:var(--shadow-sm);text-decoration:none}
.gsearch{width:100%;padding:15px 18px;border:1.5px solid var(--line);border-radius:14px;font-size:16px;font-family:var(--sans);background:var(--paper);margin:8px 0 4px;
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.gsearch:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 4px rgba(46,107,78,.12)}
.gcount{font-size:13px;color:var(--muted);min-height:18px;margin-bottom:10px}
.related{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px 26px;margin-top:36px;box-shadow:var(--shadow-sm)}
.related h2{font-size:19px;margin-bottom:10px}
.related ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 20px}
.related a{font-size:14.5px}
@media(max-width:600px){.related ul{grid-template-columns:1fr}}

/* ---------- article (guides, about, privacy, support) ---------- */
.article{background:var(--paper);min-height:60vh}
.article .wrap{max-width:780px;padding-top:56px;padding-bottom:80px}
.article h1{font-size:clamp(32px,4.4vw,44px);margin-bottom:10px;letter-spacing:-.4px;text-wrap:balance}
.article .updated{color:var(--muted);font-size:16px;margin-bottom:8px}
.byline{font-size:14.5px;color:var(--muted);margin:0 0 26px}
.byline a{color:var(--pine);font-weight:600}
.article h2{font-size:27px;margin:42px 0 12px}
.article h3{font-size:20px;margin:28px 0 8px}
.article p,.article li{color:#37453D;font-size:16.5px;margin-bottom:13px}
.article ul{padding-left:24px}
.article .lead-in{font-size:19px;color:#2C3A32;line-height:1.65}
.article figure{margin:30px 0}
.article figure img{border-radius:16px;width:100%;display:block;max-height:440px;object-fit:cover;box-shadow:var(--shadow-md)}
.article figcaption{font-size:13px;color:var(--muted);margin-top:9px}
.guide-cta{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:22px 24px;margin-top:36px;box-shadow:var(--shadow-sm)}
.guide-cta a{font-weight:600}

/* ---------- responsive ---------- */
@media(max-width:1020px){
  .guide-grid--four{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:920px){
  .guide-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
}
@media(max-width:760px){
  section.block{padding:64px 0}
  .tips-grid{grid-template-columns:1fr}
  footer .wrap{flex-direction:column;text-align:center}
  footer .links a{margin:0 10px}
  .foot-grid{grid-template-columns:1fr;gap:28px;text-align:left}
  .foot-bottom{justify-content:center;text-align:center}
}
@media(max-width:800px){
  .nav nav a:nth-child(2),.nav nav a:nth-child(3){display:none}
  .nav nav a{margin-left:16px}
}
@media(max-width:560px){
  .nav .wrap{padding:0 16px;height:60px}
  .brand{font-size:18px;gap:8px}
  .brand img{width:28px;height:28px}
  .nav nav a{font-size:14px;margin-left:12px}
  .nav-app{padding:9px 16px}
  .hero-eyebrow{font-size:11.5px;padding:7px 14px;letter-spacing:.3px}
  .hero-photo{min-height:520px}
  .hero-photo .wrap{padding-top:56px;padding-bottom:48px}
  .hero-search{flex-direction:column;gap:12px}
  .hero-search .btn{width:100%;justify-content:center}
  .guide-grid{grid-template-columns:1fr}
  .guide-grid--four{grid-template-columns:1fr}
  .appshots img{height:430px}
}
