/* Organic Gardening Collective — "The Almanac" shared stylesheet */
:root{
  --ink:#243420; --ink-soft:#48584a; --paper:#f7f1e3; --paper-deep:#efe5cf;
  --green:#3c6e36; --green-deep:#27481f; --rust:#b4552d; --gold:#c89441; --line:#cdbf9f;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--paper); color:var(--ink); font-family:'Nunito Sans',sans-serif; line-height:1.6;
  background-image:radial-gradient(rgba(120,100,60,.06) 1px, transparent 1px); background-size:7px 7px;}
.serif{font-family:'Fraunces',serif}
.hand{font-family:'Caveat',cursive}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.narrow{max-width:760px}
.rule{border:none;border-top:1px solid var(--line)}
.rule-thick{border:none;border-top:3px double var(--ink)}
a{color:var(--green)}

/* Masthead */
.topline{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);display:flex;justify-content:space-between;padding:10px 0}
.masthead{text-align:center;padding:18px 0 10px}
.masthead h1{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(2.4rem,5.5vw,4.2rem);letter-spacing:-.01em;line-height:1}
.masthead h1 a{color:inherit;text-decoration:none}
.masthead .est{font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:var(--rust);margin-top:8px}
nav.mainnav{display:flex;justify-content:center;gap:22px;flex-wrap:wrap;padding:14px 0;font-weight:800;font-size:.86rem;letter-spacing:.12em;text-transform:uppercase}
nav.mainnav a{color:var(--ink);text-decoration:none;border-bottom:2px solid transparent;padding:10px 8px;display:inline-block}
nav.mainnav a:hover{color:var(--rust);border-color:var(--rust)}
nav.mainnav a.active{color:var(--green);border-color:var(--green)}
nav.mainnav a.join{background:var(--green);color:#fff;padding:6px 18px;border-radius:999px}
nav.mainnav a.join:hover{color:#fff;background:var(--green-deep);border-color:transparent}

/* Almanac bar */
.almanac{background:var(--green-deep);color:var(--paper);margin-top:6px}
.almanac .wrap{display:grid;grid-template-columns:200px 1fr;gap:0;align-items:stretch}
.alm-label{padding:26px 24px;border-right:1px dashed rgba(247,241,227,.35)}
.alm-label .hand{font-size:1.5rem;color:var(--gold)}
.alm-label h2{font-family:'Fraunces',serif;font-size:2rem;line-height:1.05}
.alm-body{padding:20px 0 20px 30px}
.months{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.months button{background:transparent;border:1px solid rgba(247,241,227,.4);color:var(--paper);
  padding:4px 12px;border-radius:999px;font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:.78rem;cursor:pointer}
.months button.on{background:var(--gold);color:var(--green-deep);border-color:var(--gold)}
.alm-items{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.alm-item b{display:block;font-family:'Fraunces',serif;font-size:1.04rem;color:var(--gold)}
.alm-item span{font-size:.9rem;opacity:.92}

/* Subscribe strip */
.substrip{background:#1b3315;color:var(--paper)}
.substrip .wrap{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 28px;flex-wrap:wrap}
.substrip .hand{font-family:'Caveat',cursive;font-size:1.25rem;color:var(--gold)}
.substrip form{display:flex;gap:8px;flex-wrap:wrap}
.substrip input{padding:8px 14px;border-radius:999px;border:none;min-width:220px;font-family:inherit}

/* Feature */
.feature{display:grid;grid-template-columns:1.15fr .85fr;gap:44px;padding:46px 0 38px;align-items:center}
.kicker{color:var(--rust);font-weight:800;letter-spacing:.22em;text-transform:uppercase;font-size:.74rem}
.feature h2{font-family:'Fraunces',serif;font-weight:800;font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.08;margin:10px 0 14px}
.feature p.lede{font-size:1.08rem;color:var(--ink-soft)}
.feature p.lede::first-letter{font-family:'Fraunces',serif;font-size:2.4em;float:left;line-height:.9;padding-right:8px;color:var(--green)}
.byline{margin-top:14px;font-size:.86rem;color:var(--ink-soft)}
.byline .hand{font-size:1.25rem;color:var(--green-deep)}
.btn{display:inline-block;background:var(--green);color:#fff;border:none;font-weight:800;letter-spacing:.06em;
  padding:12px 26px;border-radius:4px;text-decoration:none;font-size:.9rem;cursor:pointer;box-shadow:3px 3px 0 var(--green-deep)}
.btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--green-deep)}
.btn.ghost{background:transparent;color:var(--green-deep);box-shadow:3px 3px 0 var(--line);border:1.5px solid var(--green-deep)}
.btn.small{padding:8px 18px;font-size:.82rem}
.frame{position:relative;padding:14px;background:#fff;box-shadow:0 10px 26px rgba(40,40,20,.18)}
.frame img{width:100%;display:block}
.frame .cap{font-family:'Caveat',cursive;font-size:1.3rem;text-align:center;padding-top:10px;color:var(--ink-soft)}

/* Sections */
.secthead{display:flex;align-items:baseline;justify-content:space-between;margin:34px 0 6px;gap:16px;flex-wrap:wrap}
.secthead h3{font-family:'Fraunces',serif;font-size:1.7rem}
.secthead a{color:var(--rust);font-weight:800;font-size:.85rem;text-decoration:none;letter-spacing:.08em;text-transform:uppercase}
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:22px 0 8px}
.story{border-top:4px solid var(--ink);padding-top:14px}
.story img{width:100%;aspect-ratio:3/2;object-fit:cover}
.story .tag{font-size:.7rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--rust);margin-top:12px;display:block}
.story h4{font-family:'Fraunces',serif;font-size:1.28rem;line-height:1.2;margin:6px 0}
.story h4 a{color:var(--ink);text-decoration:none}
.story h4 a:hover{color:var(--green)}
.story p{font-size:.92rem;color:var(--ink-soft)}
.story .read{display:inline-block;margin-top:8px;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green);text-decoration:none}

/* Curriculum */
.curriculum{background:var(--paper-deep);border:1.5px solid var(--line);border-radius:6px;margin:40px 0;padding:34px;display:grid;grid-template-columns:.9fr 1.4fr;gap:36px}
.curriculum h3{font-family:'Fraunces',serif;font-size:2rem;line-height:1.1}
.curriculum .hand{font-size:1.5rem;color:var(--rust)}
.lessons{display:grid;gap:10px}
.lesson{display:flex;gap:14px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:12px 16px}
.lesson .num{width:34px;height:34px;border-radius:50%;border:2px solid var(--green);display:grid;place-items:center;
  font-weight:800;color:var(--green);flex:none;font-size:.9rem}
.lesson.done .num{background:var(--green);color:#fff}
.lesson.done .t{text-decoration:line-through;color:var(--ink-soft)}
.lesson .t{font-weight:700}
.lesson .meta{margin-left:auto;font-size:.78rem;color:var(--ink-soft);white-space:nowrap}
.progressbar{height:10px;background:#fff;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin:14px 0 4px}
.progressbar i{display:block;height:100%;background:var(--green);border-radius:999px}

/* Letters + Tended */
.duo{display:grid;grid-template-columns:1.3fr .7fr;gap:30px;margin:8px 0 40px}
.letters{border:1.5px solid var(--line);border-radius:6px;padding:26px;background:#fffdf6}
.letter{padding:16px 0;border-bottom:1px dashed var(--line)}
.letter:last-child{border:none}
.letter .q{font-family:'Fraunces',serif;font-weight:700;font-size:1.05rem}
.letter .a{font-size:.92rem;color:var(--ink-soft);margin-top:4px}
.letter .who{font-family:'Caveat',cursive;font-size:1.2rem;color:var(--rust)}
.tended{background:var(--green-deep);color:var(--paper);border-radius:6px;padding:28px;position:relative;overflow:hidden}
.tended h3{font-family:'Fraunces',serif;font-size:1.7rem;line-height:1.15;color:var(--gold)}
.tended p{font-size:.92rem;margin:10px 0 16px;opacity:.92}
.tended .hand{font-size:1.4rem;color:var(--gold)}
.tended ul{list-style:none;margin:0 0 18px}
.tended li{padding:6px 0;font-size:.9rem;border-bottom:1px dashed rgba(247,241,227,.25)}
.tended li::before{content:"❧ ";color:var(--gold)}

/* Newsletter + footer */
.newsletter{text-align:center;border-top:3px double var(--ink);border-bottom:3px double var(--ink);padding:38px 20px;margin-bottom:40px}
.newsletter h3{font-family:'Fraunces',serif;font-size:2rem}
.newsletter p{color:var(--ink-soft);margin:8px 0 18px}
.newsletter form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.newsletter input{padding:12px 18px;border:1.5px solid var(--ink);border-radius:4px;background:#fffdf6;min-width:300px;font-family:inherit}
footer{padding:26px 0 50px;color:var(--ink-soft);font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
footer a{color:var(--ink-soft)}

/* ---- Inner-page components ---- */
.breadcrumb{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);padding:18px 0 0}
.breadcrumb a{color:var(--rust);text-decoration:none;font-weight:800}
.breadcrumb span{margin:0 8px;color:var(--line)}

.pagehero{padding:30px 0 24px;border-bottom:3px double var(--ink);margin-bottom:8px}
.pagehero .kicker{display:block;margin-bottom:8px}
.pagehero h1{font-family:'Fraunces',serif;font-weight:800;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.05}
.pagehero p{font-size:1.05rem;color:var(--ink-soft);margin-top:12px;max-width:680px}

/* Filter chips */
.chips{display:flex;gap:8px;flex-wrap:wrap;padding:22px 0 6px}
.chips button{background:transparent;border:1.5px solid var(--line);color:var(--ink);padding:6px 16px;border-radius:999px;
  font-family:inherit;font-weight:700;font-size:.82rem;cursor:pointer}
.chips button.on{background:var(--green);color:#fff;border-color:var(--green)}

/* Guide cards grid */
.guidegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:14px 0 30px}
.gcard{background:#fffdf6;border:1.5px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}
.gcard img{width:100%;aspect-ratio:3/2;object-fit:cover}
.gcard .body{padding:16px 18px 20px;display:flex;flex-direction:column;flex:1}
.gcard .tag{font-size:.7rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--rust)}
.gcard h4{font-family:'Fraunces',serif;font-size:1.24rem;line-height:1.2;margin:6px 0 8px}
.gcard h4 a{color:var(--ink);text-decoration:none}
.gcard h4 a:hover{color:var(--green)}
.gcard p{font-size:.9rem;color:var(--ink-soft);flex:1}
.gcard .meta{margin-top:12px;font-size:.78rem;color:var(--ink-soft);display:flex;justify-content:space-between}

/* Article body */
.article{padding:8px 0 20px}
.article .hero{margin:18px 0 26px}
.article .hero img{width:100%;border-radius:6px;display:block}
.article .hero .cap{font-family:'Caveat',cursive;font-size:1.2rem;color:var(--ink-soft);text-align:center;padding-top:8px}
.prose{font-size:1.08rem;color:var(--ink)}
.prose>p{margin:0 0 18px}
.prose h2{font-family:'Fraunces',serif;font-size:1.7rem;margin:30px 0 10px;line-height:1.15}
.prose h3{font-family:'Fraunces',serif;font-size:1.3rem;margin:24px 0 8px}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{margin:6px 0}
.prose blockquote{border-left:4px solid var(--gold);background:var(--paper-deep);padding:14px 20px;margin:22px 0;font-family:'Fraunces',serif;font-style:italic;font-size:1.15rem;border-radius:0 6px 6px 0}
.callout{background:var(--paper-deep);border:1.5px solid var(--line);border-radius:6px;padding:20px 24px;margin:24px 0}
.callout .hand{font-size:1.4rem;color:var(--rust);display:block}
.callout b{font-family:'Fraunces',serif}
.tagrow{display:flex;gap:8px;flex-wrap:wrap;margin:26px 0}
.tagrow span{font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green-deep);background:var(--paper-deep);border:1px solid var(--line);padding:4px 12px;border-radius:999px}
.authorbox{display:flex;gap:16px;align-items:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;margin:8px 0 30px}
.authorbox .avatar{width:56px;height:56px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-family:'Fraunces',serif;font-size:1.5rem;flex:none}
.authorbox .who{font-family:'Caveat',cursive;font-size:1.5rem;color:var(--green-deep)}
.authorbox p{font-size:.9rem;color:var(--ink-soft)}

/* Stat row */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:24px 0}
.stat{text-align:center;border:1.5px solid var(--line);border-radius:6px;padding:22px 12px;background:#fffdf6}
.stat b{display:block;font-family:'Fraunces',serif;font-size:2.2rem;color:var(--green-deep);line-height:1}
.stat span{font-size:.82rem;color:var(--ink-soft);letter-spacing:.04em}

/* App feature rows */
.appgrid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:34px 0}
.appgrid.rev .txt{order:2}
.appgrid h3{font-family:'Fraunces',serif;font-size:1.6rem;margin-bottom:8px}
.appgrid p{color:var(--ink-soft)}
.featurelist{list-style:none;display:grid;gap:14px;margin:8px 0}
.featurelist li{display:flex;gap:12px;align-items:flex-start}
.featurelist .ic{width:32px;height:32px;border-radius:8px;background:var(--paper-deep);border:1px solid var(--line);display:grid;place-items:center;flex:none;color:var(--green)}

/* Join popup (shared account) */
.ogc-modal{position:fixed;inset:0;background:rgba(20,30,15,.55);display:grid;place-items:center;z-index:60;padding:18px}
.ogc-modal .ogc-sheet{background:var(--paper);border:1.5px solid var(--line);border-radius:12px;max-width:430px;width:100%;
  padding:26px 24px;position:relative;box-shadow:0 18px 50px rgba(20,30,15,.4);max-height:92vh;overflow:auto}
.ogc-sheet h2{font-family:'Fraunces',serif;font-size:1.6rem;text-align:center}
.ogc-sheet .sub{text-align:center;color:var(--ink-soft);font-size:.9rem;margin:4px 0 14px}
.ogc-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:1.7rem;line-height:1;color:var(--ink-soft);cursor:pointer}
.ogc-tabs{display:flex;gap:6px;background:var(--paper-deep);border-radius:999px;padding:4px;margin-bottom:14px}
.ogc-tabs button{flex:1;border:none;background:transparent;padding:8px;border-radius:999px;font-weight:800;font-size:.85rem;color:var(--ink-soft);cursor:pointer}
.ogc-tabs button.on{background:#fff;color:var(--green-deep);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.ogc-sheet label{display:block;font-weight:700;font-size:.82rem;margin:10px 0 4px}
.ogc-sheet input{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:7px;background:#fff;font-family:inherit;font-size:1rem}
.ogc-sheet input:focus{outline:2px solid var(--green);border-color:var(--green)}
.ogc-sheet .btn{margin-top:14px}
.ogc-err{background:#fbe7df;border:1px solid var(--rust);color:#7a2f15;border-radius:7px;padding:9px 12px;font-size:.88rem;margin:8px 0}
.ogc-ok{background:var(--paper-deep);border:1px solid var(--line);border-radius:7px;padding:9px 12px;font-size:.88rem;margin:8px 0}
.ogc-alt{text-align:center;margin-top:12px}
.ogc-alt button{background:none;border:none;color:var(--green);font-weight:700;text-decoration:underline;cursor:pointer;font-size:.88rem}
.ogc-spin{width:16px;height:16px;border:3px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;display:inline-block;animation:ogcspin .7s linear infinite;vertical-align:-2px}
@keyframes ogcspin{to{transform:rotate(360deg)}}

@media(max-width:900px){
  .almanac .wrap,.feature,.curriculum,.duo,.appgrid,.appgrid.rev .txt{grid-template-columns:1fr}
  .appgrid.rev .txt{order:0}
  .alm-items,.cols3,.guidegrid,.stats{grid-template-columns:1fr}
  .alm-label{border-right:none;border-bottom:1px dashed rgba(247,241,227,.35)}
}
