/*
Theme Name: Custom Auto Theme
Author: System
Version: 1.0
*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Open+Sans:wght@300;400;600&display=swap');

html{scroll-behavior:smooth}
a{display:inline-block;text-align:center}

:root{
  --primary:#2d6a4f;
  --accent:#52b788;
  --bg:#faf8f5;
  --bg-sec:#f0ebe3;
  --text:#1b1b1b;
  --r:2px;
  --fh:'Playfair Display',Georgia,serif;
  --fb:'Open Sans',sans-serif;
  --mw:780px;
  --sp:1.5rem
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);background:var(--bg);color:var(--text);line-height:1.75;font-size:1rem}

/* ===== HEADER ===== */
.site-header{background:var(--bg);border-bottom:2px solid var(--primary);padding:1rem var(--sp);position:sticky;top:0;z-index:100}
.hdr-in{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.site-logo{font-family:var(--fh);font-size:1.6rem;font-weight:700;color:var(--primary);text-decoration:none;display:inline-block;text-align:left}
.site-nav{display:none;gap:2rem;align-items:center}
.site-nav a{font-size:.85rem;color:var(--text);text-decoration:none;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding-bottom:2px;border-bottom:2px solid transparent;transition:border-color .25s,color .25s;display:inline-block;text-align:center}
.site-nav a:hover{color:var(--primary);border-bottom-color:var(--accent)}

/* Burger */
.burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;border:none;background:none;padding:4px;align-self:center}
.burger span{width:26px;height:2px;background:var(--primary);display:block;transition:transform .3s,opacity .3s}

/* Mobile menu – checkbox hack */
.menu-toggle{display:none}
.menu-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;cursor:pointer}
.mobile-nav{position:fixed;top:0;right:-100%;width:min(320px,85vw);height:100vh;background:var(--bg);z-index:201;padding:2rem;transition:right .32s ease;border-left:2px solid var(--primary);display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto}
.mobile-nav a{font-family:var(--fh);font-size:1.35rem;color:var(--text);text-decoration:none;border-bottom:1px solid var(--bg-sec);padding-bottom:.75rem;display:block;text-align:left;transition:color .2s}
.mobile-nav a:hover{color:var(--primary)}
.mob-close{display:inline-block;text-align:center;background:none;border:2px solid var(--primary);color:var(--primary);padding:.45rem 1rem;font-size:.9rem;cursor:pointer;border-radius:var(--r);font-family:var(--fb);text-decoration:none;align-self:flex-start;margin-bottom:.5rem;transition:background .2s,color .2s}
.mob-close:hover{background:var(--primary);color:#fff}

.menu-toggle:checked~.menu-overlay{display:block}
.menu-toggle:checked~.mobile-nav{right:0}

@media(min-width:768px){
  .site-nav{display:flex}
  .burger{display:none}
}

/* ===== BREADCRUMBS ===== */
.breadcrumbs{padding:.65rem var(--sp);border-bottom:1px solid var(--bg-sec);background:var(--bg)}
.bc-in{max-width:var(--mw);margin:0 auto;font-size:.8rem;color:#888;display:flex;gap:.35rem;flex-wrap:wrap;align-items:center}
.bc-in a{color:var(--primary);text-decoration:none;display:inline;transition:text-decoration .2s}
.bc-in a:hover{text-decoration:underline}
.bc-sep{color:#ccc;display:inline}

/* ===== ARTICLE WRAP ===== */
.art-wrap{max-width:var(--mw);margin:0 auto;padding:2.5rem var(--sp) 4rem}

/* Meta */
.art-meta{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center;margin-bottom:1.25rem}
.rubric-tag{background:var(--primary);color:#fff;padding:.22rem .8rem;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--r);display:inline-block}
.read-time{font-size:.82rem;color:#999;display:inline}

/* Title */
.art-title{font-family:var(--fh);font-size:clamp(1.9rem,5vw,2.9rem);font-weight:700;line-height:1.18;margin-bottom:.9rem;color:var(--text)}

/* Byline (Structure A) */
.art-byline{display:flex;flex-wrap:wrap;gap:.4rem .9rem;align-items:center;font-size:.84rem;color:#777;border-top:1px solid var(--bg-sec);border-bottom:1px solid var(--bg-sec);padding:.7rem 0;margin-bottom:2rem}
.art-byline strong{color:var(--text)}

/* Byline slim (Structure B) */
.art-byline-slim{font-size:.82rem;color:#999;margin-bottom:1.75rem;display:block}

/* Image */
.art-img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r);border:1px solid var(--bg-sec);display:block;margin-bottom:2rem}

/* Body text */
.art-body{font-size:1.04rem}
.art-body h2{font-family:var(--fh);font-size:clamp(1.3rem,3.5vw,1.72rem);font-weight:600;margin:2.75rem 0 .9rem;padding-top:2.75rem;border-top:1px solid var(--bg-sec);color:var(--primary);line-height:1.25}
.art-body p{margin-bottom:1.2rem;color:var(--text)}
.lede{font-size:1.14rem;font-weight:600;color:#3a3a3a;margin-bottom:1.5rem;line-height:1.65;display:block;border-left:3px solid var(--accent);padding-left:1rem}

/* Pull-quote */
.pull-quote{border-left:4px solid var(--accent);padding:1.2rem 1.5rem;margin:2.75rem 0;background:var(--bg-sec);border-radius:0 var(--r) var(--r) 0}
.pull-quote blockquote{font-family:var(--fh);font-size:1.22rem;font-style:italic;color:var(--primary);line-height:1.5}
.pull-quote cite{display:block;margin-top:.65rem;font-size:.82rem;color:#777;font-style:normal}

/* Disclaimer */
.art-disclaimer{background:var(--bg-sec);border:1px solid var(--accent);border-radius:var(--r);padding:1rem 1.25rem;margin:2.75rem 0 1.25rem;font-size:.87rem;color:#555;line-height:1.65}
.art-disclaimer strong{color:var(--primary)}

/* Tags */
.art-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin:1.25rem 0 2.75rem}
.art-tags a{border:1px solid var(--accent);color:var(--primary);padding:.28rem .72rem;font-size:.8rem;border-radius:var(--r);text-decoration:none;transition:background .2s,color .2s;display:inline-block}
.art-tags a:hover{background:var(--accent);color:#fff}

/* Divider */
hr.divider{border:none;border-top:1px solid var(--bg-sec);margin:2.5rem 0}

/* Author box (Structure A) */
.author-box{border:1px solid var(--bg-sec);border-radius:var(--r);padding:1.5rem;display:flex;gap:1.25rem;align-items:flex-start;background:var(--bg-sec)}
.author-avatar{width:62px;height:62px;min-width:62px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.45rem;color:#fff;font-weight:700;border:2px solid var(--accent)}
.author-info h3{font-family:var(--fh);font-size:1.05rem;margin-bottom:.2rem;color:var(--text)}
.author-info p{font-size:.86rem;color:#666;margin:0;line-height:1.55}

/* Audio player (Structure B) */
.audio-wrap{border:1px solid var(--accent);border-radius:var(--r);padding:1.2rem 1.5rem;margin-bottom:2.25rem;background:var(--bg-sec);display:flex;flex-direction:column;gap:.6rem}
.audio-top{display:flex;align-items:center;gap:.75rem}
.audio-icon{font-size:1.6rem;line-height:1}
.audio-meta{display:flex;flex-direction:column;gap:.1rem}
.audio-label-txt{font-size:.75rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em;display:block}
.audio-title-txt{font-family:var(--fh);font-size:.95rem;color:var(--text);display:block}
.audio-wrap audio{width:100%;accent-color:var(--primary);margin-top:.25rem}

/* Read also */
.read-also{margin:3.25rem 0 2rem}
.read-also h2{font-family:var(--fh);font-size:1.35rem;font-weight:600;margin-bottom:1.25rem;padding-bottom:.65rem;border-bottom:2px solid var(--primary);color:var(--text)}
.ra-grid{display:grid;grid-template-columns:1fr;gap:1rem}
.ra-card{border:1px solid var(--bg-sec);border-radius:var(--r);padding:1rem 1.2rem;background:var(--bg);text-decoration:none;color:var(--text);transition:border-color .22s;display:block;text-align:left}
.ra-card:hover{border-color:var(--accent)}
.ra-rubric{font-size:.73rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem;display:block}
.ra-title{font-family:var(--fh);font-size:.97rem;font-weight:600;margin-bottom:.2rem;display:block;color:var(--text)}
.ra-time{font-size:.78rem;color:#aaa;display:block}
@media(min-width:600px){.ra-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.ra-grid{grid-template-columns:repeat(3,1fr)}}

/* Subscribe section */
.subscribe-section{background:var(--bg-sec);border-top:2px solid var(--primary);border-bottom:2px solid var(--primary);padding:3.25rem var(--sp)}
.sub-inner{max-width:510px;margin:0 auto;text-align:center}
.sub-inner h2{font-family:var(--fh);font-size:1.65rem;margin-bottom:.65rem;color:var(--text)}
.sub-inner p{color:#666;margin-bottom:1.5rem;font-size:.94rem;line-height:1.6}
.sub-form{display:flex;flex-direction:column;gap:.7rem}
.sub-form input[type=email]{padding:.82rem 1rem;border:1px solid var(--accent);border-radius:var(--r);font-family:var(--fb);font-size:.97rem;background:var(--bg);color:var(--text);outline:none;transition:border-color .2s;width:100%}
.sub-form input[type=email]:focus{border-color:var(--primary)}
.sub-form button{padding:.82rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--r);font-family:var(--fb);font-size:.97rem;font-weight:600;cursor:pointer;transition:background .22s;white-space:nowrap;display:inline-block}
.sub-form button:hover{background:var(--accent)}
@media(min-width:480px){.sub-form{flex-direction:row}.sub-form input[type=email]{flex:1}}

/* Footer */
.site-footer{background:var(--primary);color:#fff;padding:2.5rem var(--sp)}
.ftr-in{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:1.5rem}
.ftr-brand a{font-family:var(--fh);font-size:1.45rem;font-weight:700;color:#fff;text-decoration:none;display:inline-block;text-align:left}
.ftr-brand p{font-size:.83rem;color:rgba(255,255,255,.65);margin-top:.4rem;display:block}
.ftr-links{display:flex;flex-wrap:wrap;gap:.9rem .75rem;align-items:center}
.ftr-links a{color:rgba(255,255,255,.82);text-decoration:none;font-size:.83rem;border-bottom:1px solid transparent;transition:border-color .2s,color .2s;display:inline-block}
.ftr-links a:hover{color:#fff;border-bottom-color:var(--accent)}
.ftr-disc{font-size:.78rem;color:rgba(255,255,255,.55);line-height:1.55;border-top:1px solid rgba(255,255,255,.14);padding-top:1.25rem;grid-column:1/-1;display:block}
@media(min-width:768px){.ftr-in{grid-template-columns:1fr 1fr}}

/* Cookie banner – CSS-only checkbox hack */
.cookie-toggle{display:none}
.cookie-banner{position:fixed;bottom:20px;right:20px;width:min(340px,calc(100vw - 40px));background:var(--bg);border:1px solid var(--primary);border-radius:var(--r);padding:1.2rem 1.3rem;z-index:1000}
.cookie-banner p{font-size:.84rem;color:var(--text);margin-bottom:.9rem;line-height:1.55}
.cookie-banner p a{color:var(--primary);text-decoration:underline;display:inline}
.ck-btns{display:flex;gap:.65rem;flex-wrap:wrap}
.ck-btn{padding:.46rem .95rem;font-size:.83rem;border-radius:var(--r);cursor:pointer;font-family:var(--fb);font-weight:600;transition:background .2s,color .2s;display:inline-block;text-align:center}
.ck-accept{background:var(--primary);color:#fff;border:none}
.ck-accept:hover{background:var(--accent)}
.ck-decline{background:none;color:var(--primary);border:1px solid var(--primary)}
.ck-decline:hover{background:var(--bg-sec)}
.cookie-toggle:checked~.cookie-banner{display:none}

/* 404 */
.e404-wrap{min-height:78vh;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:3rem var(--sp);gap:.9rem}
.e404-leaf{font-size:4.5rem;line-height:1;filter:grayscale(.3)}
.e404-num{font-family:var(--fh);font-size:clamp(5.5rem,22vw,9.5rem);font-weight:700;color:var(--bg-sec);-webkit-text-stroke:2px var(--primary);text-stroke:2px var(--primary);line-height:1}
.e404-title{font-family:var(--fh);font-size:clamp(1.45rem,4vw,2.1rem);color:var(--primary);margin-top:.25rem}
.e404-text{color:#777;max-width:420px;font-size:.97rem;line-height:1.65}
.e404-link{background:var(--primary);color:#fff;padding:.82rem 2rem;border-radius:var(--r);text-decoration:none;font-weight:600;transition:background .22s;font-size:.97rem;margin-top:.5rem;display:inline-block}
.e404-link:hover{background:var(--accent)}


/* ===== HOME INTRO CARD ===== */
.home-intro-card{background:var(--bg-sec);border-left:4px solid var(--accent);border-radius:0 var(--r) var(--r) 0;padding:1.2rem 1.5rem;margin-bottom:2rem}
.home-intro-text{font-family:var(--fh);font-size:1.1rem;font-style:italic;color:var(--primary);margin:0;line-height:1.6}

/* ===== POLICY PAGES ===== */
.policy-main{padding:0 0 4rem}
.policy-wrap{max-width:760px;margin:0 auto;padding:0 var(--sp)}
.policy-hero{padding:3rem 0 2rem;border-bottom:2px solid var(--primary);margin-bottom:2.5rem}
.policy-label{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;display:block}
.policy-hero h1{font-family:var(--fh);font-size:clamp(1.9rem,5vw,2.75rem);font-weight:700;color:var(--text);line-height:1.18;margin-bottom:.75rem}
.policy-updated{font-size:.83rem;color:#999;display:block}
.policy-section{margin-bottom:2.25rem;padding-bottom:2.25rem;border-bottom:1px solid var(--bg-sec)}
.policy-section:last-child{border-bottom:none}
.policy-section h2{font-family:var(--fh);font-size:1.25rem;font-weight:600;color:var(--primary);margin-bottom:.9rem;padding-top:.5rem}
.policy-section p{font-size:.97rem;color:var(--text);margin-bottom:1rem;line-height:1.72}
.policy-section p:last-child{margin-bottom:0}
.policy-section a{color:var(--primary);text-decoration:underline;display:inline}
.policy-section a:hover{color:var(--accent)}

/* ===== SUCCESS PAGE ===== */
.success-main{min-height:72vh;display:flex;align-items:center;justify-content:center;padding:3rem var(--sp)}
.success-wrap{max-width:540px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.1rem}
.success-icon{font-size:4.5rem;line-height:1}
.success-title{font-family:var(--fh);font-size:clamp(2rem,6vw,3rem);font-weight:700;color:var(--primary);line-height:1.15}
.success-subtitle{font-size:1.05rem;color:#555;line-height:1.7;max-width:460px}
.success-note{font-size:.9rem;color:#999}
.success-btn{background:var(--primary);color:#fff;padding:.85rem 2.25rem;border-radius:var(--r);text-decoration:none;font-weight:600;font-size:1rem;transition:background .22s;margin-top:.5rem;display:inline-block}
.success-btn:hover{background:var(--accent)}
