/* ===================================================
   THE EAST IDAHO WEEKLY — SHARED STYLES
   styles.css  (new brand: pine, gold, cream)
   Link this from every page: <link rel="stylesheet" href="styles.css">
   =================================================== */

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

/* ==================================================
   VARIABLES
================================================== */
:root{
  --paper:#FBF8F1;
  --cream-deep:#F4EAD4;
  --card:#FFFFFF;
  --ink:#1F2A2C;
  --muted:#5C6B66;
  --pine:#2E5A4E;
  --pine-deep:#244A40;
  --gold:#B57F2E;
  --gold-bright:#C8943B;
  --rule:#E7E1D4;
}

/* ==================================================
   RESET & BASE
================================================== */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.serif{font-family:'Fraunces',Georgia,serif;}
a{color:inherit;}
img{max-width:100%;}

/* ==================================================
   LAYOUT HELPERS
================================================== */
.wrap{max-width:1080px;margin:0 auto;padding:0 24px;}
.wrap-narrow{max-width:620px;margin:0 auto;padding:0 24px;}
.row{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}

/* ==================================================
   BUTTONS
================================================== */
.btn{
  display:inline-block;background:var(--pine);color:#fff;text-decoration:none;
  font-weight:600;padding:14px 26px;border-radius:7px;font-size:15px;
  border:none;cursor:pointer;font-family:inherit;transition:background .15s;
}
.btn:hover{background:var(--pine-deep);}
.btn-ghost{background:transparent;color:var(--pine-deep);border:1.5px solid var(--pine);}
.btn-ghost:hover{background:var(--pine);color:#fff;}

/* ==================================================
   TYPOGRAPHY HELPERS
================================================== */
.eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700;}
.section-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px;}
.section-heading{font-family:'Fraunces',serif;font-size:36px;color:var(--pine-deep);line-height:1.15;font-weight:600;margin-bottom:18px;}

/* ==================================================
   NAV
================================================== */
nav{padding:22px 0;}
.wordmark{font-family:'Fraunces',serif;font-weight:700;font-size:22px;color:var(--pine-deep);text-decoration:none;letter-spacing:-.01em;}
nav .btn{padding:10px 20px;font-size:14px;}

/* ==================================================
   HERO (landing page)
================================================== */
.hero{text-align:center;padding:48px 0 0;position:relative;}
.hero h1{font-size:64px;line-height:1.02;font-weight:600;color:var(--pine-deep);letter-spacing:-.015em;margin:18px auto 0;}
.hero .sub{font-size:19px;color:var(--muted);max-width:46ch;margin:22px auto 0;}
.signup{display:flex;gap:10px;justify-content:center;max-width:480px;margin:32px auto 0;flex-wrap:wrap;}
.signup input{flex:1;min-width:220px;padding:14px 16px;border:1.5px solid var(--rule);border-radius:7px;font-size:15px;font-family:inherit;background:#fff;}
.signup input:focus{outline:none;border-color:var(--pine);}
.reassure{font-size:13px;color:var(--muted);margin:14px auto 0;}
.mtns{display:block;width:100%;margin-top:40px;}

/* ==================================================
   PILLARS (what's in every issue)
================================================== */
.pillars{background:var(--pine-deep);padding:64px 0;}
.pillars h2{text-align:center;color:#fff;font-size:34px;font-weight:600;margin-bottom:6px;}
.pillars .lead{text-align:center;color:#B9C8C2;margin-bottom:44px;}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.pcard{background:#2C5247;border:1px solid #3A6256;border-radius:12px;padding:30px 26px;}
.pnum{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--gold-bright);letter-spacing:.04em;}
.pcard h3{color:#fff;font-size:21px;margin:10px 0 8px;font-weight:600;}
.pcard p{color:#C3D2CC;font-size:15px;}

/* ==================================================
   PEEK / SECTION BANDS
================================================== */
.peek{padding:70px 0;text-align:center;}
.peek .eyebrow{display:block;margin-bottom:14px;}
.peek h2{font-size:36px;color:var(--pine-deep);font-weight:600;max-width:18ch;margin:0 auto 14px;}
.peek p{color:var(--muted);max-width:48ch;margin:0 auto 26px;font-size:17px;}

.tiktok{background:var(--cream-deep);padding:60px 0;}
.tiktok h2{font-size:30px;color:var(--pine-deep);font-weight:600;margin-bottom:8px;}
.tiktok p{color:var(--muted);max-width:42ch;font-size:16px;}

.final{padding:74px 0;text-align:center;}
.final h2{font-size:40px;color:var(--pine-deep);font-weight:600;margin-bottom:10px;}
.final p{color:var(--muted);font-size:18px;margin-bottom:28px;}

/* ==================================================
   SUBSCRIBE CTA BLOCK (reusable)
================================================== */
.subscribe-cta{background:var(--pine);border-radius:10px;padding:30px;text-align:center;margin:40px 0;}
.subscribe-cta p{color:#fff;font-size:18px;font-weight:600;margin-bottom:16px;}
.subscribe-cta a{display:inline-block;padding:12px 28px;background:#fff;color:var(--pine-deep);font-size:15px;font-weight:700;text-decoration:none;border-radius:6px;}

/* ==================================================
   PAGE HEADER (subpages: forms, articles)
================================================== */
.page-header{background:var(--pine-deep);padding:52px 0 60px;}
.page-header-inner{max-width:620px;margin:0 auto;padding:0 24px;}
.page-header-back{display:inline-block;font-size:13px;color:#9FB3AC;text-decoration:none;margin-bottom:22px;transition:color .2s;}
.page-header-back:hover{color:#EAD9B4;}
.page-header-meta{font-size:12px;color:var(--gold-bright);text-transform:uppercase;letter-spacing:.16em;font-weight:700;margin-bottom:12px;}
.page-header-title{font-family:'Fraunces',serif;font-size:40px;color:#fff;line-height:1.12;font-weight:600;margin-bottom:14px;}
.page-header-subtitle{font-size:17px;color:#B9C8C2;line-height:1.7;}

/* ==================================================
   FORM PAGES
================================================== */
.form-page{padding:48px 0 70px;}
.form-card{
  max-width:620px;margin:0 auto;background:var(--card);
  border:1px solid var(--rule);border-radius:12px;padding:38px 36px;
}
.contact-field{margin-bottom:18px;}
.contact-field label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:7px;}
.contact-field input,
.contact-field textarea,
.contact-field select{
  width:100%;padding:13px 16px;border:1.5px solid var(--rule);border-radius:7px;
  background:#fff;color:var(--ink);font-family:'Inter',sans-serif;font-size:15px;
  outline:none;transition:border-color .2s;
}
.contact-field input:focus,
.contact-field textarea:focus,
.contact-field select:focus{border-color:var(--pine);}
.contact-field textarea{min-height:130px;resize:vertical;}
.contact-hint{font-size:12.5px;color:var(--muted);margin-top:6px;}
.contact-submit{
  padding:14px 28px;background:var(--pine);color:#fff;border:none;border-radius:7px;
  font-family:'Inter',sans-serif;font-size:15px;font-weight:700;cursor:pointer;
  transition:background .2s;width:100%;margin-top:8px;
}
.contact-submit:hover{background:var(--pine-deep);}
.form-message{display:none;margin-top:14px;font-size:14px;font-weight:600;text-align:center;}
.form-message.success{display:block;color:var(--pine);}
.form-message.error{display:block;color:#b3402e;}

/* ==================================================
   FORM SUCCESS STATE (animated checkmark)
================================================== */
.form-card.form-hiding{opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease;pointer-events:none;}
.form-success{display:none;text-align:center;padding:48px 24px;max-width:520px;margin:0 auto;}
.form-success.show{display:block;animation:fs-pop .45s ease both;}
@keyframes fs-pop{0%{opacity:0;transform:translateY(8px) scale(.96);}100%{opacity:1;transform:none;}}
.checkmark{width:80px;height:80px;display:block;margin:0 auto 22px;}
.checkmark-circle{fill:none;stroke:var(--pine);stroke-width:4;stroke-dasharray:230;stroke-dashoffset:230;animation:fs-draw-circle .6s ease-out forwards;}
.checkmark-check{fill:none;stroke:var(--pine);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:50;stroke-dashoffset:50;animation:fs-draw-check .35s .5s ease-out forwards;}
@keyframes fs-draw-circle{to{stroke-dashoffset:0;}}
@keyframes fs-draw-check{to{stroke-dashoffset:0;}}
.form-success-title{font-family:'Fraunces',serif;font-size:28px;color:var(--pine-deep);font-weight:600;margin-bottom:8px;}
.form-success-text{color:var(--muted);font-size:16px;}
@media (prefers-reduced-motion: reduce){
  .form-card.form-hiding{transition:none;}
  .form-success.show{animation:none;}
  .checkmark-circle,.checkmark-check{animation:none;stroke-dashoffset:0;}
}

/* ==================================================
   FOOTER
================================================== */
footer{background:var(--pine-deep);color:#C3D2CC;padding:54px 0 30px;}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;}
footer .fmark{font-family:'Fraunces',serif;font-size:22px;color:#fff;font-weight:700;margin-bottom:10px;}
footer .ftag{color:#9FB3AC;font-size:14px;max-width:32ch;}
footer h4{color:#fff;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;font-weight:600;}
footer ul{list-style:none;}
footer li{margin-bottom:10px;}
footer a{color:#C3D2CC;text-decoration:none;font-size:14px;}
footer a:hover{color:#EAD9B4;}
footer .legal{border-top:1px solid #356054;margin-top:40px;padding-top:22px;font-size:12px;color:#8FA39C;text-align:center;}
.legal-copyright{margin-top:10px;}

/* ==================================================
   FORM INTRO (subheading above a form)
================================================== */
.form-intro{max-width:620px;margin:0 auto 34px;}
.form-intro h2{font-family:'Fraunces',serif;font-size:26px;color:var(--pine-deep);font-weight:600;margin-bottom:8px;}
.form-intro p{color:var(--muted);font-size:16px;}

/* ==================================================
   ADVERTISE STATS
================================================== */
.promo-intro{padding:56px 0 104px;}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px;}
.stat{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:28px 22px;text-align:center;}
.stat-num{font-family:'Fraunces',serif;font-size:40px;font-weight:700;color:var(--pine);line-height:1;margin-bottom:8px;}
.stat-label{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;}

/* ==================================================
   ARCHIVE
================================================== */
.archive{padding:48px 0 70px;}
.issue-list{max-width:720px;margin:0 auto;display:grid;gap:16px;}
.issue-card{display:block;background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:22px 26px;text-decoration:none;transition:border-color .2s;}
.issue-card:hover{border-color:var(--pine);}
.issue-date{font-size:12px;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:6px;}
.issue-title{font-family:'Fraunces',serif;font-size:20px;color:var(--pine-deep);font-weight:600;margin-bottom:4px;}
.issue-desc{font-size:14px;color:var(--muted);}
.archive-empty{max-width:620px;margin:0 auto;text-align:center;color:var(--muted);font-size:17px;line-height:1.7;}

/* ==================================================
   ISSUE PAGE (archived newsletter, web version)
================================================== */
.post-wrap{max-width:680px;margin:0 auto;padding:54px 24px 10px;}
.post-eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:12px;}
.post-title{font-family:'Fraunces',serif;font-size:46px;line-height:1.04;color:var(--pine);font-weight:700;margin-bottom:14px;}
.post-tagline{font-size:18px;color:var(--muted);line-height:1.5;}
.post-divider{border:none;border-top:1px solid var(--rule);margin:30px 0;}
.post-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:14px;}
.post-note{font-size:16px;line-height:1.7;color:var(--ink);margin-bottom:14px;}
.post-byline{font-family:'Fraunces',serif;font-style:italic;font-size:16px;color:var(--pine);}
.post-deal{border:2px dashed var(--gold);border-radius:6px;padding:24px 26px;}
.post-deal-company{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--ink);margin-bottom:6px;}
.post-deal-offer{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:8px;}
.post-deal-fine{font-size:14px;line-height:1.6;color:var(--muted);}
.post-event{padding-bottom:22px;margin-bottom:22px;border-bottom:1px solid var(--rule);}
.post-event.last{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.post-event-date{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--pine);font-weight:700;margin-bottom:4px;}
.post-event-name{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:4px;}
.post-event-where{font-size:14px;color:var(--muted);margin-bottom:8px;}
.post-event-desc{font-size:15px;line-height:1.6;color:var(--ink);margin-bottom:10px;}
.post-link{font-size:15px;font-weight:700;color:var(--pine);text-decoration:underline;}
.post-free{font-size:14px;font-weight:700;color:var(--pine);}
.post-accent{border-left:4px solid var(--pine);padding:4px 0 4px 20px;}
.post-accent-name{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:5px;}
.post-accent p{font-size:16px;line-height:1.7;color:var(--ink);}
.post-sponsor{border:1px solid #d8c79b;border-radius:10px;padding:26px;}
.post-sponsor-name{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--ink);margin-bottom:10px;}
.post-sponsor p{font-size:15px;line-height:1.7;color:var(--muted);margin-bottom:14px;}

/* ==================================================
   LEGAL / POLICY PAGES
================================================== */
.policy-content{max-width:760px;margin:0 auto;padding:56px 24px 84px;}
.policy-intro{font-size:18px;line-height:1.7;color:var(--muted);margin-bottom:30px;}
.policy-content h2{font-family:'Fraunces',serif;font-size:26px;color:var(--pine-deep);font-weight:600;margin:40px 0 14px;}
.policy-content h3{font-family:'Fraunces',serif;font-size:19px;color:var(--pine);font-weight:600;margin:24px 0 8px;}
.policy-content p{color:var(--ink);font-size:16px;line-height:1.75;margin-bottom:16px;}
.policy-content strong{color:var(--pine-deep);font-weight:700;}
.policy-content ul{margin:0 0 16px 22px;}
.policy-content li{color:var(--ink);font-size:16px;line-height:1.7;margin-bottom:8px;}
.policy-content a{color:var(--pine);text-decoration:underline;}
.policy-content a:hover{color:var(--gold);}
.policy-contact-box{background:var(--cream-deep);border:1px solid var(--rule);border-radius:12px;padding:24px 26px;margin:26px 0;}
.policy-contact-box p{margin-bottom:6px;}
.policy-updated{margin-top:38px;padding-top:20px;border-top:1px solid var(--rule);font-size:14px;color:var(--muted);font-style:italic;}

/* ==================================================
   RESPONSIVE
================================================== */
@media (max-width:820px){
  .hero h1{font-size:44px;}
  .section-heading{font-size:30px;}
  .cards{grid-template-columns:1fr;}
  .page-header-title{font-size:30px;}
  .form-card{padding:28px 22px;}
  footer .grid{grid-template-columns:1fr 1fr;gap:28px;}
  .stats{grid-template-columns:1fr;}
  .post-title{font-size:34px;}
  .policy-content h2{font-size:22px;}
}
@media (max-width:520px){
  .hero h1{font-size:34px;}
  footer .grid{grid-template-columns:1fr;}
}

/* 404 page */
.nf-intro{text-align:center;}
.nf-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:26px;}
