/* ============================================
   Travel Daily Shot — Shared Styles v1.0
   Dark/Light theme system, CSP-safe
   Accent: Tropical Cyan — evokes ocean, adventure, sky
   ============================================ */

/* === DARK THEME (default) === */
:root {
  --bg: #050d0e;
  --bg-elevated: #0a1517;
  --bg-card: #0f1d20;
  --bg-card-hover: #152527;
  --border: #1e3035;
  --border-light: #152528;
  --text-primary: #eef5f6;
  --text-secondary: #8aacb0;
  --text-muted: #4a6a70;
  --accent: #00d4ff;
  --accent-dim: #00aacf;
  --accent-glow: rgba(0, 212, 255, 0.08);
  --accent-subtle: rgba(0, 212, 255, 0.05);
  --accent-border: rgba(0, 212, 255, 0.12);
  --accent-shadow: rgba(0, 212, 255, 0.30);
  --gradient-1: #00d4ff;
  --gradient-2: #00ffa3;
  --nav-bg: rgba(5,13,14,0.88);
  --nav-border: var(--border-light);
  --selection-bg: var(--accent);
  --selection-text: #050d0e;
  --noise-opacity: 0.025;
  --pro-color: #00ffa3;
  --con-color: #ff6b6b;
  --font-display: 'Instrument Serif', Georgia, serif;
  --font-body: 'DM Sans', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --radius: 12px;
  --radius-sm: 8px;
  --transition: 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  color-scheme: dark;
}

/* === LIGHT THEME === */
[data-theme="light"] {
  --bg: #f0f9fc;
  --bg-elevated: #ffffff;
  --bg-card: #ffffff;
  --bg-card-hover: #e8f5f8;
  --border: #c0dde3;
  --border-light: #d8edf1;
  --text-primary: #0c1e22;
  --text-secondary: #3d6870;
  --text-muted: #7a9ea4;
  --accent: #0369a1;
  --accent-dim: #025480;
  --accent-glow: rgba(3, 105, 161, 0.08);
  --accent-subtle: rgba(3, 105, 161, 0.04);
  --accent-border: rgba(3, 105, 161, 0.15);
  --accent-shadow: rgba(3, 105, 161, 0.20);
  --gradient-1: #0369a1;
  --gradient-2: #059669;
  --nav-bg: rgba(240,249,252,0.92);
  --nav-border: var(--border-light);
  --selection-bg: var(--accent);
  --selection-text: #ffffff;
  --noise-opacity: 0.01;
  --pro-color: #059669;
  --con-color: #dc2626;
  color-scheme: light;
}

/* === RESET === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s}
::selection{background:var(--selection-bg);color:var(--selection-text)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* Font faces */
@font-face{font-family:'DM Sans';src:url('/assets/fonts/dm-sans-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'DM Sans';src:url('/assets/fonts/dm-sans-medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'DM Sans';src:url('/assets/fonts/dm-sans-bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'DM Sans';src:url('/assets/fonts/dm-sans-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Instrument Serif';src:url('/assets/fonts/instrument-serif-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Instrument Serif';src:url('/assets/fonts/instrument-serif-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'JetBrains Mono';src:url('/assets/fonts/jetbrains-mono-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'JetBrains Mono';src:url('/assets/fonts/jetbrains-mono-medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}

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

/* ============================================
   NAV
   ============================================ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 40px;height:68px;display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg);backdrop-filter:blur(20px) saturate(1.5);border-bottom:1px solid var(--nav-border);transition:background .3s}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.35rem;letter-spacing:-0.02em;color:var(--text-primary);white-space:nowrap;flex-shrink:0;text-decoration:none}
.nav-logo:hover{color:var(--text-primary);text-decoration:none}
.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;animation:logo-pulse 3s ease-in-out infinite}
@keyframes logo-pulse{0%,100%{box-shadow:0 0 0 0 var(--accent-shadow)}50%{box-shadow:0 0 0 6px rgba(0,212,255,0)}}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.86rem;font-weight:500;color:var(--text-secondary);transition:color var(--transition);letter-spacing:.01em;text-decoration:none;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--text-primary);text-decoration:none}
.nav-links a.active{color:var(--accent)}
.nav-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.nav-cta{display:inline-flex;align-items:center;padding:9px 20px;background:var(--accent);color:var(--selection-text);border-radius:100px;font-weight:600;font-size:.78rem;letter-spacing:.03em;text-transform:uppercase;transition:all var(--transition);text-decoration:none;white-space:nowrap}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-shadow);color:var(--selection-text);text-decoration:none}

/* Theme toggle */
.theme-toggle{background:none;border:1px solid var(--border);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s}
.theme-toggle:hover{border-color:var(--border);color:var(--text-primary);background:var(--bg-elevated)}
.theme-toggle svg{width:16px;height:16px}
[data-theme="dark"] .icon-sun{display:block}
[data-theme="dark"] .icon-moon{display:none}
[data-theme="light"] .icon-sun{display:none}
[data-theme="light"] .icon-moon{display:block}

/* Hamburger */
.nav-hamburger{display:none;background:none;border:1px solid var(--border);border-radius:8px;width:36px;height:36px;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;padding:0}
.nav-hamburger span{display:block;width:16px;height:1.5px;background:var(--text-secondary);border-radius:2px;transition:all .2s}
.nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile menu */
.mobile-overlay{position:fixed;inset:0;background:rgba(5,13,14,.7);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px)}
.mobile-overlay.open{opacity:1;pointer-events:all}
.mobile-menu{position:fixed;top:0;right:0;width:300px;height:100%;background:var(--bg-card);border-left:1px solid var(--border);z-index:999;transform:translateX(100%);transition:transform .3s cubic-bezier(.25,.46,.45,.94);padding:80px 24px 40px;display:flex;flex-direction:column}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-inner{display:flex;flex-direction:column;gap:4px}
.mobile-menu-inner a{font-size:1.1rem;font-weight:500;color:var(--text-secondary);padding:12px 16px;border-radius:8px;transition:all .2s}
.mobile-menu-inner a:hover,.mobile-menu-inner a.active{color:var(--text-primary);background:var(--bg-elevated)}
.mobile-menu-inner a.active{color:var(--accent)}
.mobile-menu-cta{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-light)}
.mobile-menu-cta .nav-cta{width:100%;justify-content:center}
.skip-link{position:absolute;top:-100%;left:16px;padding:12px 24px;background:var(--accent);color:var(--selection-text);border-radius:0 0 8px 8px;z-index:10000;font-size:.9rem;text-decoration:none;transition:top .2s}
.skip-link:focus{top:0}

/* ============================================
   LAYOUT HELPERS
   ============================================ */
.page-body{padding-top:68px}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ============================================
   HOMEPAGE
   ============================================ */
.hp-hero{position:relative;padding:110px 24px 72px;text-align:center;overflow:hidden;max-height:80vh;display:flex;align-items:center}
.hp-hero-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,212,255,.06) 0%,transparent 60%);pointer-events:none}
.hp-hero-dots{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle,var(--accent-border) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;opacity:.5}
.hp-hero-inner{position:relative;z-index:1;max-width:820px;margin:0 auto}
.hp-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:var(--bg-card);border:1px solid var(--accent-border);border-radius:100px;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:32px;animation:fadeUp .6s ease both}
.hp-badge-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hp-hero h1{font-family:var(--font-display);font-size:clamp(2.8rem,6.5vw,4.8rem);line-height:1.05;letter-spacing:-.04em;margin-bottom:24px;animation:fadeUp .6s .1s ease both}
.hp-hero h1 em{font-style:italic;background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hp-hero-sub{font-size:1.1rem;color:var(--text-secondary);max-width:560px;margin:0 auto 36px;line-height:1.75;animation:fadeUp .6s .2s ease both}
.hp-hero-form{display:flex;gap:12px;max-width:480px;margin:0 auto 40px;animation:fadeUp .6s .3s ease both}
.hp-hero-form input{flex:1;padding:16px 24px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:100px;color:var(--text-primary);font-size:.9rem;font-family:var(--font-body);outline:none;transition:all .2s}
.hp-hero-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.hp-hero-form input::placeholder{color:var(--text-muted)}
.hp-hero-form button{padding:16px 28px;background:var(--accent);color:var(--selection-text);border:none;border-radius:100px;font-family:var(--font-body);font-weight:700;font-size:.88rem;cursor:pointer;transition:all .2s;white-space:nowrap}
.hp-hero-form button:hover{transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-shadow)}
.hp-hero-stats{display:flex;gap:48px;justify-content:center;animation:fadeUp .6s .4s ease both}
.hp-stat{text-align:center}
.hp-stat-num{font-family:var(--font-mono);font-size:1.4rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}
.hp-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:4px}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Ticker */
.hp-ticker{border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);overflow:hidden;padding:12px 0}
.hp-ticker-track{display:flex;gap:48px;animation:tickerScroll 30s linear infinite;width:max-content}
.hp-ticker-track span{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);white-space:nowrap}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
.hp-section{max-width:1200px;margin:0 auto;padding:72px 24px}
.hp-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid var(--border-light)}
.hp-section-title{font-family:var(--font-display);font-size:2rem;letter-spacing:-.02em}
.hp-section-link{font-size:.85rem;font-weight:500;color:var(--accent);display:flex;align-items:center;gap:6px;text-decoration:none;transition:gap .2s}
.hp-section-link:hover{gap:10px}
.hp-divider{border:none;border-top:1px solid var(--border-light);margin:0 auto;max-width:1200px}

/* Articles grid */
.hp-articles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hp-art{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;transition:all .3s;text-decoration:none;display:flex;flex-direction:column}
.hp-art:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,.2)}
.hp-art-img{width:100%;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-card));position:relative}
.hp-art-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.hp-art:hover .hp-art-img img{transform:scale(1.04)}
.hp-art-img .no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--accent);opacity:.15}
.hp-art-body{padding:24px;flex:1;display:flex;flex-direction:column}
.hp-art-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.hp-art-cat{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);padding:4px 10px;background:var(--accent-glow);border-radius:4px;border:1px solid var(--accent-border)}
.hp-art-date{font-size:.78rem;color:var(--text-muted)}
.hp-art-title{font-family:var(--font-display);font-size:1.1rem;line-height:1.3;letter-spacing:-.01em;margin-bottom:10px;color:var(--text-primary);transition:color .2s}
.hp-art:hover .hp-art-title{color:var(--accent)}
.hp-art-excerpt{font-size:.84rem;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.hp-art-read{margin-top:14px;font-size:.78rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:6px;transition:gap .2s}
.hp-art:hover .hp-art-read{gap:10px}

/* Featured card */
.hp-art.featured{grid-column:1/-1;display:grid;grid-template-columns:1.2fr 1fr}
.hp-art.featured .hp-art-img{aspect-ratio:auto;min-height:320px}
.hp-art.featured .hp-art-body{padding:40px;justify-content:center}
.hp-art.featured .hp-art-title{font-size:1.6rem;line-height:1.2;margin-bottom:14px}
.hp-art.featured .hp-art-excerpt{-webkit-line-clamp:4;font-size:.9rem}

/* Topics grid */
.hp-topics{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.hp-topic{position:relative;padding:28px 24px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;transition:all .3s;text-decoration:none;display:block}
.hp-topic::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;border-radius:3px 0 0 3px;transition:width .3s}
.hp-topic:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.2)}
.hp-topic-icon{font-size:1.6rem;margin-bottom:12px;display:block}
.hp-topic-name{font-family:var(--font-display);font-size:1.1rem;color:var(--text-primary);margin-bottom:6px;transition:color .2s}
.hp-topic-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.55;margin-bottom:14px}
.hp-topic-footer{display:flex;align-items:center;justify-content:space-between}
.hp-topic-count{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}
.hp-topic-arrow{font-size:.82rem;font-weight:600;transition:transform .2s}
.hp-topic:hover .hp-topic-arrow{transform:translateX(4px)}

/* Tools banner */
.hp-tools-banner{display:flex;align-items:center;justify-content:space-between;gap:32px;padding:40px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);transition:all .3s;text-decoration:none}
.hp-tools-banner:hover{border-color:var(--border);box-shadow:0 8px 28px rgba(0,0,0,.15)}
.hp-tools-eyebrow{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:10px}
.hp-tools-title{font-family:var(--font-display);font-size:1.4rem;letter-spacing:-.01em;margin-bottom:6px}
.hp-tools-desc{font-size:.88rem;color:var(--text-secondary);line-height:1.65;max-width:500px}
.hp-tools-icons{display:flex;gap:8px;flex-shrink:0}
.hp-tools-ico{width:44px;height:44px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.2rem}

/* Features grid */
.hp-features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.hp-feat{padding:32px 28px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);transition:all .3s}
.hp-feat:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,.12)}
.hp-feat-icon{font-size:1.6rem;margin-bottom:16px}
.hp-feat-name{font-family:var(--font-display);font-size:1.1rem;margin-bottom:8px}
.hp-feat-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.65}

/* Final CTA */
.hp-cta{max-width:1200px;margin:0 auto;padding:0 24px 80px}
.hp-cta-box{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:72px 48px;text-align:center;position:relative;overflow:hidden}
.hp-cta-box::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:700px;height:500px;background:radial-gradient(ellipse,var(--accent-subtle),transparent 65%);pointer-events:none;opacity:.6}
.hp-cta-box h2{font-family:var(--font-display);font-size:2.5rem;letter-spacing:-.03em;margin-bottom:16px;position:relative}
.hp-cta-box h2 em{font-style:italic;color:var(--accent)}
.hp-cta-box p{font-size:1rem;color:var(--text-secondary);max-width:480px;margin:0 auto 36px;line-height:1.7;position:relative}

/* ============================================
   PAGE HEROES — compact (30-40vh)
   ============================================ */
.page-hero{padding:72px 24px 48px;text-align:center;border-bottom:1px solid var(--border-light);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-100px;left:50%;transform:translateX(-50%);width:600px;height:400px;background:radial-gradient(ellipse,var(--accent-subtle),transparent 65%);pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:700px;margin:0 auto}
.page-hero-eyebrow{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:16px;display:block}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.03em;line-height:1.1;margin-bottom:16px}
.page-hero p{font-size:.98rem;color:var(--text-secondary);max-width:560px;margin:0 auto;line-height:1.7}
.page-hero-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:28px}
.page-hero-filter{padding:8px 18px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:100px;font-size:.82rem;color:var(--text-secondary);cursor:pointer;transition:all .2s;text-decoration:none}
.page-hero-filter:hover,.page-hero-filter.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}

/* ============================================
   BLOG PAGE
   ============================================ */
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;max-width:1200px;margin:0 auto;padding:56px 24px}
.blog-grid{display:grid;grid-template-columns:1fr;gap:28px}
.blog-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden;display:grid;grid-template-columns:200px 1fr;transition:all .3s;text-decoration:none}
.blog-card:hover{border-color:var(--border);box-shadow:0 8px 24px rgba(0,0,0,.15);transform:translateX(4px)}
.blog-card-img{overflow:hidden;background:var(--bg-elevated);position:relative}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;opacity:.1;color:var(--accent)}
.blog-card-body{padding:24px;display:flex;flex-direction:column;justify-content:space-between}
.blog-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.blog-card-cat{font-family:var(--font-mono);font-size:.63rem;text-transform:uppercase;letter-spacing:.08em;padding:3px 9px;border-radius:4px;border:1px solid;font-weight:600}
.blog-card-date{font-size:.76rem;color:var(--text-muted)}
.blog-card-title{font-family:var(--font-display);font-size:1.15rem;line-height:1.3;letter-spacing:-.01em;margin-bottom:8px;color:var(--text-primary);transition:color .2s}
.blog-card:hover .blog-card-title{color:var(--accent)}
.blog-card-excerpt{font-size:.84rem;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-read{margin-top:12px;font-size:.76rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:4px}

/* Sidebar */
.blog-sidebar{display:flex;flex-direction:column;gap:28px}
.sidebar-widget{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:28px}
.sidebar-widget-title{font-family:var(--font-display);font-size:1.1rem;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}
.sidebar-nl-form{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.sidebar-nl-form input{width:100%;padding:12px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.88rem;font-family:var(--font-body)}
.sidebar-nl-form input:focus{outline:none;border-color:var(--accent)}
.sidebar-nl-form button{width:100%;padding:12px;background:var(--accent);color:var(--selection-text);border:none;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s}
.sidebar-nl-form button:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-shadow)}
.sidebar-cats{display:flex;flex-direction:column;gap:6px}
.sidebar-cat{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:8px;border:1px solid transparent;text-decoration:none;transition:all .2s;color:var(--text-secondary);font-size:.86rem}
.sidebar-cat:hover{background:var(--bg-elevated);border-color:var(--border-light);color:var(--text-primary)}
.sidebar-cat-count{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:48px}
.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;font-size:.88rem;font-weight:500;border:1px solid var(--border-light);transition:all .2s;text-decoration:none;color:var(--text-secondary)}
.pagination a:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.pagination .current{background:var(--accent);color:var(--selection-text);border-color:var(--accent)}

/* Search bar */
.search-bar{display:flex;gap:10px;margin-bottom:32px}
.search-bar input{flex:1;padding:14px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;font-family:var(--font-body);outline:none;transition:all .2s}
.search-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.search-bar button{padding:14px 24px;background:var(--accent);color:var(--selection-text);border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s}

/* ============================================
   ARTICLE PAGE
   ============================================ */
.art-layout{display:grid;grid-template-columns:1fr 300px;gap:56px;max-width:1200px;margin:0 auto;padding:48px 24px}
.art-main{}
.art-header{margin-bottom:36px}
.art-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--text-muted);margin-bottom:20px;flex-wrap:wrap}
.art-breadcrumb a{color:var(--text-muted);transition:color .2s}
.art-breadcrumb a:hover{color:var(--accent)}
.art-breadcrumb span{color:var(--border)}
.art-cat{display:inline-block;font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;padding:5px 12px;border-radius:6px;border:1px solid;margin-bottom:16px;font-weight:600}
.art-title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.15;letter-spacing:-.03em;margin-bottom:16px}
.art-meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap;padding:16px 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);margin-bottom:28px}
.art-author{display:flex;align-items:center;gap:10px}
.art-author-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);overflow:hidden;border:1px solid var(--border)}
.art-author-name{font-size:.84rem;font-weight:600;color:var(--text-primary)}
.art-author-role{font-size:.75rem;color:var(--text-muted)}
.art-meta-divider{width:1px;height:24px;background:var(--border-light)}
.art-meta-item{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:6px}
.art-featured-img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius);margin-bottom:36px;background:var(--bg-elevated)}
.art-content{font-size:1.02rem;line-height:1.8;color:var(--text-secondary)}
.art-content h2{font-family:var(--font-display);font-size:1.65rem;letter-spacing:-.02em;color:var(--text-primary);margin:40px 0 16px;line-height:1.3}
.art-content h3{font-family:var(--font-display);font-size:1.25rem;color:var(--text-primary);margin:32px 0 12px;line-height:1.35}
.art-content h4{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:24px 0 10px}
.art-content p{margin-bottom:20px}
.art-content ul,.art-content ol{margin:16px 0 20px 24px}
.art-content li{margin-bottom:8px;line-height:1.7}
.art-content strong{color:var(--text-primary);font-weight:700}
.art-content em{font-style:italic;color:var(--text-secondary)}
.art-content a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-border)}
.art-content a:hover{text-decoration-color:var(--accent)}
.art-content blockquote{border-left:3px solid var(--accent);padding:16px 24px;margin:24px 0;background:var(--bg-elevated);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;color:var(--text-secondary)}
.art-content pre{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;overflow-x:auto;margin:24px 0;font-family:var(--font-mono);font-size:.88rem;line-height:1.6}
.art-content code{font-family:var(--font-mono);font-size:.88em;background:var(--bg-elevated);padding:2px 6px;border-radius:4px;color:var(--accent)}
.art-content .callout-box{background:var(--bg-elevated);border:1px solid var(--accent-border);border-radius:var(--radius);padding:24px 28px;margin:28px 0}
.art-content .callout-box h3{font-family:var(--font-display);font-size:1.1rem;color:var(--accent);margin:0 0 12px}
.art-content .callout-box ul{margin-left:20px}
.art-content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:.9rem}
.art-content th{padding:12px 16px;background:var(--bg-elevated);color:var(--text-primary);font-weight:600;text-align:left;border-bottom:2px solid var(--border)}
.art-content td{padding:12px 16px;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}
.art-content tr:hover td{background:var(--bg-elevated)}

/* Article sidebar */
.art-sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:88px;align-self:start}
.art-toc{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:24px}
.art-toc-title{font-family:var(--font-display);font-size:1rem;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}
.art-toc-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.art-toc-list a{font-size:.83rem;color:var(--text-muted);padding:4px 0;border-left:2px solid transparent;padding-left:12px;transition:all .2s;display:block}
.art-toc-list a:hover{color:var(--accent);border-left-color:var(--accent)}

/* Article CTAs */
.art-cta-box{margin-top:48px;padding:32px;background:linear-gradient(135deg,var(--bg-card),var(--bg-elevated));border:1px solid var(--accent-border);border-radius:var(--radius);text-align:center}
.art-cta-box h3{font-family:var(--font-display);font-size:1.3rem;margin-bottom:8px}
.art-cta-box p{font-size:.88rem;color:var(--text-secondary);margin-bottom:20px}
.art-continue-reading{margin-top:48px}
.art-continue-reading h3{font-family:var(--font-display);font-size:1.4rem;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}
.art-related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.art-related-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;text-decoration:none;transition:all .3s;display:block}
.art-related-card:hover{border-color:var(--border);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.art-related-card-cat{font-family:var(--font-mono);font-size:.63rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:8px}
.art-related-card-title{font-family:var(--font-display);font-size:.95rem;line-height:1.3;color:var(--text-primary)}

/* ============================================
   TOOLS PAGE
   ============================================ */
.tools-layout{max-width:1200px;margin:0 auto;padding:56px 24px}
.tools-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}
.tools-filter{padding:8px 18px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:100px;font-size:.82rem;color:var(--text-secondary);cursor:pointer;transition:all .2s;border:1px solid;text-decoration:none}
.tools-filter:hover,.tools-filter.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tool-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:24px;transition:all .3s;display:flex;flex-direction:column;text-decoration:none}
.tool-card:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.15)}
.tool-card-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.tool-logo{width:44px;height:44px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.tool-card-name{font-family:var(--font-display);font-size:1.1rem;margin-bottom:4px}
.tool-card-tagline{font-size:.78rem;color:var(--text-muted)}
.tool-card-desc{font-size:.84rem;color:var(--text-secondary);line-height:1.6;flex:1;margin-bottom:16px}
.tool-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--border-light)}
.tool-card-pricing{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}
.tool-card-rating{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-secondary)}
.tool-card-rating span{color:#f59e0b;font-size:.9rem}
.tool-cat-badge{font-family:var(--font-mono);font-size:.63rem;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:4px;border:1px solid;font-weight:600;align-self:flex-start;margin-bottom:10px}

/* Tool Review Page */
.tool-review-layout{max-width:900px;margin:0 auto;padding:48px 24px}
.tool-review-header{display:flex;align-items:flex-start;gap:24px;margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid var(--border-light)}
.tool-review-logo{width:80px;height:80px;border-radius:16px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0}
.tool-review-meta h1{font-family:var(--font-display);font-size:2.2rem;letter-spacing:-.02em;margin-bottom:8px}
.tool-review-rating{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.stars{color:#f59e0b;font-size:1.1rem;letter-spacing:2px}
.tool-review-price{font-size:.88rem;color:var(--text-muted)}
.tool-review-actions{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--accent);color:var(--selection-text);border-radius:8px;font-weight:600;font-size:.88rem;transition:all .2s;text-decoration:none;border:none;cursor:pointer}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-shadow);color:var(--selection-text)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-weight:500;font-size:.88rem;transition:all .2s;text-decoration:none}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:28px 0}
.pros-col,.cons-col{background:var(--bg-elevated);border-radius:var(--radius);padding:20px 24px}
.pros-col{border-top:3px solid var(--pro-color)}
.cons-col{border-top:3px solid var(--con-color)}
.pros-col h4{color:var(--pro-color);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.cons-col h4{color:var(--con-color);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.pros-col li,.cons-col li{font-size:.88rem;color:var(--text-secondary);line-height:1.6;margin-bottom:8px;list-style:none;padding-left:20px;position:relative}
.pros-col li::before{content:'✓';position:absolute;left:0;color:var(--pro-color);font-weight:700}
.cons-col li::before{content:'✗';position:absolute;left:0;color:var(--con-color);font-weight:700}
.tool-section-title{font-family:var(--font-display);font-size:1.4rem;margin:32px 0 16px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}

/* ============================================
   GLOSSARY PAGE
   ============================================ */
.glossary-layout{max-width:1100px;margin:0 auto;padding:56px 24px}
.glossary-alpha{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:36px}
.glossary-alpha a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border-light);border-radius:8px;font-size:.82rem;font-weight:600;color:var(--text-secondary);transition:all .2s;text-decoration:none}
.glossary-alpha a:hover,.glossary-alpha a.has-terms{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.glossary-section{margin-bottom:48px}
.glossary-letter{font-family:var(--font-display);font-size:2rem;letter-spacing:-.02em;color:var(--accent);margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}
.glossary-terms{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.glossary-term-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;transition:all .2s;text-decoration:none;display:block}
.glossary-term-card:hover{border-color:var(--border);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.glossary-term-name{font-family:var(--font-display);font-size:1.05rem;color:var(--text-primary);margin-bottom:8px;transition:color .2s}
.glossary-term-card:hover .glossary-term-name{color:var(--accent)}
.glossary-term-def{font-size:.84rem;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.glossary-cat-badge{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px}
.glossary-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}

/* ============================================
   GUIDES PAGE
   ============================================ */
.guides-layout{max-width:1200px;margin:0 auto;padding:56px 24px}
.guides-bundle{background:linear-gradient(135deg,var(--bg-card),var(--bg-elevated));border:1px solid var(--accent-border);border-radius:var(--radius);padding:40px;margin-bottom:48px;position:relative;overflow:hidden}
.guides-bundle::before{content:'';position:absolute;top:-40px;right:-40px;width:300px;height:300px;background:radial-gradient(ellipse,var(--accent-subtle),transparent 70%);pointer-events:none}
.guides-bundle-badge{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);background:var(--accent-glow);padding:4px 12px;border-radius:100px;border:1px solid var(--accent-border);display:inline-block;margin-bottom:14px}
.guides-bundle h2{font-family:var(--font-display);font-size:1.8rem;letter-spacing:-.02em;margin-bottom:10px}
.guides-bundle p{font-size:.9rem;color:var(--text-secondary);max-width:500px;line-height:1.7;margin-bottom:24px}
.guides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.guide-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:28px;transition:all .3s;text-decoration:none;display:flex;flex-direction:column}
.guide-card:hover{border-color:var(--border);transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.2)}
.guide-tier{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;padding:4px 10px;border-radius:100px;border:1px solid;display:inline-block;margin-bottom:14px;align-self:flex-start}
.guide-tier.free{color:var(--pro-color);border-color:rgba(0,255,163,.2);background:rgba(0,255,163,.05)}
.guide-tier.pro{color:#f59e0b;border-color:rgba(245,158,11,.2);background:rgba(245,158,11,.05)}
.guide-tier.premium{color:var(--accent);border-color:var(--accent-border);background:var(--accent-glow)}
.guide-card h3{font-family:var(--font-display);font-size:1.15rem;margin-bottom:10px;line-height:1.3;color:var(--text-primary)}
.guide-card p{font-size:.84rem;color:var(--text-secondary);line-height:1.6;flex:1;margin-bottom:16px}
.guide-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border-light);margin-top:auto}
.guide-card-price{font-family:var(--font-mono);font-size:.88rem;font-weight:600;color:var(--text-primary)}
.guide-card-chapters{font-size:.76rem;color:var(--text-muted)}

/* ============================================
   AUTHOR PAGE
   ============================================ */
.author-header{max-width:800px;margin:0 auto;padding:56px 24px 40px;text-align:center}
.author-avatar{width:96px;height:96px;border-radius:50%;margin:0 auto 20px;background:var(--bg-elevated);border:2px solid var(--border);overflow:hidden}
.author-name{font-family:var(--font-display);font-size:2rem;letter-spacing:-.02em;margin-bottom:8px}
.author-role{font-size:.92rem;color:var(--accent);margin-bottom:16px;font-family:var(--font-mono)}
.author-bio{font-size:.95rem;color:var(--text-secondary);line-height:1.75;max-width:600px;margin:0 auto}

/* ============================================
   SUBSCRIBE PAGE
   ============================================ */
.subscribe-layout{max-width:680px;margin:0 auto;padding:56px 24px}
.subscribe-form-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:48px}
.subscribe-form{display:flex;flex-direction:column;gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}
.form-group input,.form-group textarea{padding:14px 18px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.92rem;font-family:var(--font-body);outline:none;transition:all .2s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.subscribe-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:36px 0}
.subscribe-stat{text-align:center;padding:20px;background:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border-light)}
.subscribe-stat-num{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--accent);margin-bottom:4px}
.subscribe-stat-label{font-size:.78rem;color:var(--text-muted)}

/* ============================================
   ADVERTISE PAGE
   ============================================ */
.advertise-layout{max-width:1100px;margin:0 auto;padding:56px 24px}
.advertise-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:64px}
.advertise-stat-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:28px;text-align:center}
.advertise-stat-num{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--accent);margin-bottom:6px}
.advertise-stat-label{font-size:.8rem;color:var(--text-secondary)}
.advertise-formats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:48px}
.format-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:28px;transition:all .2s}
.format-card:hover{border-color:var(--accent-border)}
.format-card h3{font-family:var(--font-display);font-size:1.15rem;margin-bottom:10px}
.format-card p{font-size:.86rem;color:var(--text-secondary);line-height:1.6}
.tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px}
.tier-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:32px;transition:all .2s;text-align:center;position:relative}
.tier-card.featured{border-color:var(--accent-border);background:linear-gradient(135deg,var(--bg-card),var(--bg-elevated))}
.tier-card-name{font-family:var(--font-display);font-size:1.3rem;margin-bottom:8px}
.tier-card-desc{font-size:.84rem;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}
.tier-card-features{list-style:none;text-align:left;margin-bottom:28px}
.tier-card-features li{font-size:.85rem;color:var(--text-secondary);padding:6px 0;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:8px}
.tier-card-features li::before{content:'✓';color:var(--pro-color);font-weight:700;flex-shrink:0}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-layout{max-width:800px;margin:0 auto;padding:56px 24px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:48px}

/* ============================================
   FOOTER
   ============================================ */
.ft{background:var(--bg-elevated);border-top:1px solid var(--border-light)}
.ft-newsletter{background:linear-gradient(135deg,var(--bg-card),var(--bg-elevated));border-bottom:1px solid var(--border-light);padding:56px 24px}
.ft-nl-inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.ft-nl-badge{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:10px}
.ft-nl-title{font-family:var(--font-display);font-size:1.7rem;letter-spacing:-.02em;margin-bottom:10px}
.ft-nl-desc{font-size:.88rem;color:var(--text-secondary);line-height:1.7}
.ft-nl-form{display:flex;flex-direction:column;gap:12px}
.ft-nl-input{padding:14px 20px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;font-family:var(--font-body);outline:none;transition:all .2s}
.ft-nl-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.ft-nl-btn{padding:14px 24px;background:var(--accent);color:var(--selection-text);border:none;border-radius:8px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s}
.ft-nl-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-shadow)}
.ft-main{padding:56px 24px}
.ft-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px}
.ft-brand{}
.ft-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.3rem;letter-spacing:-.02em;margin-bottom:16px;text-decoration:none;color:var(--text-primary)}
.ft-logo-icon{width:28px;height:28px;background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.ft-tagline{font-size:.86rem;color:var(--text-secondary);line-height:1.7;margin-bottom:20px}
.ft-social{display:flex;gap:10px}
.ft-social-link{width:36px;height:36px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .2s}
.ft-social-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.ft-col-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-family:var(--font-mono);margin-bottom:16px}
.ft-link{display:block;font-size:.88rem;color:var(--text-secondary);padding:6px 0;transition:color .2s;text-decoration:none}
.ft-link:hover{color:var(--accent)}
.ft-bottom{border-top:1px solid var(--border-light);padding:24px}
.ft-bottom-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.ft-copy{font-size:.8rem;color:var(--text-muted)}
.ft-made{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono)}

/* ============================================
   COOKIE CONSENT
   ============================================ */
.cookie-banner{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:9998;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 28px;display:flex;align-items:center;gap:20px;max-width:680px;width:calc(100% - 48px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.cookie-banner p{font-size:.84rem;color:var(--text-secondary);line-height:1.5;flex:1}
.cookie-banner a{color:var(--accent)}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-accept{padding:9px 20px;background:var(--accent);color:var(--selection-text);border:none;border-radius:8px;font-weight:600;font-size:.82rem;cursor:pointer;transition:all .2s}
.cookie-decline{padding:9px 16px;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.82rem;cursor:pointer;transition:all .2s}

/* ============================================
   ALERTS
   ============================================ */
.alert{padding:14px 20px;border-radius:var(--radius-sm);border:1px solid;margin-bottom:20px;font-size:.88rem}
.alert-success{background:rgba(0,255,163,.08);border-color:rgba(0,255,163,.2);color:var(--pro-color)}
.alert-error{background:rgba(255,107,107,.08);border-color:rgba(255,107,107,.2);color:var(--con-color)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:8px;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s;text-decoration:none;border:none}
.btn-accent{background:var(--accent);color:var(--selection-text)}
.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-shadow);color:var(--selection-text)}
.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* ============================================
   LEGAL PAGES
   ============================================ */
.legal-layout{max-width:760px;margin:0 auto;padding:56px 24px}
.legal-layout h1{font-family:var(--font-display);font-size:2.4rem;letter-spacing:-.03em;margin-bottom:8px}
.legal-date{font-size:.82rem;color:var(--text-muted);margin-bottom:40px;font-family:var(--font-mono)}
.legal-content h2{font-family:var(--font-display);font-size:1.35rem;margin:36px 0 14px;color:var(--text-primary)}
.legal-content h3{font-size:1.05rem;font-weight:600;margin:24px 0 10px}
.legal-content p,.legal-content li{font-size:.92rem;color:var(--text-secondary);line-height:1.8;margin-bottom:12px}
.legal-content ul,.legal-content ol{margin:12px 0 16px 24px}
.legal-content a{color:var(--accent)}

/* ============================================
   404
   ============================================ */
.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;text-align:center;padding:40px 24px}
.not-found-code{font-family:var(--font-mono);font-size:6rem;font-weight:700;color:var(--border);line-height:1}
.not-found h1{font-family:var(--font-display);font-size:2rem;margin:16px 0 12px}
.not-found p{font-size:.95rem;color:var(--text-secondary);max-width:400px;line-height:1.7}
.not-found-links{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap;justify-content:center}

/* ============================================
   CATEGORY PAGE
   ============================================ */
.cat-header{border-bottom:1px solid var(--border-light);padding:56px 24px 40px;position:relative;overflow:hidden}
.cat-header::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px}
.cat-header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:flex-end;gap:28px}
.cat-icon-big{width:64px;height:64px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}
.cat-header h1{font-family:var(--font-display);font-size:2.4rem;letter-spacing:-.02em;margin-bottom:8px}
.cat-header-desc{font-size:.92rem;color:var(--text-secondary);line-height:1.65}
.cat-layout{max-width:1200px;margin:0 auto;padding:48px 24px}
.cat-articles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}

/* ============================================
   NEWSLETTER SUCCESS
   ============================================ */
.success-page{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;text-align:center}
.success-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:56px 48px;max-width:560px}
.success-icon{font-size:3rem;margin-bottom:20px}
.success-card h1{font-family:var(--font-display);font-size:2rem;letter-spacing:-.02em;margin-bottom:12px}
.success-card p{font-size:.95rem;color:var(--text-secondary);line-height:1.7}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .hp-articles{grid-template-columns:repeat(2,1fr)}
  .hp-art.featured{grid-template-columns:1fr;grid-column:1/-1}
  .hp-art.featured .hp-art-img{min-height:220px}
  .hp-topics{grid-template-columns:repeat(2,1fr)}
  .hp-features{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr;gap:32px}
  .ft-nl-inner{grid-template-columns:1fr}
  .tools-grid{grid-template-columns:repeat(2,1fr)}
  .guides-grid{grid-template-columns:repeat(2,1fr)}
  .art-layout{grid-template-columns:1fr}
  .blog-layout{grid-template-columns:1fr}
  .blog-sidebar{display:none}
  .advertise-stats{grid-template-columns:repeat(2,1fr)}
  .tiers-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .site-nav{padding:0 20px}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .nav-cta{display:none}
  .hp-hero{padding:96px 20px 56px;max-height:none}
  .hp-hero h1{font-size:2.4rem}
  .hp-hero-form{flex-direction:column}
  .hp-hero-stats{gap:24px}
  .hp-section{padding:48px 20px}
  .hp-articles{grid-template-columns:1fr}
  .hp-art.featured{grid-template-columns:1fr}
  .hp-topics{grid-template-columns:1fr}
  .hp-features{grid-template-columns:1fr}
  .hp-cta-box{padding:40px 24px}
  .blog-card{grid-template-columns:1fr}
  .blog-card-img{height:180px}
  .ft-grid{grid-template-columns:1fr}
  .ft-nl-inner{grid-template-columns:1fr}
  .tools-grid{grid-template-columns:1fr}
  .guides-grid{grid-template-columns:1fr}
  .pros-cons{grid-template-columns:1fr}
  .advertise-stats{grid-template-columns:1fr 1fr}
  .advertise-formats{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cat-articles-grid{grid-template-columns:1fr}
  .hp-tools-banner{flex-direction:column;align-items:flex-start}
  .glossary-terms{grid-template-columns:1fr}
  .art-related-grid{grid-template-columns:1fr}
  .subscribe-stats{grid-template-columns:1fr}
  .tool-review-header{flex-direction:column}
}
@media(max-width:480px){
  .hp-hero h1{font-size:2rem}
  .hp-stat-num{font-size:1.2rem}
  .hp-cta-box h2{font-size:1.8rem}
  .page-hero h1{font-size:1.8rem}
  .art-title{font-size:1.6rem}
  .cookie-banner{flex-direction:column;align-items:flex-start}
  .cookie-actions{width:100%}
}
