/* ===== TIMELEFTTODAY SHARED STYLES ===== */
:root{
  --ink:#111827;--ink2:#374151;--ink3:#6b7280;--ink4:#9ca3af;
  --bg:#ffffff;--bg2:#fafaf9;--bg3:#f3f4f6;
  --border:#e5e7eb;
  --primary:#7c3aed;--primary-mid:#8b5cf6;--primary-light:#ede9fe;--primary-pale:#faf5ff;
  --teal:#0f766e;--teal-light:#ccfbf1;
  --amber:#92400e;--amber-light:#fef3c7;
  --radius:10px;
  --shadow:0 1px 3px rgba(0,0,0,.1);--shadow-md:0 4px 12px rgba(0,0,0,.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,'Segoe UI',sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased}
h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;line-height:1.15}
h2{font-size:clamp(1.25rem,3vw,1.65rem);font-weight:700;line-height:1.3;margin-bottom:.75rem}
h3{font-size:1.05rem;font-weight:600;margin-bottom:.4rem}
p{color:var(--ink2);margin-bottom:1rem}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.container-narrow{max-width:760px;margin:0 auto;padding:0 20px}

/* NAV */
.site-nav{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:60px;gap:20px}
.nav-logo{font-weight:800;font-size:1rem;color:var(--primary);text-decoration:none}
.nav-logo span{color:var(--ink3);font-weight:400;font-size:.85rem}
.nav-links{display:flex;gap:4px;list-style:none}
.nav-links a{padding:6px 13px;border-radius:6px;font-size:.88rem;font-weight:500;color:var(--ink2);text-decoration:none;transition:background .15s}
.nav-links a:hover,.nav-links a.active{background:var(--bg3);color:var(--ink)}
.nav-cta{background:var(--primary);color:#fff !important;border-radius:8px;padding:8px 18px !important;font-weight:600 !important;font-size:.875rem;white-space:nowrap}
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px}
@media(max-width:680px){
  .nav-links{display:none;position:absolute;top:60px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;padding:10px 20px 16px}
  .nav-links.open{display:flex}
  .nav-hamburger{display:block}
}

/* PAGE HERO */
.page-hero{background:var(--ink);color:#fff;padding:52px 0 44px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-80px;left:-80px;width:400px;height:400px;border-radius:50%;background:rgba(139,92,246,.07);pointer-events:none}
.page-hero-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:10px}
.page-hero h1{color:#fff;margin-bottom:10px}
.page-hero p{color:rgba(255,255,255,.65);max-width:560px;margin-bottom:0}

/* BREADCRUMB */
.breadcrumb{padding:12px 0;border-bottom:1px solid var(--border);font-size:.8rem;color:var(--ink4)}
.breadcrumb a{color:var(--ink3);text-decoration:none}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb span{margin:0 6px;color:var(--ink4)}

/* SECTIONS */
.section{padding:60px 0}
.section-alt{background:var(--bg2)}
.eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--primary);margin-bottom:10px}
.section-header{text-align:center;max-width:600px;margin:0 auto 40px}

/* PROSE (blog articles) */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin-top:2rem;margin-bottom:.6rem;padding-top:.5rem;border-top:1px solid var(--border)}
.prose h3{margin-top:1.5rem;color:var(--ink)}
.prose ul,.prose ol{padding-left:1.5rem;margin-bottom:1rem}
.prose li{margin-bottom:.4rem;color:var(--ink2)}
.prose blockquote{border-left:3px solid var(--primary-mid);padding:12px 20px;background:var(--primary-pale);border-radius:0 8px 8px 0;margin:1.5rem 0}
.prose blockquote p{margin:0;color:var(--ink);font-style:italic}
.prose table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem}
.prose th{background:var(--bg3);padding:10px 14px;text-align:left;font-weight:600;border:1px solid var(--border)}
.prose td{padding:10px 14px;border:1px solid var(--border)}
.prose tr:nth-child(even) td{background:var(--bg2)}
.prose .callout{background:var(--primary-pale);border:1px solid var(--primary-light);border-radius:10px;padding:18px 22px;margin:1.5rem 0}
.prose .callout strong{color:var(--primary)}
.prose .verdict-box{background:var(--bg2);border:2px solid var(--border);border-radius:12px;padding:24px;margin:2rem 0}
.prose .verdict-box.good{border-color:#10b981}
.prose .verdict-box.avg{border-color:#f59e0b}

/* CARDS */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.card{border:1px solid var(--border);border-radius:var(--radius);padding:24px;background:var(--bg);transition:box-shadow .2s,border-color .2s}
.card:hover{box-shadow:var(--shadow-md);border-color:#c4b5fd}
.card-icon{font-size:1.75rem;margin-bottom:12px}
.card-rate{font-size:1.2rem;font-weight:800;color:var(--ink);margin-bottom:4px}
.card-rate span{font-size:.8rem;font-weight:400;color:var(--ink3)}

/* TAGS */
.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.tag-purple{background:var(--primary-light);color:var(--primary)}
.tag-teal{background:var(--teal-light);color:var(--teal)}
.tag-amber{background:var(--amber-light);color:var(--amber)}
.tag-green{background:#d1fae5;color:#065f46}

/* BUTTONS */
.btn-primary{background:var(--primary-mid);color:#fff;font-weight:700;padding:13px 28px;border-radius:var(--radius);text-decoration:none;font-size:.95rem;display:inline-flex;align-items:center;gap:6px;border:none;cursor:pointer;transition:background .2s,transform .15s}
.btn-primary:hover{background:var(--primary);transform:translateY(-1px);text-decoration:none}
.btn-sm{background:var(--primary-mid);color:#fff;padding:8px 18px;border-radius:7px;font-size:.82rem;font-weight:600;text-decoration:none;display:inline-block;transition:background .2s}
.btn-sm:hover{background:var(--primary);text-decoration:none}
.btn-outline{border:2px solid var(--primary);color:var(--primary);padding:10px 22px;border-radius:var(--radius);font-weight:600;font-size:.9rem;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:background .2s}
.btn-outline:hover{background:var(--primary-pale);text-decoration:none}

/* RATING */
.stars{color:#f59e0b;font-size:1.1rem}
.rating-score{font-size:1.8rem;font-weight:800;color:var(--ink)}
.rating-label{font-size:.8rem;color:var(--ink3);margin-left:6px}

/* FAQ */
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}
.faq-q{padding:16px 20px;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--ink);background:var(--bg)}
.faq-q:hover{background:var(--bg2)}
.faq-q::after{content:'▾';color:var(--ink3);transition:transform .2s;flex-shrink:0;margin-left:12px}
.faq-q.open::after{transform:rotate(-180deg)}
.faq-a{display:none;padding:0 20px 16px;color:var(--ink2);font-size:.93rem;line-height:1.7;border-top:1px solid var(--border)}
.faq-a.open{display:block}

/* EMAIL CTA */
.email-section{background:linear-gradient(135deg,var(--primary) 0%,#4c1d95 100%);color:#fff;padding:52px 0;text-align:center}
.email-section h2{color:#fff;margin-bottom:10px}
.email-section p{color:rgba(255,255,255,.8);max-width:440px;margin:0 auto 24px}
.email-form{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.email-input{flex:1;min-width:210px;padding:12px 16px;border-radius:8px;border:none;font-size:.95rem;outline:none}
.email-submit{background:#fff;color:var(--primary);padding:12px 22px;border-radius:8px;border:none;cursor:pointer;font-weight:700;font-size:.95rem;white-space:nowrap;transition:transform .15s}
.email-submit:hover{transform:scale(1.02)}
.email-trust{font-size:.75rem;color:rgba(255,255,255,.5);margin-top:10px}

/* AFFILIATE NOTICE */
.affiliate-notice{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:12px 18px;font-size:.8rem;color:var(--ink3);margin:20px 0;text-align:center}

/* FOOTER */
.site-footer{background:var(--ink);color:rgba(255,255,255,.6);padding:48px 0 24px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;margin-bottom:32px}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.45);margin-top:10px}
.footer-col h4{color:#fff;font-size:.85rem;margin-bottom:12px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:7px}
.footer-col ul li a{color:rgba(255,255,255,.45);font-size:.85rem;text-decoration:none;transition:color .2s}
.footer-col ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.78rem;color:rgba(255,255,255,.3)}
.footer-bottom a{color:rgba(255,255,255,.3);text-decoration:none}
@media(max-width:680px){
  .footer-inner{grid-template-columns:1fr}
}

/* ARTICLE SIDEBAR LAYOUT */
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start}
.article-sidebar{position:sticky;top:80px}
.sidebar-box{border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:20px;background:var(--bg)}
.sidebar-box h4{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3);margin-bottom:14px}
.toc-list{list-style:none;padding:0}
.toc-list li{margin-bottom:6px}
.toc-list a{font-size:.85rem;color:var(--ink2);text-decoration:none;padding:4px 0;display:block}
.toc-list a:hover{color:var(--primary)}
@media(max-width:900px){.article-layout{grid-template-columns:1fr}}
@media(max-width:900px){.article-sidebar{display:none}}

/* COMPARE TABLE */
.compare-table{width:100%;border-collapse:collapse;font-size:.88rem;margin:1.5rem 0}
.compare-table th{background:var(--ink);color:#fff;padding:12px 16px;text-align:left;font-weight:600}
.compare-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:top}
.compare-table tr:hover td{background:var(--bg2)}
.compare-table .best{background:#f0fdf4;font-weight:600;color:#065f46}
.check{color:#10b981;font-weight:700}
.cross{color:#ef4444}
.score-pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.75rem;font-weight:700}
.score-a{background:#d1fae5;color:#065f46}
.score-b{background:#fef3c7;color:#92400e}
.score-c{background:#fee2e2;color:#991b1b}
