/* ============================================================
   LA BIBLE DE L'IA — DESIGN SYSTEM
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg-page:#faf8f3;--bg-surface:#ffffff;--bg-elevated:#f5f3ee;
  --bg-infobox:#f8f4eb;--bg-dark:#1a1a2e;--bg-dark-surface:#24243e;
  --ink:#1a1a2e;--ink-secondary:#4a4a5a;--ink-tertiary:#7a7a8a;--ink-inverse:#faf8f3;
  --gold:#c9a84c;--gold-light:#e4c76b;--gold-glow:rgba(201,168,76,.15);
  --link:#2563eb;--link-hover:#1d4ed8;
  --prix-gratuit:#059669;--prix-freemium:#d97706;--prix-payant:#dc2626;--prix-essai:#7c3aed;
  --cat-chatbots:#14b8a6;--cat-texte:#3b82f6;--cat-image:#ec4899;--cat-video:#f59e0b;
  --cat-audio:#8b5cf6;--cat-code:#10b981;--cat-marketing:#ef4444;
  --cat-productivite:#6366f1;--cat-education:#f97316;--cat-automation:#64748b;
  --cat-recherche:#0ea5e9;--cat-design-web:#d946ef;--cat-reunions-email:#06b6d4;
  --cat-carriere:#84cc16;--cat-finance:#eab308;--cat-3d:#f472b6;
  --cat-sante:#22c55e;--cat-juridique:#a855f7;--cat-service-client:#f43f5e;--cat-data:#0891b2;
  --border-light:rgba(0,0,0,.06);--border-medium:rgba(0,0,0,.1);
  --shadow-sm:0 1px 3px rgba(26,26,46,.06);--shadow-md:0 4px 12px rgba(26,26,46,.08);
  --shadow-lg:0 12px 32px rgba(26,26,46,.12);
  --star-filled:#f59e0b;--star-empty:#d4c9b8;
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans','Helvetica Neue',sans-serif;
  --font-ui:'DM Sans','Helvetica Neue',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'Cascadia Code','Fira Code',monospace;
  --radius-sm:6px;--radius-md:10px;--radius-lg:16px;
}

html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg-page);color:var(--ink);font-family:var(--font-body);line-height:1.7;overflow-x:hidden}

/* Paper texture — disabled on mobile for GPU performance */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.3;
  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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:256px}
@media(max-width:768px){body::before{display:none}}

/* Skip to content — accessibility (canonical rule at bottom of file) */

/* Scroll progress */
.scroll-progress{position:fixed;top:0;left:0;height:3px;z-index:10001;width:0;
  background:linear-gradient(90deg,var(--gold),var(--gold-light))}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3{font-family:var(--font-display);line-height:1.2}
h1{font-size:clamp(2.5rem,6vw,5rem);font-weight:900}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:900}
h3{font-size:1.3rem;font-weight:700}
a{color:var(--link);text-decoration:none;transition:color .2s}
a:hover{color:var(--link-hover)}
::selection{background:var(--gold-glow);color:var(--ink)}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 4vw;height:60px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(26,26,46,.92);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(244,241,235,.06);
  transform:translateY(-100%);transition:transform .4s cubic-bezier(.22,1,.36,1)}
.nav.visible{transform:translateY(0)}
/* Language switcher */
.lang-switcher{display:flex;gap:.3rem;margin-right:.6rem}
.lang-btn{background:none;border:1px solid rgba(244,241,235,.12);border-radius:4px;padding:.2rem .35rem;
  cursor:pointer;line-height:1;transition:all .3s;text-decoration:none;display:flex;align-items:center}
.lang-btn:hover{border-color:var(--gold);background:rgba(201,168,76,.1)}
.lang-btn.active{border-color:var(--gold);background:rgba(201,168,76,.15)}
.lang-btn img{width:22px;height:16px;border-radius:2px;display:block}
.nav-left{display:flex;align-items:center;gap:.4rem}
.nav-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.nav-logo svg{width:26px;height:26px}
.nav-logo span{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--ink-inverse)}
.nav-links{display:flex;align-items:center;gap:1.5rem}
.nav-links a{color:rgba(244,241,235,.85);font-family:var(--font-ui);font-size:.8rem;font-weight:500;
  letter-spacing:.05em;transition:color .3s;text-decoration:none}
.nav-links a:hover{color:var(--gold)}
.nav-compare-badge{background:var(--gold);color:var(--bg-dark);font-size:.65rem;font-weight:700;
  padding:1px 6px;border-radius:10px;margin-left:-.3rem;display:none}
.nav-search-btn{background:none;border:1px solid rgba(244,241,235,.12);color:rgba(244,241,235,.65);
  padding:.35rem .8rem;border-radius:6px;cursor:pointer;font-family:var(--font-mono);font-size:.7rem;
  display:flex;align-items:center;gap:.5rem;transition:all .3s}
.nav-search-btn:hover{border-color:var(--gold);color:var(--gold)}
.nav-search-btn kbd{font-size:.6rem;background:rgba(244,241,235,.08);padding:1px 5px;border-radius:3px}
.nav-fav-btn{background:none;border:1px solid rgba(244,241,235,.12);color:rgba(244,241,235,.65);
  padding:.35rem .5rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:.3rem;transition:all .3s}
.nav-fav-btn:hover{border-color:var(--gold);color:var(--gold)}
.nav-fav-btn svg{width:14px;height:14px}
.nav-cta{background:var(--gold);color:var(--bg-dark);font-family:var(--font-ui);font-size:.75rem;
  font-weight:700;padding:.45rem 1rem;border-radius:6px;border:none;cursor:pointer;
  letter-spacing:.03em;transition:all .3s;text-decoration:none}
.nav-cta:hover{background:var(--gold-light);color:var(--bg-dark)}

/* Nav dropdown */
.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:.3rem}
.nav-dropdown>a::after{content:'▾';font-size:.6rem;opacity:.5;transition:transform .3s}
.nav-dropdown:hover>a::after{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(5px);
  min-width:180px;background:rgba(26,26,46,.96);backdrop-filter:blur(20px);
  border:1px solid rgba(244,241,235,.08);border-radius:10px;padding:.5rem 0;
  opacity:0;visibility:hidden;transition:all .25s ease;z-index:1001;
  box-shadow:0 12px 40px rgba(0,0,0,.4)}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown-menu a{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.2rem;
  color:rgba(244,241,235,.75)!important;font-size:.78rem!important;transition:all .2s}
.nav-dropdown-menu a:hover{color:var(--gold)!important;background:rgba(201,168,76,.06)}
.nav-dropdown-menu a svg{width:14px;height:14px;opacity:.4;flex-shrink:0}

/* Quiz promo banner */
.quiz-promo{display:flex;align-items:center;justify-content:center;gap:.75rem;
  max-width:720px;margin:0 auto 1.5rem;padding:.75rem 1.5rem;margin-inline:auto;
  background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.03));
  border:1px solid rgba(201,168,76,.18);border-radius:12px;animation:fadeUp .6s .4s both}
.quiz-promo-icon{font-size:1.3rem;flex-shrink:0}
.quiz-promo-text{font-size:.9rem;color:var(--ink-secondary);margin:0}
.quiz-promo-text strong{color:var(--ink);font-weight:600}
.quiz-promo-btn{flex-shrink:0;padding:.45rem 1.1rem;background:var(--gold);color:#fff;
  border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;
  transition:background .2s,transform .2s;white-space:nowrap}
.quiz-promo-btn:hover{background:var(--gold-light);transform:translateY(-1px)}

/* Weekly Banner — Strip compact (Option B) */
.weekly-banner{display:flex;gap:0;margin:0 4vw 2rem;border-radius:14px;overflow:hidden;
  border:1px solid var(--border-light);background:var(--bg-surface);animation:fadeUp .6s .3s both}
.weekly-banner-item{flex:1;padding:1rem 1.2rem;display:flex;align-items:center;gap:.8rem;
  position:relative;transition:background .3s;text-decoration:none;color:inherit;cursor:pointer}
.weekly-banner-item:hover{background:rgba(201,168,76,.04)}
.weekly-banner-item+.weekly-banner-item::before{content:'';position:absolute;left:0;top:15%;height:70%;
  width:1px;background:var(--border-light)}
.strip-icon-wrap{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:1.4rem;flex-shrink:0}
.strip-icon-wrap.gold-bg{background:linear-gradient(135deg,rgba(201,168,76,.12),rgba(201,168,76,.04))}
.strip-icon-wrap.red-bg{background:linear-gradient(135deg,rgba(231,76,60,.1),rgba(231,76,60,.04))}
.strip-icon-wrap.vs-bg{background:var(--gold);color:#fff;font-family:var(--font-display);font-weight:900;font-size:.7rem}
.strip-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.strip-label{font-family:var(--font-ui);font-size:.55rem;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;color:var(--gold)}
.strip-label.red{color:#e74c3c}
.strip-name{font-family:var(--font-display);font-weight:700;font-size:.85rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.strip-meta{font-size:.7rem;color:var(--ink-tertiary)}
.strip-arrow{margin-left:auto;color:var(--ink-tertiary);font-size:.8rem;transition:transform .3s;flex-shrink:0}
.weekly-banner-item:hover .strip-arrow{transform:translateX(3px);color:var(--gold)}
@media(max-width:600px){.quiz-promo{flex-direction:column;text-align:center;padding:1rem}
  .quiz-promo-btn{width:100%}}
@media(max-width:768px){.weekly-banner{flex-direction:column}
  .weekly-banner-item+.weekly-banner-item::before{top:0;left:10%;width:80%;height:1px}}

/* Mobile nav */
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:.5rem}
.nav-hamburger span{display:block;width:20px;height:2px;background:var(--ink-inverse);margin:4px 0;transition:all .3s}

@media(max-width:768px){
  .nav-links{display:none}
  .nav-hamburger{display:block}
  .nav-search-btn kbd{display:none}
  .lang-switcher{margin-right:.3rem}
  .lang-btn{font-size:.75rem;padding:.2rem .35rem}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:6rem 4vw 4rem;position:relative;overflow:hidden;
  background:linear-gradient(170deg,#0d0d1a 0%,var(--bg-dark) 40%,#1e1e3a 100%)}
.hero::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:150px;
  background:linear-gradient(to top,var(--bg-page),transparent)}

/* Decorative ornament */
.hero-ornament{font-family:var(--font-display);font-size:.75rem;letter-spacing:.5em;text-transform:uppercase;
  color:var(--gold);margin-bottom:2rem;display:flex;align-items:center;gap:1.5rem;
  opacity:0;animation:fadeUp .8s .2s forwards}
.hero-ornament::before,.hero-ornament::after{content:'';width:60px;height:1px;background:var(--gold);opacity:.4}

.hero h1{color:var(--ink-inverse);max-width:800px;opacity:0;animation:fadeUp .8s .4s forwards}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-family:var(--font-body);font-size:1.1rem;color:rgba(244,241,235,.7);
  max-width:550px;margin-top:1.2rem;font-weight:400;opacity:0;animation:fadeUp .8s .6s forwards}

/* Hero search */
.hero-search{margin-top:2.5rem;width:100%;max-width:600px;position:relative;opacity:0;animation:fadeUp .8s .8s forwards}
.hero-search input{width:100%;padding:1rem 1.5rem 1rem 3.2rem;border:2px solid rgba(244,241,235,.1);
  border-radius:12px;background:rgba(244,241,235,.06);color:var(--ink-inverse);font-family:var(--font-ui);
  font-size:1rem;outline:none;transition:all .3s}
.hero-search input::placeholder{color:rgba(244,241,235,.5)}
.hero-search input:focus{border-color:var(--gold);background:rgba(244,241,235,.1);box-shadow:0 0 30px rgba(201,168,76,.15)}
.hero-search-icon{position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);
  width:20px;height:20px;stroke:rgba(244,241,235,.3);fill:none;stroke-width:2}

/* Category pills */
.hero-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1.5rem;
  opacity:0;animation:fadeUp .8s 1s forwards}
.hero-cat-pill{font-family:var(--font-ui);font-size:.75rem;font-weight:500;padding:.4rem .9rem;
  border-radius:20px;border:1px solid rgba(244,241,235,.15);color:rgba(244,241,235,.7);
  cursor:pointer;transition:all .3s;text-decoration:none;background:transparent}
.hero-cat-pill:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.08)}

/* Hero stats */
.hero-stats{display:flex;gap:3rem;margin-top:3rem;opacity:0;animation:fadeUp .8s 1.2s forwards}
.hero-stat{text-align:center}
.hero-stat .num{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--gold)}
.hero-stat .lbl{font-size:.7rem;font-family:var(--font-mono);color:rgba(244,241,235,.6);
  text-transform:uppercase;letter-spacing:.15em;margin-top:.2rem}

@media(max-width:600px){
  .hero-stats{gap:1.5rem;flex-wrap:wrap}
  .hero-stat .num{font-size:1.5rem}
}

/* ============================================================
   ORNAMENTAL DIVIDER
   ============================================================ */
.divider{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.5rem 0;color:var(--border-medium)}
.divider::before,.divider::after{content:'';flex:1;max-width:200px;height:1px;background:var(--border-light)}
.divider svg{width:20px;height:20px;fill:var(--gold);opacity:.5}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:4rem 4vw;position:relative}
.section-dark{background:var(--bg-dark);color:var(--ink-inverse)}
.section-cream{background:var(--bg-elevated)}
.section-label{font-family:var(--font-mono);font-size:.85rem;letter-spacing:.4em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.8rem;text-align:center}
.section-title{margin-bottom:.5rem;text-align:center}
.section-desc{font-size:1rem;color:var(--ink-secondary);max-width:600px;margin-bottom:2.5rem;text-align:center;margin-inline:auto}
.section-dark .section-desc{color:rgba(244,241,235,.7)}

/* ============================================================
   TABLE OF CONTENTS + FEATURED
   ============================================================ */
.toc-grid{display:flex;flex-direction:column;gap:2rem}

/* TOC list — compact grid */
.toc-list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:.3rem;max-width:900px;margin:0 auto}
@media(max-width:900px){.toc-list{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.toc-list{grid-template-columns:1fr}}
.toc-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:var(--radius-md);
  cursor:pointer;transition:all .3s;text-decoration:none;color:var(--ink)}
.toc-item:hover{background:var(--bg-surface);box-shadow:var(--shadow-sm);color:var(--ink)}
.toc-roman{font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--gold);min-width:28px}
.toc-icon{font-size:1.1rem}
.toc-info{flex:1;display:flex;flex-direction:column;gap:.1rem}
.toc-cat-name{font-family:var(--font-ui);font-weight:600;font-size:.8rem;display:block}
.toc-cat-count{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-tertiary);display:block}

/* Featured grid — compact cards with tagline */
.featured-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;max-width:1000px;margin:0 auto}
@media(max-width:900px){.featured-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.featured-grid{grid-template-columns:1fr}}
.featured-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-sm);
  padding:.8rem;cursor:pointer;transition:all .3s;text-decoration:none;color:var(--ink);display:block;
  min-height:100px;contain:content}
.featured-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);color:var(--ink)}
.featured-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}
.featured-card-icon{font-size:1.3rem;flex-shrink:0}
.featured-card-name{font-family:var(--font-display);font-weight:700;font-size:.85rem}
.featured-card-company{display:none}
.featured-card-tagline{font-size:.7rem;color:var(--ink-secondary);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.featured-card-footer{display:none}
.editor-badge{display:none}

/* ============================================================
   CATALOG
   ============================================================ */
.catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:2.5rem;align-items:start}
@media(max-width:1024px){.catalog-layout{grid-template-columns:220px 1fr;gap:1.5rem}}
@media(max-width:900px){.catalog-layout{grid-template-columns:1fr}}

/* Filters sidebar */
.filters{position:sticky;top:80px}
.filters-section{margin-bottom:1.5rem}
.filters-title{font-family:var(--font-ui);font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.15em;color:var(--ink-tertiary);margin-bottom:.7rem}
.filter-option{display:flex;align-items:center;gap:.6rem;padding:.35rem 0;cursor:pointer;
  font-family:var(--font-ui);font-size:.85rem;color:var(--ink-secondary);transition:color .2s}
.filter-option:hover{color:var(--ink)}
.filter-option input[type="checkbox"]{accent-color:var(--gold);width:15px;height:15px;cursor:pointer}
.filter-count{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-tertiary);margin-left:auto}
.filter-stars{display:flex;gap:2px;cursor:pointer}
.filter-star{font-size:1.1rem;color:var(--star-empty);transition:color .2s;cursor:pointer}
.filter-star.filled{color:var(--star-filled)}
.filter-reset{font-family:var(--font-ui);font-size:.75rem;color:#9a7d2e;cursor:pointer;
  background:none;border:none;padding:.3rem 0;margin-top:.5rem;transition:opacity .2s}
.filter-reset:hover{opacity:.7}
.filters-divider{height:1px;background:var(--border-light);margin:1rem 0}

@media(max-width:900px){
  .filters{position:fixed;bottom:0;left:0;right:0;top:auto;z-index:900;background:var(--bg-surface);
    padding:1.5rem;border-top:1px solid var(--border-light);box-shadow:0 -4px 20px rgba(0,0,0,.1);
    transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);
    max-height:70vh;overflow-y:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .filters.open{transform:translateY(0)}
}

/* Active filters bar */
.active-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.2rem;min-height:32px}
.active-filter-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .7rem;
  border-radius:20px;background:var(--gold-glow);color:var(--gold);font-family:var(--font-ui);
  font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}
.active-filter-pill:hover{border-color:var(--gold);background:rgba(201,168,76,.25)}
.active-filter-pill .x{font-weight:700;margin-left:.2rem}
.results-count{font-family:var(--font-mono);font-size:.75rem;color:var(--ink-tertiary)}

/* Catalog toolbar */
.catalog-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}
.view-toggle{display:flex;gap:4px;background:var(--bg-elevated);border-radius:var(--radius-sm);padding:3px}
.view-btn{background:none;border:none;padding:.4rem .6rem;border-radius:4px;cursor:pointer;
  color:var(--ink-tertiary);transition:all .2s;display:flex;align-items:center}
.view-btn.active{background:var(--bg-surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.view-btn svg{width:16px;height:16px;fill:currentColor}
.sort-select{font-family:var(--font-ui);font-size:.8rem;padding:.4rem .8rem;border:1px solid var(--border-light);
  border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--ink);cursor:pointer;outline:none}
.mobile-filter-btn{display:none;font-family:var(--font-ui);font-size:.8rem;font-weight:600;
  padding:.5rem 1rem;border:1px solid var(--border-light);border-radius:var(--radius-sm);
  background:var(--bg-surface);cursor:pointer;color:var(--ink)}
@media(max-width:900px){.mobile-filter-btn{display:flex;align-items:center;gap:.4rem}}

/* Tool cards grid */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;
  align-items:start}
.tools-grid.list-view{grid-template-columns:1fr}

/* Tool card — min-height prevents CLS during lazy rendering */
.tool-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);
  padding:1.4rem;cursor:pointer;transition:all .3s;position:relative;display:flex;flex-direction:column;text-decoration:none;color:inherit;
  min-height:220px;contain:content}
.tool-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.tool-card-header{display:flex;align-items:flex-start;gap:.8rem;margin-bottom:.8rem}
.tool-card-icon{font-size:2.2rem;line-height:1}
.tool-card-info{flex:1;min-width:0}
.tool-card-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;line-height:1.3}
.tool-card-company{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-tertiary);margin-top:.1rem}
.tool-card-tagline{font-size:.82rem;color:var(--ink-secondary);line-height:1.5;margin-bottom:.8rem;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tool-card-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.8rem}
.tool-card-tag{font-family:var(--font-mono);font-size:.6rem;font-weight:600;padding:.2rem .5rem;
  border-radius:4px;text-transform:uppercase;letter-spacing:.05em;color:#fff}
/* Tool Badges */
.tool-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.6rem}
.tool-badge{font-family:var(--font-ui);font-size:.65rem;font-weight:600;padding:.2rem .55rem;
  border-radius:20px;letter-spacing:.02em;display:inline-flex;align-items:center;gap:.25rem;line-height:1.2}
.badge-quality{background:rgba(139,92,246,.12);color:#7c3aed;border:1px solid rgba(139,92,246,.25)}
.badge-value{background:rgba(201,168,76,.12);color:#a08030;border:1px solid rgba(201,168,76,.3)}
.badge-trust{background:rgba(59,130,246,.1);color:#2563eb;border:1px solid rgba(59,130,246,.25)}
.badge-eu{background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.25)}
.badge-open{background:rgba(20,184,166,.1);color:#0d9488;border:1px solid rgba(20,184,166,.25)}
.badge-discontinued{background:rgba(107,114,128,.12);color:#6b7280;border:1px solid rgba(107,114,128,.25)}
.tool-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.8rem;
  border-top:1px solid var(--border-light)}
.tool-card-rating{display:flex;align-items:center;gap:.3rem}
.tool-card-stars{font-size:.8rem;color:var(--star-filled)}
.tool-card-rating-num{font-family:var(--font-mono);font-size:.75rem;color:var(--ink-tertiary)}
.pricing-badge{font-family:var(--font-mono);font-size:.65rem;font-weight:600;padding:.2rem .6rem;
  border-radius:4px;text-transform:uppercase;letter-spacing:.05em}
.pricing-badge.gratuit{background:rgba(5,150,105,.1);color:var(--prix-gratuit)}
.pricing-badge.freemium{background:rgba(217,119,6,.1);color:var(--prix-freemium)}
.pricing-badge.payant{background:rgba(220,38,38,.1);color:var(--prix-payant)}
.pricing-badge.essai{background:rgba(124,58,237,.1);color:var(--prix-essai)}
.tool-card-compare{position:absolute;top:.8rem;right:2.8rem;background:var(--bg-elevated);border:1px solid var(--border-light);
  border-radius:6px;padding:.3rem .5rem;font-family:var(--font-mono);font-size:.6rem;color:var(--ink-tertiary);
  cursor:pointer;transition:all .2s;opacity:0}
.tool-card:hover .tool-card-compare{opacity:1}
.tool-card-compare:hover{background:var(--gold);color:var(--bg-dark);border-color:var(--gold)}
.tool-card-compare.added{background:var(--gold);color:var(--bg-dark);border-color:var(--gold);opacity:1}

/* List view card */
.tools-grid.list-view .tool-card{flex-direction:row;align-items:center;padding:1rem 1.4rem;gap:1.5rem}
.tools-grid.list-view .tool-card-header{margin-bottom:0;min-width:200px}
.tools-grid.list-view .tool-card-tagline{margin-bottom:0;-webkit-line-clamp:1;flex:1}
.tools-grid.list-view .tool-card-tags{display:none}
.tools-grid.list-view .tool-card-footer{border-top:none;padding-top:0;min-width:180px;justify-content:flex-end;gap:1rem}

.load-more{display:block;margin:2rem auto 0;font-family:var(--font-ui);font-size:.85rem;font-weight:600;
  padding:.7rem 2rem;border:2px solid var(--border-medium);border-radius:var(--radius-md);
  background:transparent;color:var(--ink);cursor:pointer;transition:all .3s}
.load-more:hover{border-color:var(--gold);color:var(--gold)}
.no-results{text-align:center;padding:3rem;color:var(--ink-tertiary);font-family:var(--font-ui)}
.no-results-icon{font-size:3rem;margin-bottom:1rem}

/* ============================================================
   TOOL DETAIL MODAL
   ============================================================ */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(10,10,20,.6);backdrop-filter:blur(8px);
  display:none;align-items:flex-start;justify-content:center;padding:2rem 4vw;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal{background:var(--bg-page);border-radius:var(--radius-lg);max-width:960px;width:100%;
  position:relative;box-shadow:var(--shadow-lg);animation:modalIn .4s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg-elevated);border:1px solid var(--border-light);
  border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1.1rem;color:var(--ink-tertiary);transition:all .2s;z-index:1}
.modal-close:hover{background:var(--ink);color:var(--ink-inverse)}
.modal-breadcrumb{padding:1.2rem 2rem .5rem;font-family:var(--font-mono);font-size:.7rem;color:var(--ink-tertiary)}
.modal-breadcrumb a{color:var(--gold);text-decoration:none}
.modal-breadcrumb a:hover{text-decoration:underline}
.modal-body{display:grid;grid-template-columns:1fr 280px;gap:2rem;padding:1rem 2rem 2rem}
@media(max-width:768px){.modal-body{grid-template-columns:1fr;padding:1rem}}

/* Modal main content */
.modal-main h2{font-size:2rem;margin-bottom:.3rem}
.modal-main .modal-company{font-family:var(--font-mono);font-size:.8rem;color:var(--ink-tertiary);margin-bottom:1.2rem}
.modal-main .modal-desc{font-size:.95rem;line-height:1.8;margin-bottom:1.5rem}
.modal-main .modal-desc::first-letter{font-family:var(--font-display);font-size:3rem;font-weight:700;
  float:left;line-height:1;margin-right:.5rem;margin-top:.1rem;color:var(--gold)}
.modal-section-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;
  margin:1.5rem 0 .8rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-light)}
.modal-features{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.modal-features li{font-size:.85rem;padding:.3rem 0 .3rem 1.3rem;position:relative}
.modal-features li::before{content:'✦';position:absolute;left:0;color:var(--gold);font-size:.7rem}
.modal-usecases{list-style:none}
.modal-usecases li{font-size:.85rem;padding:.4rem 0 .4rem 1.5rem;position:relative;color:var(--ink-secondary)}
.modal-usecases li::before{content:'→';position:absolute;left:0;color:var(--gold)}
.modal-proscons{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.modal-pros li,.modal-cons li{font-size:.82rem;padding:.3rem 0;list-style:none;padding-left:1.3rem;position:relative}
.modal-pros li::before{content:'+';position:absolute;left:0;color:var(--prix-gratuit);font-weight:700;font-family:var(--font-mono)}
.modal-cons li::before{content:'−';position:absolute;left:0;color:var(--prix-payant);font-weight:700;font-family:var(--font-mono)}
.modal-pros h3,.modal-cons h3{font-family:var(--font-ui);font-size:.8rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}
.modal-pros h3{color:var(--prix-gratuit)}
.modal-cons h3{color:var(--prix-payant)}

/* Pricing table in modal */
.modal-pricing-note{font-family:var(--font-mono);font-size:.8rem;color:var(--ink-secondary);
  background:var(--bg-elevated);padding:.8rem 1rem;border-radius:var(--radius-sm);border-left:3px solid var(--gold)}

/* See also */
.modal-seealso{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.5rem}
.modal-seealso-chip{font-family:var(--font-ui);font-size:.8rem;padding:.4rem .8rem;border-radius:20px;
  border:1px solid var(--border-light);cursor:pointer;transition:all .2s;background:var(--bg-surface);color:var(--ink);text-decoration:none}
.modal-seealso-chip:hover{border-color:var(--gold);background:var(--gold-glow)}

/* Infobox */
.infobox{background:var(--bg-infobox);border:1px solid var(--border-medium);border-radius:var(--radius-md);
  padding:1.5rem;position:sticky;top:80px}
.infobox-icon{font-size:3rem;text-align:center;margin-bottom:.8rem}
.infobox-title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;text-align:center;margin-bottom:1rem;
  padding-bottom:.8rem;border-bottom:1px solid var(--border-light)}
.infobox-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;
  border-bottom:1px solid rgba(228,218,200,.5);font-size:.82rem}
.infobox-row:last-child{border-bottom:none}
.infobox-key{font-family:var(--font-ui);font-weight:600;color:var(--ink-secondary);font-size:.75rem}
.infobox-val{font-family:var(--font-mono);font-size:.8rem;text-align:right}
.infobox-platforms{display:flex;gap:.3rem;justify-content:flex-end;flex-wrap:wrap}
.infobox-platform{font-size:.6rem;padding:.15rem .4rem;background:var(--bg-surface);
  border:1px solid var(--border-light);border-radius:3px;font-family:var(--font-mono)}
.infobox-cta{display:block;width:100%;margin-top:1.2rem;padding:.7rem;text-align:center;
  background:var(--gold);color:var(--bg-dark);font-family:var(--font-ui);font-weight:700;
  font-size:.85rem;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .3s;text-decoration:none}
.infobox-cta:hover{background:var(--gold-light);color:var(--bg-dark)}
.infobox-compare-btn{display:block;width:100%;margin-top:.5rem;padding:.6rem;text-align:center;
  background:transparent;color:var(--ink);font-family:var(--font-ui);font-weight:600;font-size:.8rem;
  border-radius:var(--radius-sm);border:1px solid var(--border-medium);cursor:pointer;transition:all .2s}
.infobox-compare-btn:hover{border-color:var(--gold);color:var(--gold)}

/* Verdict */
.modal-verdict{background:var(--bg-elevated);border-left:3px solid var(--gold);padding:1rem 1.2rem;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:1rem;font-style:italic;
  font-family:var(--font-body);color:var(--ink-secondary);font-size:.9rem}

/* ============================================================
   COMPARATOR
   ============================================================ */
/* Floating tray */
.compare-tray{position:fixed;bottom:0;left:0;right:0;z-index:1500;
  background:var(--bg-dark);border-top:2px solid var(--gold);
  padding:.8rem 4vw;display:none;align-items:center;justify-content:space-between;gap:1rem;
  box-shadow:0 -4px 20px rgba(0,0,0,.2)}
.compare-tray.visible{display:flex}
.compare-tray-items{display:flex;gap:.6rem;flex:1;flex-wrap:wrap}
.compare-tray-item{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .7rem;
  background:var(--bg-dark-surface);border:1px solid rgba(244,241,235,.1);border-radius:20px;
  font-family:var(--font-ui);font-size:.8rem;color:var(--ink-inverse)}
.compare-tray-item .remove{cursor:pointer;color:rgba(244,241,235,.4);font-weight:700;margin-left:.2rem}
.compare-tray-item .remove:hover{color:var(--gold)}
.compare-tray-btn{background:var(--gold);color:var(--bg-dark);font-family:var(--font-ui);font-weight:700;
  font-size:.85rem;padding:.6rem 1.5rem;border-radius:var(--radius-sm);border:none;cursor:pointer;
  transition:all .3s;white-space:nowrap}
.compare-tray-btn:hover{background:var(--gold-light)}
.compare-tray-label{font-family:var(--font-mono);font-size:.7rem;color:rgba(244,241,235,.4);white-space:nowrap}

/* Comparator view */
.comparator-overlay{position:fixed;inset:0;z-index:2000;background:var(--bg-page);display:none;overflow-y:auto}
.comparator-overlay.open{display:block}
.comparator-header{padding:1.5rem 4vw;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border-light)}
.comparator-header h2{font-size:1.5rem}
.comparator-close{background:none;border:1px solid var(--border-medium);border-radius:var(--radius-sm);
  padding:.4rem .8rem;cursor:pointer;font-family:var(--font-ui);font-size:.8rem;color:var(--ink-secondary);transition:all .2s}
.comparator-close:hover{border-color:var(--ink);color:var(--ink)}
.comparator-table{width:100%;border-collapse:collapse;margin:0 auto;max-width:1000px}
.comparator-table th,.comparator-table td{padding:1rem 1.5rem;text-align:center;
  border-bottom:1px solid var(--border-light);font-size:.85rem}
.comparator-table th:first-child,.comparator-table td:first-child{text-align:left;font-weight:600;
  font-family:var(--font-ui);font-size:.8rem;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.1em}
.comparator-table thead th{padding:2rem 1.5rem;vertical-align:bottom;border-bottom:2px solid var(--border-medium)}
.comparator-tool-header{display:flex;flex-direction:column;align-items:center;gap:.3rem}
.comparator-tool-icon{font-size:2rem}
.comparator-tool-name{font-family:var(--font-display);font-weight:700;font-size:1.1rem}
.comp-check{color:var(--prix-gratuit);font-weight:700;font-size:1.1rem}
.comp-cross{color:var(--prix-payant);font-weight:700;font-size:1.1rem}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay{position:fixed;inset:0;z-index:3000;background:rgba(10,10,20,.7);backdrop-filter:blur(12px);
  display:none;align-items:flex-start;justify-content:center;padding:15vh 4vw}
.search-overlay.open{display:flex}
.search-modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:580px;
  box-shadow:var(--shadow-lg);overflow:hidden;animation:modalIn .3s ease}
.search-modal-input{width:100%;padding:1.2rem 1.5rem 1.2rem 3rem;border:none;border-bottom:1px solid var(--border-light);
  font-family:var(--font-ui);font-size:1.05rem;outline:none;background:transparent;color:var(--ink)}
.search-modal-input::placeholder{color:var(--ink-tertiary)}
.search-modal-icon{position:absolute;left:1.1rem;top:1.3rem;width:18px;height:18px;
  stroke:var(--ink-tertiary);fill:none;stroke-width:2}
.search-results{max-height:400px;overflow-y:auto}
.search-result-item{display:flex;align-items:center;gap:1rem;padding:.8rem 1.5rem;cursor:pointer;
  transition:background .15s;border-bottom:1px solid rgba(0,0,0,.03)}
.search-result-item:hover,.search-result-item.active{background:var(--gold-glow)}
.search-result-icon{font-size:1.5rem}
.search-result-name{font-family:var(--font-display);font-weight:700;font-size:.95rem}
.search-result-cat{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-tertiary)}
.search-result-meta{margin-left:auto;text-align:right}
.search-empty{padding:2rem;text-align:center;color:var(--ink-tertiary);font-family:var(--font-ui);font-size:.9rem}
.search-footer{padding:.6rem 1.5rem;background:var(--bg-elevated);font-family:var(--font-mono);
  font-size:.65rem;color:var(--ink-tertiary);display:flex;justify-content:space-between}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter{text-align:center;padding:4rem 4vw;background:linear-gradient(135deg,#1a1a2e,#2a1a1e)}
.newsletter h2{color:var(--ink-inverse);margin-bottom:.5rem}
.newsletter-desc{color:rgba(244,241,235,.7);font-size:1rem;margin-bottom:2rem;max-width:500px;margin-inline:auto}
.newsletter-form{display:flex;gap:.6rem;max-width:460px;margin:0 auto}
.newsletter-input{flex:1;padding:.8rem 1.2rem;border:2px solid rgba(244,241,235,.1);border-radius:var(--radius-sm);
  background:rgba(244,241,235,.05);color:var(--ink-inverse);font-family:var(--font-ui);font-size:.9rem;outline:none;transition:border-color .3s}
.newsletter-input:focus{border-color:var(--gold)}
.newsletter-input::placeholder{color:rgba(244,241,235,.5)}
.newsletter-btn{padding:.8rem 1.5rem;background:var(--gold);color:var(--bg-dark);font-family:var(--font-ui);
  font-weight:700;font-size:.85rem;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .3s;white-space:nowrap}
.newsletter-btn:hover{background:var(--gold-light)}
.newsletter-note{font-family:var(--font-mono);font-size:.7rem;color:rgba(244,241,235,.6);margin-top:1rem}
.newsletter-success{color:var(--prix-gratuit);font-family:var(--font-ui);font-size:.9rem;display:none}
@media(max-width:500px){.newsletter-form{flex-direction:column}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--bg-dark);padding:3rem 4vw 2rem;color:rgba(244,241,235,.7)}
.footer-grid{display:grid;grid-template-columns:2fr 2fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--ink-inverse);margin-bottom:.5rem}
.footer-brand-desc{font-size:.82rem;line-height:1.6;color:rgba(244,241,235,.75)}
.footer-col h3{font-family:var(--font-ui);font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.2em;color:rgba(244,241,235,.75);margin-bottom:1rem}
#footerCategories{columns:2;column-gap:1.2rem}
#footerCategories a{break-inside:avoid}
.footer-col a{display:block;padding:.25rem 0;font-family:var(--font-ui);font-size:.82rem;
  color:rgba(244,241,235,.75);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{text-align:center;padding-top:1.5rem;border-top:1px solid rgba(244,241,235,.06);
  font-family:var(--font-mono);font-size:.7rem;color:rgba(244,241,235,.7);letter-spacing:.05em}

/* ============================================================
   LEGAL/INFO PAGES MODAL
   ============================================================ */
.page-overlay{position:fixed;inset:0;z-index:2500;background:rgba(10,10,20,.6);backdrop-filter:blur(8px);
  display:none;align-items:flex-start;justify-content:center;padding:2rem 4vw;overflow-y:auto}
.page-overlay.open{display:flex}
.page-modal{background:var(--bg-page);border-radius:var(--radius-lg);max-width:780px;width:100%;
  position:relative;box-shadow:var(--shadow-lg);animation:modalIn .4s ease;padding:2.5rem 3rem 3rem}
@media(max-width:600px){.page-modal{padding:1.5rem 1.2rem 2rem}}
.page-modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg-elevated);border:1px solid var(--border-light);
  border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1.1rem;color:var(--ink-tertiary);transition:all .2s;z-index:1}
.page-modal-close:hover{background:var(--ink);color:var(--ink-inverse)}
.page-modal-icon{font-size:2.5rem;margin-bottom:.8rem}
.page-modal h2{font-family:var(--font-display);font-size:1.8rem;font-weight:900;margin-bottom:.3rem}
.page-modal .page-subtitle{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-tertiary);
  letter-spacing:.15em;text-transform:uppercase;margin-bottom:2rem}
.page-modal h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin:1.8rem 0 .6rem;
  padding-bottom:.4rem;border-bottom:1px solid var(--border-light)}
.page-modal p,.page-modal li{font-size:.9rem;line-height:1.8;color:var(--ink-secondary);margin-bottom:.8rem}
.page-modal ul{list-style:none;padding:0}
.page-modal ul li{padding-left:1.3rem;position:relative}
.page-modal ul li::before{content:'✦';position:absolute;left:0;color:var(--gold);font-size:.7rem}
.page-modal a{color:var(--gold)}
.page-modal a:hover{text-decoration:underline}
.page-modal .info-card{background:var(--bg-infobox);border:1px solid var(--border-medium);
  border-radius:var(--radius-md);padding:1.2rem 1.5rem;margin:1rem 0}
.page-modal .info-card-label{font-family:var(--font-mono);font-size:.65rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.15em;color:var(--gold);margin-bottom:.5rem}
.page-modal .info-card p{margin-bottom:.3rem}
/* Contact form */
.contact-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}
.contact-form label{font-family:var(--font-ui);font-size:.8rem;font-weight:600;color:var(--ink-secondary)}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:.7rem 1rem;
  border:1px solid var(--border-light);border-radius:var(--radius-sm);font-family:var(--font-ui);
  font-size:.9rem;outline:none;background:var(--bg-surface);color:var(--ink);transition:border-color .3s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--gold)}
.contact-form textarea{min-height:120px;resize:vertical}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.contact-form .form-row{grid-template-columns:1fr}}
.contact-form button{align-self:flex-start;padding:.7rem 2rem;background:var(--gold);color:var(--bg-dark);
  font-family:var(--font-ui);font-weight:700;font-size:.85rem;border:none;border-radius:var(--radius-sm);
  cursor:pointer;transition:all .3s}
.contact-form button:hover{background:var(--gold-light)}
.contact-form .form-success{color:var(--prix-gratuit);font-family:var(--font-ui);font-size:.9rem;display:none}
/* Submit tool form extras */
.submit-tool-form .form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
@media(max-width:600px){.submit-tool-form .form-row-3{grid-template-columns:1fr}}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(30px);transition:all .7s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   TENDANCES IA
   ============================================================ */
.trends-tabs{display:flex;gap:.5rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}
.trends-tab{font-family:var(--font-ui);font-size:.8rem;font-weight:600;padding:.5rem 1.2rem;border-radius:20px;
  border:1px solid var(--border-light);background:transparent;color:var(--ink-secondary);cursor:pointer;transition:all .3s}
.trends-tab.active{background:var(--gold);color:#1a1a2e;border-color:var(--gold)}
.trends-tab:hover:not(.active){border-color:var(--gold);color:var(--ink)}
.trends-list{max-width:800px;margin:0 auto}
.trends-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;border-bottom:1px solid var(--border-light);
  cursor:pointer;transition:all .2s;text-decoration:none;color:var(--ink)}
.trends-item:hover{background:var(--bg-surface);border-radius:var(--radius-sm)}
.trends-rank{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:var(--gold);min-width:28px;text-align:center}
.trends-rank.top3{font-size:1.3rem}
.trends-icon{font-size:1.5rem}
.trends-info{flex:1}
.trends-name{font-family:var(--font-display);font-weight:700;font-size:.95rem}
.trends-tagline{font-size:.72rem;color:var(--ink-secondary);margin-top:.15rem}
.trends-meta{display:flex;align-items:center;gap:.8rem;flex-shrink:0}
.trends-rating{font-family:var(--font-mono);font-size:.75rem;color:var(--star-filled)}
.trends-pop{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-tertiary);background:var(--bg-surface);
  padding:.2rem .5rem;border-radius:10px}
.trends-badge{font-family:var(--font-mono);font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  padding:.2rem .5rem;border-radius:4px}
.trends-badge.new{color:#10b981;background:rgba(16,185,129,.12)}
.trends-badge.rising{color:#f59e0b;background:rgba(245,158,11,.12)}
.trends-badge.hot{color:#ef4444;background:rgba(239,68,68,.12)}

/* ============================================================
   VERSUS
   ============================================================ */
.versus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:1000px;margin:0 auto}
@media(max-width:900px){.versus-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.versus-grid{grid-template-columns:1fr}}
.versus-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);
  padding:1.2rem;text-align:center;cursor:pointer;transition:all .3s;text-decoration:none;color:var(--ink);display:block}
.versus-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.versus-icons{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.6rem;font-size:1.4rem}
.versus-vs{font-family:var(--font-display);font-weight:800;font-size:.75rem;color:var(--gold);
  background:var(--gold-glow);padding:.15rem .4rem;border-radius:4px}
.versus-names{font-family:var(--font-display);font-weight:700;font-size:.82rem;margin-bottom:.3rem}
.versus-cat{font-family:var(--font-mono);font-size:.6rem;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.08em}
.btn-load-more{font-family:var(--font-ui);font-size:.85rem;font-weight:600;padding:.7rem 2rem;border-radius:25px;
  border:1px solid var(--gold);background:transparent;color:var(--gold);cursor:pointer;transition:all .3s}
.btn-load-more:hover{background:var(--gold);color:#1a1a2e;transform:translateY(-1px);box-shadow:0 4px 15px rgba(201,168,76,.3)}

/* ============================================================
   DARK MODE
   ============================================================ */
[data-theme="dark"]{
  --bg-page:#141425;--bg-surface:#1e1e38;--bg-elevated:#252547;
  --bg-infobox:#1e1e38;
  --ink:#e8e6e1;--ink-secondary:#b0aec0;--ink-tertiary:#8886a0;
  --border-light:rgba(255,255,255,.08);--border-medium:rgba(255,255,255,.12);
  --shadow-sm:0 2px 8px rgba(0,0,0,.3);--shadow-md:0 4px 16px rgba(0,0,0,.4);
}
[data-theme="dark"] body{background:var(--bg-page);color:var(--ink)}
[data-theme="dark"] .tool-card{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .tool-card:hover{border-color:var(--gold)}
[data-theme="dark"] .section-title,[data-theme="dark"] h2,[data-theme="dark"] h3{color:var(--ink)}
[data-theme="dark"] .filter-panel{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .filter-option{color:var(--ink-secondary)}
[data-theme="dark"] .page-modal{background:var(--bg-surface);color:var(--ink)}
[data-theme="dark"] .modal{background:var(--bg-surface);color:var(--ink)}
[data-theme="dark"] .infobox{background:var(--bg-elevated);border-color:var(--border-light)}
[data-theme="dark"] .contact-form input,[data-theme="dark"] .contact-form textarea,[data-theme="dark"] .contact-form select{background:var(--bg-elevated);border-color:var(--border-light);color:var(--ink)}
[data-theme="dark"] .search-modal-content{background:var(--bg-surface)}
[data-theme="dark"] .search-modal-content input{background:var(--bg-elevated);color:var(--ink)}
[data-theme="dark"] .toc-item{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .featured-card{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .blog-card{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .versus-card{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .trends-card{background:var(--bg-surface);border-color:var(--border-light)}
[data-theme="dark"] .info-card{background:var(--bg-elevated);border-color:var(--border-light)}
[data-theme="dark"] .footer{background:var(--bg-dark)}

.theme-toggle{background:none;border:1px solid rgba(244,241,235,.2);border-radius:20px;padding:.35rem .7rem;
  cursor:pointer;font-size:.8rem;color:rgba(244,241,235,.5);font-family:var(--font-ui);transition:all .3s;display:flex;align-items:center;gap:.3rem}
.theme-toggle:hover{border-color:var(--gold);color:var(--gold)}
[data-theme="dark"] .nav{background:rgba(20,20,37,.95)}

/* ============================================================
   FAVORITES
   ============================================================ */
.tool-card-fav{position:absolute;top:.8rem;right:.8rem;background:var(--bg-elevated);border:1px solid var(--border-light);
  border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:.85rem;opacity:0;transition:all .2s;z-index:2;padding:0;line-height:1}
.tool-card:hover .tool-card-fav{opacity:1}
.tool-card-fav:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3)}
.tool-card-fav.active{opacity:1;color:#ef4444;background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3)}
.fav-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-light)}
.fav-section-title{font-family:var(--font-display);font-size:1.1rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.fav-empty{color:var(--ink-tertiary);font-size:.85rem;font-family:var(--font-ui)}
.nav-fav-count{background:#ef4444;color:white;font-size:.6rem;font-weight:700;padding:.1rem .35rem;border-radius:10px;margin-left:.2rem}

/* ============================================================
   SHARE BUTTONS
   ============================================================ */
.share-buttons{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.share-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:20px;font-size:.75rem;
  font-family:var(--font-ui);font-weight:500;border:1px solid var(--border-light);background:transparent;
  color:var(--ink-secondary);cursor:pointer;transition:all .2s;text-decoration:none}
.share-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-glow)}
.share-btn-copied{background:var(--gold)!important;color:var(--bg-dark)!important;border-color:var(--gold)!important}

/* ============================================================
   SKELETON LOADING
   ============================================================ */
.skeleton-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);
  padding:1.5rem;height:220px;position:relative;overflow:hidden}
.skeleton-card::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(201,168,76,.06),transparent);
  animation:shimmer 1.5s infinite}
@keyframes shimmer{to{left:100%}}
.skeleton-line{height:12px;background:var(--bg-elevated);border-radius:6px;margin-bottom:.8rem}
.skeleton-line.w60{width:60%}.skeleton-line.w80{width:80%}.skeleton-line.w40{width:40%}
.skeleton-icon{width:48px;height:48px;border-radius:12px;background:var(--bg-elevated);margin-bottom:1rem}

/* ============================================================
   TOAST NOTIFICATIONS
   ============================================================ */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(100px);
  background:var(--bg-dark);color:var(--ink-inverse);padding:.7rem 1.5rem;border-radius:25px;
  font-family:var(--font-ui);font-size:.85rem;font-weight:500;z-index:10000;
  box-shadow:0 8px 30px rgba(0,0,0,.3);transition:transform .4s cubic-bezier(.22,1,.36,1);
  display:flex;align-items:center;gap:.5rem;pointer-events:none}
.toast.visible{transform:translateX(-50%) translateY(0)}
.toast-icon{font-size:1.1rem}
[data-theme="dark"] .toast{background:var(--bg-elevated);border:1px solid var(--border-light)}

/* ============================================================
   CHATBOT WIDGET
   ============================================================ */

/* FAB (Floating Action Button) */
.chatbot-fab{position:fixed;bottom:1.5rem;right:1.5rem;width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#c9a84c,#b8943f);border:none;cursor:pointer;z-index:100000;
  box-shadow:0 4px 20px rgba(201,168,76,.4);transition:all .3s cubic-bezier(.22,1,.36,1);
  display:flex;align-items:center;justify-content:center;color:#0e0e1a;font-size:1.4rem}
.chatbot-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(201,168,76,.55)}
.chatbot-fab .chatbot-fab-icon{transition:transform .3s ease}
.chatbot-fab.open .chatbot-fab-icon{transform:rotate(90deg)}
/* FAB lifts when compare-tray is visible */
.compare-tray.visible ~ .chatbot-fab,.compare-tray.visible ~ .chatbot-panel{bottom:5.5rem}

/* Panel */
.chatbot-panel{position:fixed;bottom:6rem;right:1.5rem;width:380px;max-height:520px;
  background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);z-index:100000;display:none;flex-direction:column;overflow:hidden;
  font-family:var(--font-ui)}
.chatbot-panel.open{display:flex;animation:chatbotSlideUp .3s cubic-bezier(.22,1,.36,1) forwards}

@keyframes chatbotSlideUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* Panel Header */
.chatbot-header{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;
  background:var(--bg-dark);border-bottom:1px solid var(--border-light);flex-shrink:0}
.chatbot-header-title{font-family:var(--font-display);font-weight:700;font-size:.9rem;
  color:var(--gold);display:flex;align-items:center;gap:.4rem}
.chatbot-header-actions{display:flex;gap:.3rem}
.chatbot-header-actions button{background:none;border:none;color:var(--ink-tertiary);cursor:pointer;
  padding:.3rem;border-radius:4px;font-size:.85rem;transition:color .2s}
.chatbot-header-actions button:hover{color:var(--gold)}

/* Messages area */
.chatbot-messages{flex:1;overflow-y:auto;padding:.8rem;display:flex;flex-direction:column;gap:.6rem;
  max-height:340px;scroll-behavior:smooth}

/* Message bubbles */
.chatbot-msg{max-width:88%;padding:.6rem .9rem;border-radius:12px;font-size:.85rem;line-height:1.5;
  word-wrap:break-word}
.chatbot-msg.bot{align-self:flex-start;background:var(--bg-elevated);border:1px solid var(--border-light);
  border-top-left-radius:4px;color:var(--ink)}
.chatbot-msg.user{align-self:flex-end;background:linear-gradient(135deg,#c9a84c,#b8943f);
  color:#0e0e1a;font-weight:500;border-bottom-right-radius:4px}

/* Tool cards in messages */
.chatbot-tools{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}
.chatbot-tool-card{display:flex;align-items:center;gap:.5rem;padding:.5rem .7rem;
  background:var(--bg-surface);border:1px solid var(--border-light);border-radius:8px;
  cursor:pointer;transition:all .2s;text-decoration:none}
.chatbot-tool-card:hover{border-color:var(--gold);box-shadow:0 2px 8px rgba(201,168,76,.15);
  transform:translateX(3px)}
.chatbot-tool-card-icon{font-size:1.3rem;flex-shrink:0;width:28px;text-align:center}
.chatbot-tool-card-info{flex:1;min-width:0}
.chatbot-tool-card-name{font-weight:700;font-size:.8rem;color:var(--ink);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.chatbot-tool-card-tagline{font-size:.7rem;color:var(--ink-secondary);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.chatbot-tool-card-rating{font-size:.65rem;color:var(--gold);flex-shrink:0;font-family:var(--font-mono)}

/* Thinking animation */
.chatbot-thinking{display:flex;align-items:center;gap:.3rem;padding:.6rem .9rem}
.chatbot-thinking span{width:6px;height:6px;background:var(--gold);border-radius:50%;
  animation:chatbotBounce .6s infinite alternate}
.chatbot-thinking span:nth-child(2){animation-delay:.2s}
.chatbot-thinking span:nth-child(3){animation-delay:.4s}
@keyframes chatbotBounce{to{opacity:.3;transform:translateY(-4px)}}

/* Mode toggle */
.chatbot-mode{display:flex;padding:.4rem .8rem;gap:.3rem;border-top:1px solid var(--border-light);
  background:var(--bg-elevated);flex-shrink:0}
.chatbot-mode button{flex:1;padding:.35rem .5rem;border:1px solid var(--border-light);border-radius:6px;
  background:transparent;color:var(--ink-secondary);font-size:.72rem;font-family:var(--font-ui);
  cursor:pointer;transition:all .2s;font-weight:500}
.chatbot-mode button.active{background:var(--gold);color:#0e0e1a;border-color:var(--gold);font-weight:700}
.chatbot-mode button:hover:not(.active){border-color:var(--gold);color:var(--gold)}

/* Input area */
.chatbot-input{display:flex;gap:.4rem;padding:.6rem .8rem;border-top:1px solid var(--border-light);
  background:var(--bg-surface);flex-shrink:0}
.chatbot-input input{flex:1;border:1px solid var(--border-light);border-radius:8px;padding:.5rem .7rem;
  font-size:.82rem;font-family:var(--font-ui);background:var(--bg-elevated);color:var(--ink);
  outline:none;transition:border-color .2s}
.chatbot-input input:focus{border-color:var(--gold)}
.chatbot-input input::placeholder{color:var(--ink-tertiary)}
.chatbot-input button{background:var(--gold);color:#0e0e1a;border:none;border-radius:8px;
  padding:.5rem .7rem;cursor:pointer;font-size:.85rem;transition:opacity .2s;font-weight:700}
.chatbot-input button:hover{opacity:.85}
.chatbot-input button:disabled{opacity:.4;cursor:not-allowed}

/* Dark mode */
[data-theme="dark"] .chatbot-panel{box-shadow:0 8px 40px rgba(0,0,0,.5)}
[data-theme="dark"] .chatbot-tool-card:hover{box-shadow:0 2px 8px rgba(201,168,76,.2)}

/* Responsive */
@media(max-width:500px){
  .chatbot-panel{width:calc(100vw - 1.5rem);right:.75rem;bottom:5rem;max-height:65vh}
  .chatbot-fab{bottom:1rem;right:1rem;width:50px;height:50px;font-size:1.2rem}
  .compare-tray.visible ~ .chatbot-fab,.compare-tray.visible ~ .chatbot-panel{bottom:5rem}
}

/* ============================================================
   BLOG / GUIDES
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:1000px;margin:0 auto}
@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.blog-grid{grid-template-columns:1fr}}
.blog-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);
  padding:1.5rem;cursor:pointer;transition:all .3s;text-decoration:none;color:var(--ink);display:block}
.blog-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.blog-card-emoji{font-size:2rem;margin-bottom:.6rem}
.blog-card-tag{font-family:var(--font-mono);font-size:.6rem;color:var(--gold);text-transform:uppercase;
  letter-spacing:.1em;margin-bottom:.4rem}
.blog-card-title{font-family:var(--font-display);font-weight:700;font-size:1rem;line-height:1.4;margin-bottom:.4rem}
.blog-card-desc{font-size:.78rem;color:var(--ink-secondary);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-meta{display:flex;align-items:center;gap:.8rem;margin-top:.8rem;font-family:var(--font-mono);font-size:.6rem;color:var(--ink-tertiary)}
.blog-coming{text-align:center;padding:2rem;font-family:var(--font-ui);color:var(--ink-tertiary);font-size:.85rem}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */

/* Focus-visible — keyboard navigation indicator */
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,
textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
:focus:not(:focus-visible){outline:none}

/* Reduced motion — vestibular disorder safety */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;animation-iteration-count:1!important;
    transition-duration:0.01ms!important;scroll-behavior:auto!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* Skip to content link — accessible navigation */
.skip-to-content{position:absolute;top:-50px;left:0;background:var(--gold);color:#1a1a2e;padding:.6rem 1.2rem;z-index:10000;font-weight:700;text-decoration:none;border-radius:0 0 8px 0;transition:top .15s}
.skip-to-content:focus{top:0}

/* Minimum touch targets on mobile — 44x44px */
@media(max-width:768px){
  .lang-btn{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
  .tool-card-fav{width:44px;height:44px}
  .theme-toggle{min-height:44px;min-width:44px;justify-content:center}
  .nav-search-btn{min-height:44px}
  .chatbot-header-actions button{min-width:44px;min-height:44px}
  .filter-star{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
}