:root{
  --green:#6aa84f;
  --green-dark:#558a3f;
  --text:#222;
  --muted:#666;
  --bg:#fff;
  --card:#f4f5f2;
  --border:#e5e7e1;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:#fff;line-height:1.55}
a{color:var(--green-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

/* --- Site header / nav --- */
.site-header{border-bottom:1px solid var(--border);background:#fff}
.site-header .wrap{max-width:1100px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.site-header .brand img{height:34px;width:auto}
.site-header nav a{margin-left:22px;color:#333;font-weight:500}
.site-header nav a.active{color:var(--green-dark)}

.site-footer{border-top:1px solid var(--border);margin-top:64px;padding:32px 24px;text-align:center;color:var(--muted);font-size:13px}
.site-footer .footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px;margin-bottom:14px}
.site-footer .footer-links a{color:#555}
.site-footer .footer-copy{max-width:780px;margin:0 auto;line-height:1.55;color:#777}

/* Provider grid on topic pages */
.provider-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin:18px 0 24px}
.provider{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 18px}
.provider h3{margin:0 0 6px;font-size:16px}
.provider p{margin:0;color:#555;font-size:14px;line-height:1.5}

/* Legal articles */
.article.legal h1{font-size:32px}
.article.legal .meta{margin-bottom:24px}
.article.legal h2{margin-top:30px;font-size:20px}
.article.legal h3{font-size:17px}

/* --- Generic containers --- */
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.hero{padding:72px 24px;text-align:center;background:linear-gradient(180deg,#f7faf4 0%,#fff 100%)}
.hero h1{font-size:44px;margin:0 0 16px;line-height:1.15}
.hero p{font-size:18px;color:var(--muted);max-width:680px;margin:0 auto 28px}
.btn{display:inline-block;background:var(--green);color:#fff;padding:14px 28px;border-radius:8px;font-weight:700;letter-spacing:.5px;border:0;cursor:pointer;font-size:16px}
.btn:hover{background:var(--green-dark);text-decoration:none;color:#fff}
.btn-block{display:block;width:100%;text-align:center}

/* --- Blog grid --- */
.section{padding-top:56px;padding-bottom:56px}
.section h2{font-size:28px;margin:0 0 24px}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06)}
.card .thumb{height:160px;background:linear-gradient(135deg,#6aa84f,#2d4a23);display:flex;align-items:center;justify-content:center;color:#fff;font-size:48px}
.card .body{padding:20px}
.card .meta{font-size:13px;color:var(--muted);margin-bottom:8px}
.card h3{margin:0 0 8px;font-size:19px;line-height:1.3}
.card h3 a{color:#222}
.card p{margin:0;color:#555;font-size:14px}

/* --- Section head --- */
.section-head{text-align:center;margin-bottom:32px}
.section-head h2{margin:0 0 8px}
.section-head p{color:var(--muted);margin:0;font-size:15px}

/* --- Feature strip (editor's pick) --- */
.feature-strip{display:grid;grid-template-columns:minmax(260px,40%) 1fr;gap:0;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff}
.feature-strip__media{position:relative;background:linear-gradient(135deg,#6aa84f 0%,#2d4a23 100%);display:flex;align-items:center;justify-content:center;min-height:260px}
.feature-strip__icon{font-size:96px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}
.feature-strip__body{padding:36px 36px}
.feature-strip__body .meta{font-size:13px;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.feature-strip__body h2{margin:0 0 14px;font-size:28px;line-height:1.2}
.feature-strip__body h2 a{color:#222}
.feature-strip__body p{color:#444;font-size:16px;margin:0 0 18px;line-height:1.55}
.badge{position:absolute;top:18px;left:18px;background:#fff;color:var(--green-dark);padding:6px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.link-arrow{font-weight:700;color:var(--green-dark)}

/* --- Topic grid --- */
.topic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.topic-card{display:block;padding:28px 22px;background:#fff;border:1px solid var(--border);border-radius:12px;transition:transform .15s ease,border-color .15s ease;color:#222}
.topic-card:hover{transform:translateY(-2px);border-color:#cfd9c7;text-decoration:none}
.topic-card h3{margin:8px 0 6px;font-size:18px}
.topic-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.topic-ic{font-size:32px}

/* --- Tips grid --- */
.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.tip{background:#fff;border:1px solid var(--border);border-radius:12px;padding:22px;position:relative}
.tip-num{display:inline-block;font-size:12px;font-weight:700;color:var(--green-dark);letter-spacing:1.5px;margin-bottom:10px}
.tip h4{margin:0 0 6px;font-size:16px}
.tip p{margin:0;color:#555;font-size:14px;line-height:1.5}
.tip--cta{background:linear-gradient(160deg,#f7faf4 0%,#eaf2e0 100%);border-color:#dbe8cf}
.tip--cta h4{font-size:17px;margin-bottom:8px}
.btn-sm{padding:10px 18px;font-size:14px;margin-top:10px}

/* --- Trust / how we work --- */
.trust{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;background:#f7faf4;border:1px solid #dbe8cf;border-radius:14px;padding:40px}
.trust h2{margin:0 0 14px}
.trust p{color:#444;margin:0 0 12px;font-size:15.5px;line-height:1.6}
.trust-points{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.trust-points li{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 16px;font-size:14.5px;color:#444}
.trust-points strong{color:#222}

/* --- Newsletter --- */
.newsletter{background:#222;color:#fff;border-radius:14px;padding:40px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.newsletter h2{margin:0 0 10px;color:#fff;font-size:24px}
.newsletter p{margin:0;color:#bfc6b6;font-size:15px;line-height:1.55}
.newsletter-form{display:flex;gap:8px;flex-wrap:wrap;position:relative}
.newsletter-form input{flex:1;min-width:0;padding:14px 16px;border-radius:8px;border:0;font-size:15px;background:#fff;color:#222}
.newsletter-form .btn{background:var(--green)}
.newsletter-ok{flex-basis:100%;margin-top:10px;color:#a7d694;font-size:14px}

@media (max-width:820px){
  .feature-strip{grid-template-columns:1fr}
  .feature-strip__media{min-height:180px}
  .feature-strip__body{padding:26px 22px}
  .feature-strip__body h2{font-size:22px}
  .trust{grid-template-columns:1fr;gap:28px;padding:28px}
  .newsletter{grid-template-columns:1fr;padding:28px}
}

/* --- Article --- */
.article{max-width:760px;margin:0 auto;padding:48px 24px}
.article h1{font-size:38px;line-height:1.2;margin:0 0 12px}
.article .meta{color:var(--muted);margin-bottom:32px;font-size:14px}
.article h2{font-size:24px;margin:36px 0 12px}
.article h3{font-size:18px;margin:28px 0 8px}
.article p,.article li{font-size:16.5px;color:#333}
.article ul{padding-left:22px}
.article .cta-box{margin:40px 0;padding:28px;background:#f7faf4;border:1px solid #dbe8cf;border-radius:12px;text-align:center}
.article .cta-box h3{margin:0 0 8px;font-size:20px}
.article .cta-box p{margin:0 0 16px;color:var(--muted)}

/* --- Landing page (Mockup) --- */
.lp-body{background:#fafafa}
.lp-header{background:#fff;border-bottom:1px solid var(--border);padding:18px 24px;display:flex;justify-content:center}
.lp-header img{height:38px}
.lp-wrap{max-width:420px;margin:0 auto;padding:90px 20px 60px}
.lp-card{background:#eef0eb;border-radius:10px;padding:42px 20px;text-align:center}
.lp-card h2{margin:0 0 18px;font-size:clamp(13px,4.1vw,17px);color:#222;font-weight:700;white-space:nowrap;letter-spacing:-.2px}
.lp-card .big-btn{background:var(--green);color:#fff;width:100%;padding:16px;border:0;border-radius:6px;font-weight:700;font-size:15px;letter-spacing:1px;cursor:pointer}
.lp-card .big-btn:hover{background:var(--green-dark)}
.lp-card .note{font-size:12px;color:#666;margin-top:12px;line-height:1.4}

.lp-section-title{text-align:center;color:var(--green-dark);font-weight:700;margin:28px 0 18px;font-size:15px}

.lp-steps{display:flex;flex-direction:column;gap:0;margin:0 auto 28px;max-width:280px}
.lp-step{display:flex;align-items:center;gap:14px;padding:6px 0;position:relative}
.lp-step .num{width:30px;height:30px;border-radius:50%;border:2px solid var(--green);color:var(--green-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;background:#fff;flex-shrink:0;z-index:1}
.lp-step .txt{font-size:13px}
.lp-step .txt small{display:block;color:#888;font-size:11px;margin-bottom:1px}
.lp-step:not(:last-child)::after{content:"";position:absolute;left:14px;top:32px;width:2px;height:20px;background:#cfd9c7}

.lp-features{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.lp-feature{background:#fff;border:1px solid var(--border);border-radius:8px;padding:14px 6px;text-align:center}
.lp-feature .ic{font-size:26px;margin-bottom:6px;color:var(--green-dark)}
.lp-feature .lbl{font-size:11px;color:#555;font-weight:600;letter-spacing:.3px}

.lp-serial{background:#fff;border:1px solid var(--border);border-radius:8px;padding:16px 14px;text-align:center;margin-bottom:16px}
.lp-serial .title{font-weight:700;font-size:13px;margin-bottom:2px}
.lp-serial .sub{font-size:11px;color:#888;margin-bottom:10px}
.lp-serial .code{display:flex;justify-content:center;gap:6px;font-family:"SF Mono",Menlo,monospace;font-size:14px;color:#333;flex-wrap:wrap}
.lp-serial .code span{background:#f4f5f2;border:1px solid var(--border);padding:5px 8px;border-radius:4px;letter-spacing:1.5px}

.lp-foot-note{text-align:center;font-size:11px;color:#888;margin-top:14px}

.lp-faq{margin-top:48px}
.lp-faq h3{text-align:center;font-size:18px;margin:0 0 18px;color:#222;font-weight:700}
.lp-faq details{background:#fff;border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden}
.lp-faq details[open]{border-color:#cfd9c7}
.lp-faq summary{list-style:none;cursor:pointer;padding:14px 42px 14px 16px;font-size:14px;font-weight:600;color:#222;position:relative;line-height:1.35}
.lp-faq summary::-webkit-details-marker{display:none}
.lp-faq summary::after{content:"+";position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:20px;color:#6aa84f;font-weight:400;line-height:1}
.lp-faq details[open] summary::after{content:"–"}
.lp-faq details p{margin:0;padding:0 16px 16px;font-size:13.5px;color:#555;line-height:1.55}

/* Step 2 modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:flex-end;justify-content:center;padding:16px 12px calc(41px + env(safe-area-inset-bottom,0px));z-index:50;overflow-y:auto}
.modal-backdrop.open{display:flex}
.modal{background:#eef0eb;border-radius:10px;padding:28px 24px;max-width:420px;width:100%;position:relative;animation:pop .22s ease-out}
@keyframes pop{from{transform:translateY(24px);opacity:0}to{transform:none;opacity:1}}
@media (min-width:641px){
  .modal-backdrop{align-items:center;padding:40px 16px}
  @keyframes pop{from{transform:translateY(-8px);opacity:0}to{transform:none;opacity:1}}
}
.modal .close{position:absolute;top:14px;right:14px;background:none;border:0;font-size:22px;cursor:pointer;color:#666;line-height:1}
.modal h2{margin:0 0 18px;font-size:22px;line-height:1.2}
.modal label{display:block;font-weight:700;font-size:13px;margin:18px 0 6px}
.modal input[type=email]{width:100%;padding:14px 14px;border:1px solid #cfd3c9;border-radius:6px;font-size:15px;background:#fff}
.modal input[type=email]:focus{outline:2px solid var(--green);outline-offset:0}
.modal .disclaim{font-size:11px;color:#888;text-align:center;margin-top:10px;line-height:1.4}
.modal .disclaim a{color:#666;text-decoration:underline}

/* Responsive */
@media (max-width:640px){
  .site-header .wrap{flex-wrap:wrap}
  .hero h1{font-size:32px}
  .hero{padding:48px 20px}
  .article h1{font-size:28px}
}
