
/* DriftFactory v0.12 static editorial — clean baseline */
:root{
  --df-primary:#2F5C9F; --df-secondary:#274C84; --df-accent:#B86A00;
  --df-bg:#FFFFFF; --df-surface:#F6F8FB;
  --df-text:#1F2937; --df-muted:#5C6675;
  --df-radius:10px; --df-maxw:1140px;
  --df-line-height:1.6;
}
*{box-sizing:border-box}
html{font-size:16px}
body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--df-bg);color:var(--df-text);line-height:var(--df-line-height)}
a{color:var(--df-primary);text-decoration:none}
a:hover{color:var(--df-secondary);text-decoration:underline}
img{max-width:100%;height:auto;display:block}

/* layout */
.container{max-width:var(--df-maxw);margin:0 auto;padding:0 1.25rem}
header.site-header{background:var(--df-bg);border-bottom:1px solid color-mix(in srgb,var(--df-muted) 22%,transparent);padding:1rem 0;position:sticky;top:0;z-index:10;backdrop-filter:saturate(180%) blur(6px);background:color-mix(in srgb,var(--df-bg) 90%,transparent)}
header.site-header .row{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.2rem;color:var(--df-text)}
.brand img{width:36px;height:36px;border-radius:6px}
nav.top a{margin-left:1.2rem;font-weight:500;color:var(--df-text)}
nav.top a:hover{color:var(--df-primary);text-decoration:none}
@media(max-width:720px){nav.top a{margin-left:.6rem;font-size:.95rem}}

/* hero */
.hero{padding:3rem 0 2rem;text-align:center;border-bottom:1px solid color-mix(in srgb,var(--df-muted) 18%,transparent);margin-bottom:2rem}
.hero h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:0 0 .6rem;line-height:1.15}
.hero p.lead{max-width:680px;margin:0 auto;color:var(--df-muted);font-size:1.05rem}

/* article cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem;margin:0 0 2.4rem}
article.card{background:var(--df-surface);border-radius:var(--df-radius);overflow:hidden;border:1px solid color-mix(in srgb,var(--df-muted) 14%,transparent);display:flex;flex-direction:column;transition:transform .15s ease}
article.card:hover{transform:translateY(-3px)}
article.card a.cover{display:block;aspect-ratio:16/10;background:var(--df-surface);overflow:hidden}
article.card a.cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
article.card:hover a.cover img{transform:scale(1.04)}
article.card .body{padding:.95rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
article.card .tag{display:inline-block;font-size:.72rem;font-weight:700;color:var(--df-primary);text-transform:uppercase;letter-spacing:.05em}
article.card h3{margin:0;font-size:1.1rem;line-height:1.35}
article.card h3 a{color:var(--df-text)}
article.card h3 a:hover{color:var(--df-primary);text-decoration:none}
article.card p.summary{margin:0;color:var(--df-muted);font-size:.92rem;flex:1}
article.card .meta{font-size:.78rem;color:var(--df-muted);margin-top:.4rem}

/* article page */
article.post{max-width:760px;margin:0 auto;padding:1rem 0 3rem}
article.post .tag{display:inline-block;font-size:.78rem;font-weight:700;color:var(--df-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}
article.post h1{font-size:clamp(1.7rem,3.5vw,2.4rem);margin:.2rem 0 .6rem;line-height:1.18}
article.post .byline{color:var(--df-muted);font-size:.92rem;margin-bottom:1.5rem;display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
article.post .byline .author{font-weight:600;color:var(--df-text)}
article.post .featured{margin:0 -1rem 1.6rem;border-radius:var(--df-radius);overflow:hidden}
article.post .featured img{width:100%;aspect-ratio:16/9;object-fit:cover}
article.post h2{font-size:1.45rem;margin:2rem 0 .8rem}
article.post h3{font-size:1.15rem;margin:1.4rem 0 .6rem}
article.post p{margin:0 0 1.1rem;font-size:1.05rem}
article.post img{margin:1.4rem 0;border-radius:var(--df-radius)}
article.post img+em.caption{display:block;text-align:center;font-style:italic;color:var(--df-muted);font-size:.9rem;margin:-1rem 0 1.5rem}
article.post blockquote{margin:1.4rem 0;padding-left:1.25rem;border-left:4px solid var(--df-primary);color:var(--df-muted);font-style:italic}

/* scores + faq + comments */
.scores{margin:2rem 0;padding:1.1rem 1.4rem;background:var(--df-surface);border-radius:var(--df-radius)}
.scores h3{margin:0 0 .6rem;font-size:1.05rem}
.scores .row{display:flex;justify-content:space-between;padding:.35rem 0;border-bottom:1px dashed color-mix(in srgb,var(--df-muted) 25%,transparent);font-size:.95rem}
.scores .row:last-child{border:none}
.scores .row strong{color:var(--df-primary);font-weight:700}
.faq{margin:2rem 0;padding:1.4rem;background:var(--df-surface);border-radius:var(--df-radius)}
.faq h3{margin:0 0 .8rem;font-size:1.15rem}
.faq details{padding:.5rem 0;border-bottom:1px solid color-mix(in srgb,var(--df-muted) 18%,transparent)}
.faq details:last-child{border:none}
.faq summary{cursor:pointer;font-weight:600;padding:.3rem 0;list-style:disclosure-closed}
.faq summary::-webkit-details-marker{display:none}
.faq details[open] summary{color:var(--df-primary)}
.faq p{margin:.5rem 0 0;color:var(--df-muted)}
.comments{margin:2.4rem 0 1rem}
.comments h3{font-size:1.15rem;margin:0 0 1rem}
.comments .comment{padding:.9rem 0;border-bottom:1px solid color-mix(in srgb,var(--df-muted) 14%,transparent);display:flex;gap:.8rem}
.comments .comment:last-child{border:none}
.comments .avatar{flex:0 0 38px;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.85rem}
.comments .body{flex:1}
.comments .head{font-size:.85rem;margin-bottom:.2rem}
.comments .head .name{font-weight:600}
.comments .head .date{color:var(--df-muted);margin-left:.5rem}
.comments .text{color:var(--df-text);font-size:.95rem;line-height:1.5}

/* footer */
footer.site-footer{margin-top:3rem;padding:2.4rem 0 2rem;background:var(--df-surface);border-top:1px solid color-mix(in srgb,var(--df-muted) 18%,transparent);color:var(--df-muted);font-size:.9rem}
footer.site-footer .cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-bottom:1.6rem}
footer.site-footer h4{font-size:.92rem;text-transform:uppercase;letter-spacing:.06em;color:var(--df-text);margin:0 0 .6rem}
footer.site-footer ul{list-style:none;padding:0;margin:0}
footer.site-footer li{margin-bottom:.4rem}
footer.site-footer .bottom{border-top:1px solid color-mix(in srgb,var(--df-muted) 18%,transparent);padding-top:1.4rem;font-size:.82rem;text-align:center}
footer.site-footer .bottom .country-note{display:block;margin-top:.4rem;color:var(--df-muted)}
footer.site-footer a{color:var(--df-muted)}
footer.site-footer a:hover{color:var(--df-primary)}

/* misc */
.section{margin:3rem 0 1.5rem}
.section h2{font-size:1.45rem;margin:0 0 .3rem;display:flex;align-items:center;justify-content:space-between}
.section .more{font-size:.85rem;font-weight:600;color:var(--df-primary)}
.section .lead{color:var(--df-muted);font-size:.95rem;margin:0 0 1.4rem}
.legal-text{max-width:760px;margin:0 auto;padding:1rem 0 3rem}
.legal-text h1{font-size:1.9rem;margin:.2rem 0 1.4rem}
.legal-text p{margin:0 0 1rem;color:var(--df-text)}
