/* ============================================================
   AI GIGS — styles.css  |  aigigs.net
   Dark editorial magazine + neon accent design system
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&family=JetBrains+Mono:wght@400;500&display=swap');

/* ---------- TOKENS ---------- */
:root {
  --bg-base:#080b10;--bg-card:#0e1218;--bg-card-hover:#131921;
  --bg-glass:rgba(14,18,24,0.7);--border:rgba(255,255,255,0.07);
  --border-glow:rgba(0,255,178,0.25);
  --c-primary:#00ffb2;--c-accent:#7b5ea7;--c-hot:#ff4f6e;
  --c-gold:#f5c542;--c-blue:#3b82f6;
  --text-1:#f0f4f8;--text-2:#8a9ab0;--text-3:#505d6d;
  --font-display:'Syne',sans-serif;--font-body:'DM Sans',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-xl:32px;
  --shadow-card:0 4px 24px rgba(0,0,0,.4);
  --shadow-glow:0 0 30px rgba(0,255,178,.12);
  --transition:0.22s cubic-bezier(0.4,0,0.2,1);
  --max-w:1200px;
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--bg-base);color:var(--text-1);font-family:var(--font-body);font-size:16px;line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg-base)}
::-webkit-scrollbar-thumb{background:var(--c-accent);border-radius:2px}

/* noise texture */
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:0;opacity:.5}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.section{padding:80px 0}.section-sm{padding:48px 0}.section-lg{padding:120px 0}
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.15;font-weight:700}
h1{font-size:clamp(2.4rem,5vw,4.2rem)}
h2{font-size:clamp(1.8rem,3vw,2.8rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
h4{font-size:1.2rem}
.mono{font-family:var(--font-mono)}
.text-primary{color:var(--c-primary)}.text-accent{color:var(--c-accent)}
.text-muted{color:var(--text-2)}.text-dim{color:var(--text-3)}
.text-hot{color:var(--c-hot)}.text-gold{color:var(--c-gold)}
.eyebrow{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--c-primary)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:600;font-size:.9rem;transition:var(--transition);white-space:nowrap}
.btn-primary{background:var(--c-primary);color:#000;box-shadow:0 0 20px rgba(0,255,178,.3)}
.btn-primary:hover{background:#00e8a0;box-shadow:0 0 30px rgba(0,255,178,.5);transform:translateY(-1px)}
.btn-outline{border:1px solid var(--border-glow);color:var(--c-primary);background:transparent}
.btn-outline:hover{background:rgba(0,255,178,.05);border-color:var(--c-primary)}
.btn-ghost{color:var(--text-2);padding:10px 20px}
.btn-ghost:hover{color:var(--text-1)}
.btn-sm{padding:8px 16px;font-size:.82rem;border-radius:var(--radius-sm)}

/* ---------- TAGS ---------- */
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:500;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--border);color:var(--text-2)}
.tag-primary{border-color:rgba(0,255,178,.3);color:var(--c-primary);background:rgba(0,255,178,.06)}
.tag-hot{border-color:rgba(255,79,110,.3);color:var(--c-hot);background:rgba(255,79,110,.06)}
.tag-gold{border-color:rgba(245,197,66,.3);color:var(--c-gold);background:rgba(245,197,66,.06)}
.tag-purple{border-color:rgba(123,94,167,.3);color:#c4a9f0;background:rgba(123,94,167,.06)}

/* ---------- CARD ---------- */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);position:relative}
.card:hover{background:var(--bg-card-hover);border-color:rgba(0,255,178,.15);transform:translateY(-3px);box-shadow:var(--shadow-card),var(--shadow-glow)}
.card-body{padding:24px}
.card-footer{padding:16px 24px;border-top:1px solid var(--border)}

/* ---------- GRID BG ---------- */
.grid-bg{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 30%,transparent 100%);pointer-events:none}

/* ---------- DIVIDER ---------- */
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--c-primary),transparent);opacity:.25;margin:0}

/* ============================================================ NAV */
#site-header{position:sticky;top:0;z-index:100;background:rgba(8,11,16,.85);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:var(--transition)}
#site-header.scrolled{background:rgba(8,11,16,.97)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:24px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--text-1);flex-shrink:0}
.logo-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--c-primary),#0affdc);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:900;color:#000}
.logo span{color:var(--c-primary)}
.nav-links{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.nav-links a{padding:8px 14px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:500;color:var(--text-2);transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--text-1);background:rgba(255,255,255,.05)}
.nav-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hamburger{display:none;flex-direction:column;gap:4px;width:28px;padding:4px;cursor:pointer}
.hamburger span{display:block;height:2px;background:var(--text-1);border-radius:1px;transition:var(--transition)}
.mobile-menu{display:none;flex-direction:column;gap:2px;padding:12px 24px 16px;border-top:1px solid var(--border);background:var(--bg-base)}
.mobile-menu a{padding:10px 12px;border-radius:var(--radius-sm);font-size:.95rem;color:var(--text-2);transition:var(--transition)}
.mobile-menu a:hover{color:var(--text-1);background:rgba(255,255,255,.04)}
.mobile-menu.open{display:flex}

/* ============================================================ HERO */
.hero{position:relative;padding:100px 0 80px;overflow:hidden}
.hero-glow{position:absolute;width:700px;height:700px;background:radial-gradient(ellipse,rgba(0,255,178,.07) 0%,transparent 65%);top:-200px;left:50%;transform:translateX(-50%);pointer-events:none}
.hero-glow-2{position:absolute;width:400px;height:400px;background:radial-gradient(ellipse,rgba(123,94,167,.08) 0%,transparent 65%);bottom:-100px;right:10%;pointer-events:none}
.hero-content{position:relative;z-index:1;text-align:center;max-width:820px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;border:1px solid rgba(0,255,178,.2);background:rgba(0,255,178,.05);font-size:.78rem;font-family:var(--font-mono);color:var(--c-primary);margin-bottom:24px;letter-spacing:.06em}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--c-primary);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
.hero h1{margin-bottom:20px}
.hero h1 em{font-style:normal;color:var(--c-primary)}
.hero-sub{font-size:1.15rem;color:var(--text-2);max-width:580px;margin:0 auto 36px;line-height:1.7}
.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:56px}
.hero-stats{display:flex;gap:40px;justify-content:center;flex-wrap:wrap;padding-top:40px;border-top:1px solid var(--border)}
.hero-stat{text-align:center}
.hero-stat-num{font-family:var(--font-display);font-size:1.8rem;font-weight:800;color:var(--text-1);line-height:1}
.hero-stat-label{font-size:.8rem;color:var(--text-3);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}

/* ============================================================ TICKER */
.ticker-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(0,255,178,.02);padding:10px 0}
.ticker-track{display:flex;width:max-content;animation:ticker 40s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:flex;align-items:center;gap:8px;padding:0 32px;white-space:nowrap;font-family:var(--font-mono);font-size:.78rem;color:var(--text-3)}
.ticker-item .dot{color:var(--c-primary)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================ SECTION HEADER */
.section-header{margin-bottom:40px}
.section-header-row{display:flex;align-items:flex-end;justify-content:space-between;margin-top:12px;gap:16px}

/* ============================================================ ARTICLE CARDS */
.article-card{display:flex;flex-direction:column}
.article-card-img{aspect-ratio:16/9;background:linear-gradient(135deg,#0e1420,#1a2030);overflow:hidden;position:relative;flex-shrink:0}
.article-card-img .img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem}
.article-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--bg-card),transparent 60%)}
.article-card .card-body{flex:1;display:flex;flex-direction:column;gap:10px}
.article-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.article-card h3{font-size:1.1rem;line-height:1.3}
.article-card h3 a:hover{color:var(--c-primary)}
.article-card p{font-size:.88rem;color:var(--text-2);flex:1}
.article-card-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-3)}
.author-mini{display:flex;align-items:center;gap:8px}
.author-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--c-accent),var(--c-primary));display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0}
.article-card-featured{grid-column:span 2;flex-direction:row}
.article-card-featured .article-card-img{aspect-ratio:auto;width:380px;flex-shrink:0}
.article-card-featured h3{font-size:1.5rem}

/* ============================================================ SCORE */
.score-badge{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.75rem;font-weight:500}
.score-high{background:rgba(0,255,178,.1);color:var(--c-primary);border:1px solid rgba(0,255,178,.2)}
.score-mid{background:rgba(245,197,66,.1);color:var(--c-gold);border:1px solid rgba(245,197,66,.2)}
.score-bar{height:3px;border-radius:2px;background:var(--border);overflow:hidden;margin-top:8px}
.score-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--c-accent),var(--c-primary));transition:width 1s cubic-bezier(0.4,0,0.2,1)}

/* ============================================================ OPP CARDS */
.opp-card{padding:20px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);transition:var(--transition)}
.opp-card:hover{border-color:rgba(0,255,178,.2);background:var(--bg-card-hover);transform:translateY(-2px)}
.opp-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.opp-icon{font-size:1.8rem;line-height:1}
.opp-score-ring{position:relative;width:52px;height:52px;flex-shrink:0}
.opp-score-ring svg{transform:rotate(-90deg)}
.opp-score-ring .score-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.78rem;font-weight:700;color:var(--c-primary)}
.opp-card h4{font-size:.95rem;margin-bottom:6px}
.opp-card p{font-size:.8rem;color:var(--text-2);margin-bottom:12px}
.opp-meta{display:flex;gap:8px;flex-wrap:wrap}

/* ============================================================ TOOL CARDS */
.tool-card{display:flex;gap:14px;align-items:flex-start;padding:18px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);transition:var(--transition)}
.tool-card:hover{border-color:rgba(0,255,178,.15);background:var(--bg-card-hover);transform:translateY(-2px)}
.tool-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--bg-card-hover),#1c2433);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;border:1px solid var(--border)}
.tool-info h4{font-size:.95rem;margin-bottom:4px}
.tool-info p{font-size:.8rem;color:var(--text-2)}
.tool-info .tag{margin-top:8px}

/* ============================================================ EARNINGS WIDGET */
.earnings-widget{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;position:relative;overflow:hidden}
.earnings-widget::before{content:'';position:absolute;top:0;right:0;width:300px;height:300px;background:radial-gradient(ellipse,rgba(0,255,178,.04),transparent 70%);pointer-events:none}
.earnings-bars{display:flex;gap:16px;align-items:flex-end;height:160px;margin:24px 0}
.earnings-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
.earnings-bar-wrap{flex:1;display:flex;align-items:flex-end;width:100%;gap:4px}
.earnings-bar{flex:1;border-radius:4px 4px 0 0;min-height:8px;transition:height 1.2s cubic-bezier(0.4,0,0.2,1)}
.bar-ai{background:linear-gradient(to top,var(--c-primary),rgba(0,255,178,.4))}
.bar-trad{background:linear-gradient(to top,var(--c-accent),rgba(123,94,167,.3))}
.earnings-bar-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-3);text-align:center}
.earnings-legend{display:flex;gap:20px;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-2)}
.legend-dot{width:10px;height:10px;border-radius:2px}

/* ============================================================ PROMPTS */
.prompt-card{padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;align-items:flex-start;gap:12px;transition:var(--transition);cursor:pointer}
.prompt-card:hover{border-color:rgba(0,255,178,.15);background:var(--bg-card-hover)}
.prompt-num{font-family:var(--font-mono);font-size:.75rem;color:var(--text-3);width:20px;flex-shrink:0;padding-top:2px}
.prompt-text{font-size:.88rem;color:var(--text-1);line-height:1.4;flex:1}
.prompt-copy{opacity:0;font-size:.75rem;color:var(--c-primary);font-family:var(--font-mono);flex-shrink:0;transition:var(--transition)}
.prompt-card:hover .prompt-copy{opacity:1}

/* ============================================================ FILTERS */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.filter-btn{padding:8px 18px;border-radius:999px;border:1px solid var(--border);font-size:.82rem;font-weight:500;color:var(--text-2);background:transparent;transition:var(--transition);font-family:var(--font-body)}
.filter-btn:hover{color:var(--text-1);border-color:rgba(255,255,255,.15)}
.filter-btn.active{background:rgba(0,255,178,.08);border-color:rgba(0,255,178,.3);color:var(--c-primary)}

/* ============================================================ NEWSLETTER */
.newsletter-section{background:linear-gradient(135deg,rgba(0,255,178,.04),rgba(123,94,167,.04));border:1px solid var(--border);border-radius:var(--radius-xl);padding:56px;text-align:center;position:relative;overflow:hidden}
.newsletter-section::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:400px;height:200px;background:radial-gradient(ellipse,rgba(0,255,178,.08),transparent);pointer-events:none}
.newsletter-form{display:flex;gap:10px;max-width:480px;margin:24px auto 0}
.newsletter-input{flex:1;padding:12px 18px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);font-family:var(--font-body);font-size:.9rem;outline:none;transition:var(--transition)}
.newsletter-input::placeholder{color:var(--text-3)}
.newsletter-input:focus{border-color:rgba(0,255,178,.3);box-shadow:0 0 0 3px rgba(0,255,178,.05)}
.newsletter-note{font-size:.78rem;color:var(--text-3);margin-top:10px}

/* ============================================================ FOOTER */
#site-footer{border-top:1px solid var(--border);padding:64px 0 32px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:280px repeat(4,1fr);gap:40px;margin-bottom:48px}
.footer-brand p{font-size:.85rem;color:var(--text-2);margin:12px 0 20px;line-height:1.7}
.footer-social{display:flex;gap:10px}
.social-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--text-3);transition:var(--transition)}
.social-btn:hover{border-color:rgba(0,255,178,.3);color:var(--c-primary)}
.footer-col h5{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:14px;font-family:var(--font-mono)}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col li a{font-size:.88rem;color:var(--text-2);transition:var(--transition)}
.footer-col li a:hover{color:var(--c-primary)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:24px;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-3);flex-wrap:wrap}
.footer-bottom a{color:var(--text-3)}
.footer-bottom a:hover{color:var(--c-primary)}
.footer-legal{display:flex;gap:16px;flex-wrap:wrap}

/* ============================================================ BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-3);margin-bottom:24px}
.breadcrumb a{color:var(--text-3);transition:var(--transition)}
.breadcrumb a:hover{color:var(--c-primary)}

/* ============================================================ ARTICLE LAYOUT */
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.article-content{min-width:0}
.article-hero-img{aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:32px;background:linear-gradient(135deg,#0e1420,#1a2030);display:flex;align-items:center;justify-content:center;font-size:5rem}
.article-header{margin-bottom:32px}
.article-header .eyebrow{margin-bottom:12px}
.article-header h1{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:16px}
.article-header .lead{font-size:1.1rem;color:var(--text-2);line-height:1.75;margin-bottom:24px}
.article-meta-bar{display:flex;align-items:center;gap:16px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap}
.article-author{display:flex;align-items:center;gap:10px}
.author-avatar-lg{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--c-accent),var(--c-primary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}
.author-info .name{font-weight:600;font-size:.88rem}
.author-info .role{font-size:.78rem;color:var(--text-3)}
.article-body{font-size:1.02rem;line-height:1.8;color:var(--text-1)}
.article-body h2{font-size:1.5rem;margin:48px 0 16px;color:var(--text-1)}
.article-body h3{font-size:1.2rem;margin:32px 0 12px;color:var(--text-1)}
.article-body p{margin-bottom:20px;color:var(--text-2)}
.article-body p:first-child{color:var(--text-1)}
.article-body ul,.article-body ol{margin:0 0 20px 0;padding-left:24px;color:var(--text-2)}
.article-body li{margin-bottom:8px}
.article-body ul{list-style:disc}
.article-body ol{list-style:decimal}
.article-body strong{color:var(--text-1);font-weight:600}
.article-body a{color:var(--c-primary);text-decoration:underline;text-decoration-color:rgba(0,255,178,.3)}
.article-body a:hover{text-decoration-color:var(--c-primary)}
.article-body blockquote{border-left:3px solid var(--c-primary);padding:16px 24px;margin:32px 0;background:rgba(0,255,178,.03);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;color:var(--text-2)}
.article-callout{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px 24px;margin:28px 0}
.article-callout.callout-tip{border-color:rgba(0,255,178,.2);background:rgba(0,255,178,.03)}
.article-callout.callout-warn{border-color:rgba(245,197,66,.2);background:rgba(245,197,66,.03)}
.article-callout-title{font-weight:600;font-size:.88rem;margin-bottom:6px}
.callout-tip .article-callout-title{color:var(--c-primary)}
.callout-warn .article-callout-title{color:var(--c-gold)}
.article-sidebar{position:sticky;top:84px;display:flex;flex-direction:column;gap:20px}
.sidebar-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.sidebar-card h5{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:14px;font-family:var(--font-mono)}
.toc-list{display:flex;flex-direction:column;gap:4px}
.toc-list a{display:block;padding:6px 10px;border-radius:var(--radius-sm);font-size:.83rem;color:var(--text-2);transition:var(--transition);border-left:2px solid transparent}
.toc-list a:hover,.toc-list a.active{color:var(--c-primary);border-left-color:var(--c-primary);padding-left:14px}
.related-article{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.related-article:last-child{border-bottom:none;padding-bottom:0}
.related-article h6{font-size:.82rem;line-height:1.4;color:var(--text-1)}
.related-article h6 a:hover{color:var(--c-primary)}
.related-article .tag{margin-top:4px;font-size:.65rem}

/* ============================================================ PAGE HERO */
.page-hero{padding:60px 0 48px;position:relative;overflow:hidden}
.page-hero .grid-bg{mask-image:none;opacity:.4}
.page-hero-content{position:relative;z-index:1;max-width:680px}
.page-hero h1{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:16px}
.page-hero p{font-size:1.05rem;color:var(--text-2);line-height:1.7}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 400px;gap:48px}
.contact-form-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px}
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--text-2);margin-bottom:6px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-1);font-family:var(--font-body);font-size:.92rem;outline:none;transition:var(--transition)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:rgba(0,255,178,.3);box-shadow:0 0 0 3px rgba(0,255,178,.05)}
.form-textarea{resize:vertical;min-height:130px}
.form-select option{background:var(--bg-card)}
.contact-info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px}
.contact-info-card h3{font-size:1.1rem;margin-bottom:20px}
.contact-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none}
.contact-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:rgba(0,255,178,.06);border:1px solid rgba(0,255,178,.12);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.contact-item .label{font-size:.75rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-family:var(--font-mono)}
.contact-item .value{font-size:.88rem;color:var(--text-1)}
.contact-item .value a{color:var(--c-primary)}
.map-placeholder{border-radius:var(--radius-md);overflow:hidden;margin-top:20px;background:#0b1018;border:1px solid var(--border);height:180px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;font-size:.85rem;color:var(--text-3)}
.faq-item{border-bottom:1px solid var(--border);padding:20px 0}
.faq-q{font-weight:600;font-size:.95rem;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.faq-q:hover{color:var(--c-primary)}
.faq-a{font-size:.88rem;color:var(--text-2);line-height:1.7}

/* ============================================================ TOOLS DIR */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.tool-dir-card{padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);display:flex;flex-direction:column;gap:12px}
.tool-dir-card:hover{border-color:rgba(0,255,178,.2);transform:translateY(-3px);box-shadow:var(--shadow-card)}
.tool-dir-header{display:flex;align-items:flex-start;gap:14px}
.tool-dir-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:var(--bg-base);border:1px solid var(--border);flex-shrink:0}
.tool-dir-card h4{font-size:1rem;margin-bottom:3px}
.tool-dir-card .category{font-size:.75rem;color:var(--text-3);font-family:var(--font-mono);text-transform:uppercase}
.tool-dir-card p{font-size:.85rem;color:var(--text-2);line-height:1.6}
.tool-dir-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.tool-rating{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--c-gold)}

/* ============================================================ PROSE */
.prose-content{max-width:760px;font-size:1rem;line-height:1.8;color:var(--text-2)}
.prose-content h2{color:var(--text-1);font-size:1.4rem;margin:40px 0 12px}
.prose-content h3{color:var(--text-1);font-size:1.1rem;margin:28px 0 10px}
.prose-content p{margin-bottom:18px}
.prose-content ul,.prose-content ol{margin:0 0 18px 20px}
.prose-content li{margin-bottom:6px}
.prose-content ul{list-style:disc}
.prose-content ol{list-style:decimal}
.prose-content strong{color:var(--text-1)}
.prose-content a{color:var(--c-primary);text-decoration:underline;text-decoration-color:rgba(0,255,178,.3)}
.prose-content a:hover{text-decoration-color:var(--c-primary)}
.prose-content table{width:100%;border-collapse:collapse;margin-bottom:20px;font-size:.88rem}
.prose-content th{background:var(--bg-card);padding:10px 14px;text-align:left;border:1px solid var(--border);color:var(--text-1)}
.prose-content td{padding:10px 14px;border:1px solid var(--border);color:var(--text-2)}

/* ============================================================ ABOUT */
.team-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-align:center;transition:var(--transition)}
.team-card:hover{border-color:rgba(0,255,178,.2);transform:translateY(-2px)}
.team-avatar{width:72px;height:72px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;font-family:var(--font-display)}
.team-card h4{font-size:1rem;margin-bottom:4px}
.team-card .role{font-size:.8rem;color:var(--text-3);font-family:var(--font-mono);margin-bottom:10px}
.team-card p{font-size:.83rem;color:var(--text-2);line-height:1.6}
.value-item{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--border)}
.value-item:last-child{border-bottom:none}
.value-num{font-family:var(--font-mono);font-size:.75rem;color:var(--c-primary);width:28px;flex-shrink:0;padding-top:3px}
.value-item h4{font-size:.95rem;margin-bottom:6px}
.value-item p{font-size:.85rem;color:var(--text-2);line-height:1.6}

/* ============================================================ NOTICE */
.notice{padding:14px 18px;border-radius:var(--radius-md);font-size:.85rem;line-height:1.6;margin-bottom:24px;display:flex;gap:10px;align-items:flex-start}
.notice-info{background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.2);color:#93c5fd}
.notice-warn{background:rgba(245,197,66,.07);border:1px solid rgba(245,197,66,.2);color:var(--c-gold)}

/* ============================================================ GUIDE CARDS */
.guide-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:var(--transition);display:flex;flex-direction:column;gap:14px}
.guide-card:hover{border-color:rgba(0,255,178,.15);transform:translateY(-2px);box-shadow:var(--shadow-card)}
.guide-number{width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid rgba(0,255,178,.2);background:rgba(0,255,178,.05);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.85rem;font-weight:700;color:var(--c-primary)}
.guide-card h3{font-size:1.05rem}
.guide-card p{font-size:.85rem;color:var(--text-2);line-height:1.6;flex:1}
.level-pip{width:16px;height:4px;border-radius:2px;background:var(--border)}
.level-pip.filled{background:var(--c-primary)}

/* ============================================================ ANIMATIONS */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ============================================================ BACK TO TOP */
#back-to-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-glow);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--c-primary);cursor:pointer;z-index:50;opacity:0;pointer-events:none;transition:var(--transition);box-shadow:0 4px 16px rgba(0,0,0,.4)}
#back-to-top.visible{opacity:1;pointer-events:all}
#back-to-top:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,255,178,.2)}

/* ============================================================ TOAST */
#toast{position:fixed;bottom:80px;right:24px;background:var(--bg-card);border:1px solid rgba(0,255,178,.25);color:var(--text-1);padding:12px 18px;border-radius:var(--radius-md);font-size:.85rem;z-index:200;opacity:0;transform:translateY(8px);transition:all .3s ease;pointer-events:none}
#toast.show{opacity:1;transform:translateY(0)}

/* ============================================================ RESPONSIVE */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .footer-brand{grid-column:span 3}
  .article-layout{grid-template-columns:1fr}
  .article-sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .article-sidebar .sidebar-card{flex:1;min-width:240px}
  .contact-grid{grid-template-columns:1fr}
  .article-card-featured{grid-column:span 1;flex-direction:column}
  .article-card-featured .article-card-img{width:100%;aspect-ratio:16/9}
}
@media(max-width:768px){
  .nav-links,.nav-actions .btn{display:none}
  .hamburger{display:flex}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .hero{padding:70px 0 60px}
  .hero-stats{gap:24px}
  .section{padding:56px 0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:span 2}
  .earnings-widget{padding:24px}
  .newsletter-section{padding:36px 24px}
  .newsletter-form{flex-direction:column}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:span 1}
}

/* ============================================================ ARTICLES LISTING */
.page-hero{padding:80px 0 40px;border-bottom:1px solid var(--border)}
.page-hero h1{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:.75rem}
.page-hero-desc{font-size:1.1rem;color:var(--text-2);max-width:600px}
.articles-listing-section{padding:48px 0 80px}
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;margin-top:32px}
.featured-card{grid-column:span 2}
@media(max-width:900px){.featured-card{grid-column:span 1}}

/* ============================================================ TOOLS DIRECTORY */
.tools-dir-section{padding:48px 0 80px}
.tools-grid{display:flex;flex-direction:column;gap:48px;margin-top:32px}
.tools-category-section{}
.tools-cat-heading{font-size:1.2rem;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.cat-icon{font-size:1.1rem}
.tool-cards-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.tool-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;display:flex;flex-direction:column;gap:12px;transition:var(--transition)}
.tool-card:hover{border-color:rgba(0,255,178,.2);transform:translateY(-2px);box-shadow:var(--shadow-card)}
.tool-card-header{display:flex;align-items:center;gap:12px}
.tool-logo{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:#0a0f1a;flex-shrink:0}
.tool-card h3{font-size:1rem;font-weight:700;margin:0}
.tool-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:100px;background:rgba(0,255,178,.1);color:var(--c-primary);border:1px solid rgba(0,255,178,.2);display:inline-block;margin-top:2px}
.tool-card p{font-size:.88rem;color:var(--text-2);line-height:1.6;flex:1}
.tool-meta{display:flex;gap:12px;flex-wrap:wrap}
.tool-price{font-size:.78rem;color:var(--text-3);font-family:var(--font-mono)}
.tool-score{font-size:.78rem;color:var(--c-primary);font-family:var(--font-mono);font-weight:600}

/* ============================================================ GUIDES LISTING */
.guides-listing-section{padding:48px 0 80px}
.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px;margin-top:32px}
.guide-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;gap:16px;transition:var(--transition)}
.guide-card:hover{border-color:rgba(0,255,178,.2);transform:translateY(-2px)}
.featured-guide{grid-column:span 2;background:linear-gradient(135deg,rgba(0,255,178,.03),rgba(0,122,255,.03))}
@media(max-width:900px){.featured-guide{grid-column:span 1}}
.guide-card h2{font-size:1.1rem;font-weight:700;margin:0}
.guide-card h2 a{color:var(--text-1);text-decoration:none}
.guide-card h2 a:hover{color:var(--c-primary)}
.guide-card p{color:var(--text-2);font-size:.9rem;line-height:1.65}
.guide-card-badge{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:100px;background:rgba(0,255,178,.1);color:var(--c-primary);border:1px solid rgba(0,255,178,.2);display:inline-block;align-self:flex-start}
.guide-meta{display:flex;gap:16px;font-size:.8rem;color:var(--text-3)}
.guide-level{font-family:var(--font-mono)}
.btn-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.guides-newsletter-cta{margin-top:56px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;text-align:center}
.guides-newsletter-cta h2{font-size:1.5rem;margin-bottom:.5rem}
.guides-newsletter-cta p{color:var(--text-2);margin-bottom:1.5rem}
.newsletter-form-inline{display:flex;gap:10px;max-width:440px;margin:0 auto}
.newsletter-form-inline input{flex:1;padding:12px 16px;border-radius:var(--radius-md);background:var(--bg-3);border:1px solid var(--border);color:var(--text-1);font-size:.9rem}

/* ============================================================ ARTICLE EXTRAS */
.article-deck{font-size:1.15rem;color:var(--text-2);line-height:1.65;margin-bottom:1.5rem}
.article-byline{display:flex;align-items:center;gap:12px;padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:2rem}
.byline-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0}
.article-byline strong{display:block;font-size:.95rem}
.article-byline span{font-size:.82rem;color:var(--text-3)}
.article-tags-footer{display:flex;gap:8px;flex-wrap:wrap;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.article-header{margin-bottom:0}
.prose h2{font-size:1.45rem;margin-top:2.5rem;margin-bottom:.75rem}
.prose h3{font-size:1.15rem;margin-top:2rem;margin-bottom:.5rem}
.prose ul{padding-left:1.5rem;margin:1rem 0}
.prose ul li{margin-bottom:.5rem;color:var(--text-2)}
.prose ol{padding-left:1.5rem;margin:1rem 0}
.prose ol li{margin-bottom:.5rem;color:var(--text-2)}
.prose p{margin-bottom:1.2rem;color:var(--text-2);line-height:1.75}
.prose p.lead{font-size:1.1rem;color:var(--text-1);line-height:1.75}
.code-block{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;margin:1.5rem 0;overflow-x:auto}
.code-block pre{margin:0}
.code-block code{font-family:var(--font-mono);font-size:.85rem;color:var(--c-primary);white-space:pre-wrap}
.callout{border-radius:var(--radius-md);padding:18px 22px;margin:1.5rem 0;font-size:.9rem;line-height:1.6}
.callout-info{background:rgba(0,122,255,.07);border:1px solid rgba(0,122,255,.2);color:var(--text-2)}
.callout-warning{background:rgba(255,190,0,.07);border:1px solid rgba(255,190,0,.2);color:var(--text-2)}
.callout strong{color:var(--text-1)}

/* Sidebar */
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;max-width:1100px;margin:0 auto;padding:40px var(--container-padding) 80px}
.article-sidebar{position:sticky;top:100px;align-self:start;display:flex;flex-direction:column;gap:24px}
.sidebar-toc,.sidebar-score,.sidebar-related,.sidebar-newsletter{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px}
.sidebar-toc h3,.sidebar-score h3,.sidebar-related h3,.sidebar-newsletter h3{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:14px}
.sidebar-toc ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px}
.sidebar-toc ul li a{font-size:.85rem;color:var(--text-2);text-decoration:none;transition:color .2s}
.sidebar-toc ul li a:hover,.sidebar-toc ul li a.active{color:var(--c-primary)}
.sidebar-score{text-align:center}
.score-ring{position:relative;width:80px;height:80px;margin:0 auto 8px}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:rgba(255,255,255,.06);stroke-width:6}
.ring-fill{fill:none;stroke:var(--c-primary);stroke-width:6;stroke-linecap:round;stroke-dasharray:201;stroke-dashoffset:calc(201 - (201 * var(--score) / 100));transition:stroke-dashoffset 1.2s ease}
.score-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.1rem;font-weight:800;color:var(--c-primary);font-family:var(--font-mono)}
.score-label{font-size:.78rem;color:var(--text-3)}
.sidebar-related ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.sidebar-related ul li a{font-size:.85rem;color:var(--text-2);text-decoration:none;transition:color .2s;line-height:1.4;display:block}
.sidebar-related ul li a:hover{color:var(--c-primary)}
.sidebar-newsletter p{font-size:.83rem;color:var(--text-2);margin-bottom:12px}
.sidebar-newsletter form{display:flex;flex-direction:column;gap:8px}
.sidebar-newsletter input{padding:9px 12px;border-radius:var(--radius-sm);background:var(--bg-3);border:1px solid var(--border);color:var(--text-1);font-size:.83rem}

/* Guide-specific */
.guide-progress-bar{height:3px;background:var(--border);border-radius:2px;margin-bottom:2rem}
.guide-progress-fill{height:100%;background:var(--c-primary);border-radius:2px;transition:width .3s ease}
.prompt-anatomy-diagram{display:flex;flex-direction:column;gap:12px;margin:1.5rem 0;padding:24px;background:var(--bg-3);border-radius:var(--radius-lg);border:1px solid var(--border)}
.anatomy-item{display:flex;align-items:flex-start;gap:12px}
.anatomy-label{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--c-primary);min-width:120px;padding-top:2px}
.anatomy-item p{font-size:.88rem;color:var(--text-2);margin:0}
.prompt-example{display:flex;flex-direction:column;gap:12px;margin:1.5rem 0}
.prompt-bad,.prompt-good{padding:16px 20px;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:.85rem;line-height:1.6}
.prompt-bad{background:rgba(255,80,80,.06);border:1px solid rgba(255,80,80,.15);color:var(--text-2)}
.prompt-good{background:rgba(0,255,178,.04);border:1px solid rgba(0,255,178,.15);color:var(--text-2)}
.prompt-label{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:4px;margin-bottom:8px;font-family:var(--font-sans)}
.prompt-label.bad{background:rgba(255,80,80,.15);color:#ff8080}
.prompt-label.good{background:rgba(0,255,178,.12);color:var(--c-primary)}
.guide-next-steps{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin-top:2.5rem}
.guide-next-steps h3{font-size:1rem;margin-bottom:1rem}
.guide-next-steps ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.guide-next-steps ul li a{color:var(--c-primary);text-decoration:none;font-size:.9rem}
.guide-next-steps ul li a:hover{text-decoration:underline}

/* Back to top button fix */
.back-to-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-glow);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--c-primary);cursor:pointer;z-index:50;opacity:0;pointer-events:none;transition:var(--transition);box-shadow:0 4px 16px rgba(0,0,0,.4)}
.back-to-top.visible{opacity:1;pointer-events:all}
.back-to-top:hover{transform:translateY(-3px)}

@media(max-width:1024px){
  .article-layout{grid-template-columns:1fr;padding:32px 16px 60px}
  .article-sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .article-sidebar>*{flex:1;min-width:240px}
}

/* ============================================================ LOGO IMG */
.nav-logo-img{height:32px;width:auto;display:block}

/* ============================================================ COOKIE BANNER */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:500;background:rgba(10,14,20,.97);border-top:1px solid var(--border);backdrop-filter:blur(16px);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;transform:translateY(100%);transition:transform .4s cubic-bezier(0.4,0,0.2,1)}
#cookie-banner.visible{transform:translateY(0)}
.cookie-text{font-size:.82rem;color:var(--text-2);max-width:680px;line-height:1.55}
.cookie-text a{color:var(--c-primary);text-decoration:underline}
.cookie-actions{display:flex;gap:8px;flex-shrink:0}
.cookie-accept{padding:8px 20px;border-radius:var(--radius-sm);background:var(--c-primary);color:#000;font-weight:700;font-size:.82rem;font-family:var(--font-display);cursor:pointer;border:none;transition:var(--transition)}
.cookie-accept:hover{background:#00e8a0}
.cookie-decline{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-3);font-size:.82rem;background:transparent;cursor:pointer;transition:var(--transition)}
.cookie-decline:hover{color:var(--text-1);border-color:rgba(255,255,255,.2)}

/* ============================================================ ARTICLE HERO STOCK PHOTO */
.article-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.article-hero-img{font-size:0}

/* ============================================================ LUCIDE ICONS (inline SVG via CSS) */
.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.icon svg{stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}

/* social icon buttons with Lucide */
.social-btn svg{width:16px;height:16px}
.contact-icon svg{width:18px;height:18px}
.notice-icon svg{width:16px;height:16px}
.opp-icon svg{width:28px;height:28px}
.cat-icon svg{width:20px;height:20px}

@media(max-width:600px){
  #cookie-banner{flex-direction:column;align-items:flex-start}
  .cookie-actions{width:100%}
  .cookie-accept,.cookie-decline{flex:1;text-align:center}
}

/* ============================================================ ARTICLE PAGE FIX */
/* When article-layout is inside .container, override its own padding/max-width */
.container > .article-layout,
.container > * > .article-layout {
  padding-top: 0;
  padding-bottom: 80px;
  padding-left: 0;
  padding-right: 0;
}

/* ============================================================ BREADCRUMB FIX */
.breadcrumb ol{display:flex;align-items:center;flex-wrap:wrap;gap:4px;list-style:none;margin:0;padding:0}
.breadcrumb li{display:flex;align-items:center;gap:4px;white-space:nowrap}
.breadcrumb li+li::before{content:"›";color:var(--text-3);font-size:.85rem}

/* ============================================================ PAGE HERO SPACING */
/* Index pages (articles, guides, tools) need top padding after sticky header */
.page-hero{padding:48px 0 40px}

/* ============================================================ GLOBAL PAGE TOP PADDING */
/* Sticky header is 64px — all main content needs clearance */
main{padding-top:64px}
/* Article pages add extra via container padding */
.container>.article-hero-img{margin-top:32px}
