*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden}
:root{
  --bg:#ffffff;--bg2:#f8f9ff;--surface:#ffffff;--surface-hover:#f0edff;
  --border:#e4e4f0;--border2:rgba(124,58,237,0.4);
  --text:#0f172a;--text2:#64748b;--accent:#7c3aed;--accent2:#6d28d9;--cyan:#0891b2;
  --glow:rgba(124,58,237,0.12);--font:'Space Grotesk',sans-serif;--font2:'Inter',sans-serif;--font-mono:'JetBrains Mono',monospace;
}
[data-theme="dark"]{
  --bg:#0a0a0a;--bg2:#06061a;--surface:rgba(255,255,255,0.04);--surface-hover:rgba(255,255,255,0.07);
  --border:rgba(255,255,255,0.08);--border2:rgba(124,58,237,0.2);
  --text:#f0f0f0;--text2:#999;--accent:#7c3aed;--accent2:#a78bfa;--cyan:#22d3ee;
  --glow:rgba(124,58,237,0.25);
}
body{background:var(--bg);color:var(--text);font-family:var(--font2);min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}
body::before{content:'';position:fixed;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 10%,rgba(124,58,237,0.12) 0%,transparent 60%);
  pointer-events:none;z-index:0;opacity:0}
[data-theme="dark"] body::before{opacity:1}

/* Background symbols */
.bg-symbols{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.sym{position:absolute;font-size:18px;color:rgba(124,58,237,0.10);animation:float linear infinite}
@keyframes float{0%{transform:translateY(100vh) rotate(0deg);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-100px) rotate(360deg);opacity:0}}

/* Header */
header{position:sticky;top:0;z-index:100;padding:0 40px;
  background:rgba(255,255,255,0.9);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center;gap:32px}
[data-theme="dark"] header{background:rgba(10,10,10,0.85)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#7c3aed,#a78bfa);
  border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.logo-text{font-family:var(--font);font-weight:800;font-size:18px;color:var(--text)}
[data-theme="dark"] .logo-text{background:linear-gradient(135deg,#f0f0f0,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
nav{display:flex;gap:4px;flex:1;overflow:hidden}
nav a{color:var(--text2);text-decoration:none;font-size:13px;font-weight:500;padding:6px 12px;
  border-radius:8px;transition:.2s;white-space:nowrap}
nav a:hover,nav a.active{color:var(--text);background:var(--surface)}
nav a.active{color:var(--accent2)}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.icon-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface);
  color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:.2s}
.icon-btn:hover{color:var(--text);background:var(--surface-hover)}
.lang-btn{padding:6px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);
  color:var(--text2);cursor:pointer;font-size:13px;font-weight:600;transition:.2s}
.mob-menu-btn{display:none;width:36px;height:36px;border-radius:10px;
  border:1px solid var(--border);background:var(--surface);
  color:var(--text2);cursor:pointer;align-items:center;justify-content:center;font-size:18px}
.mob-nav{display:none;position:absolute;top:100%;left:0;right:0;z-index:99;
  background:var(--bg);border-bottom:1px solid var(--border);padding:16px;
  flex-direction:column;gap:4px}
.mob-nav.open{display:flex}
.mob-nav a{color:var(--text2);text-decoration:none;padding:10px 16px;border-radius:10px;font-size:15px;transition:.2s}
.mob-nav a:hover{background:var(--surface);color:var(--text)}

/* Search results dropdown */
.search-results{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:300;
  background:var(--bg);
  border:1.5px solid rgba(124,58,237,0.25);
  border-radius:20px;
  max-height:400px;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.06);
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
  animation:srFade .15s ease}
@keyframes srFade{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
[data-theme="dark"] .search-results{
  background:#0d0d1a;
  border-color:rgba(124,58,237,0.3);
  box-shadow:0 24px 64px rgba(0,0,0,0.6),0 4px 16px rgba(0,0,0,0.3)}
.search-result-item{
  display:block;padding:14px 20px;cursor:pointer;
  text-decoration:none;color:inherit;text-align:left;
  border-bottom:1px solid var(--border);
  transition:background .12s}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover,.search-result-item.sr-focused{background:var(--surface-hover)}
[data-theme="dark"] .search-result-item:hover,
[data-theme="dark"] .search-result-item.sr-focused{background:rgba(124,58,237,0.08)}
.sri-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:3px}
.sri-title mark{background:rgba(124,58,237,0.15);color:var(--accent);
  border-radius:3px;padding:0 2px;font-weight:700;font-style:normal}
[data-theme="dark"] .sri-title mark{background:rgba(124,58,237,0.25);color:var(--accent2)}
.sri-cat{font-size:12px;color:var(--text2);line-height:1.3}
.sri-no-results{padding:20px;text-align:center;color:var(--text2);font-size:14px}
.sri-footer{padding:10px 20px;text-align:center;font-size:12px;color:var(--text2);
  border-top:1px solid var(--border);background:var(--bg2)}
/* Mobile search dropdown */
@media(max-width:640px){
  .search-results{border-radius:16px;max-height:300px}
  .search-result-item{padding:12px 16px}
  .sri-title{font-size:13px}
}

/* Hero */
@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.hero{position:relative;z-index:2;text-align:center;padding:80px 40px 64px;overflow:visible;
  background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 8%,#ffecd2 22%,#a8edea 48%,#fed6e3 72%,#d299c2 88%,#ffecd2 100%);
  background-size:300% 300%;animation:gradient-shift 12s ease infinite}
.hero::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.45);pointer-events:none;z-index:0}
.hero > *{position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;
  border:1px solid rgba(124,58,237,0.25);border-radius:100px;
  background:rgba(255,255,255,0.75);color:#6d28d9;font-size:13px;font-weight:600;margin-bottom:24px;
  backdrop-filter:blur(8px)}
.hero h1{font-family:var(--font);font-weight:800;font-size:clamp(48px,6vw,80px);line-height:1.05;
  margin-bottom:20px;letter-spacing:-2px;color:#0f172a}
.hero h1 span{background:linear-gradient(135deg,#0f172a 0%,#7c3aed 50%,#6d28d9 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero .hero-sub{color:var(--text2);font-family:var(--font2);font-size:18px;max-width:520px;margin:0 auto 40px;line-height:1.6}
.hero-search{max-width:560px;margin:0 auto 48px;position:relative;z-index:10}
.hero-search input{width:100%;padding:16px 56px 16px 20px;
  background:rgba(255,255,255,0.85);border:1.5px solid rgba(228,228,240,0.8);border-radius:100px;
  color:#0f172a;font-size:16px;font-family:var(--font2);outline:none;transition:.2s;
  backdrop-filter:blur(10px);box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.hero-search input::placeholder{color:#94a3b8}
.hero-search input:focus{border-color:rgba(124,58,237,0.5);box-shadow:0 0 0 3px rgba(124,58,237,0.1)}
.hero-search .search-icon{position:absolute;right:18px;top:50%;transform:translateY(-50%);
  color:#94a3b8;font-size:18px}
.hero-stats{display:flex;justify-content:center;gap:0;
  background:rgba(255,255,255,0.8);border:1px solid rgba(228,228,240,0.9);border-radius:18px;
  max-width:400px;margin:0 auto;overflow:hidden;backdrop-filter:blur(8px);
  box-shadow:0 2px 16px rgba(0,0,0,0.06)}
.stat{text-align:center;flex:1;padding:18px 12px;border-right:1px solid rgba(228,228,240,0.9);
  display:flex;flex-direction:column;align-items:center;justify-content:center}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--font);font-weight:800;font-size:26px;color:#7c3aed;
  min-height:36px;display:flex;align-items:center;justify-content:center;line-height:1}
.stat-label{color:#64748b;font-size:12px;margin-top:2px}

/* Section */
.section{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 40px 80px}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.section-title{font-family:var(--font);font-weight:700;font-size:24px}
.section-link{color:var(--accent);font-size:14px;font-weight:600;text-decoration:none;display:flex;align-items:center;gap:4px}
.section-link:hover{color:var(--accent2)}

/* Category grid */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat-card{padding:24px;border-radius:20px;border:1.5px solid var(--border);
  background:var(--surface);cursor:pointer;transition:.25s;text-decoration:none;color:inherit;
  position:relative;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,0.04)}
[data-theme="dark"] .cat-card{backdrop-filter:blur(10px);box-shadow:none}
.cat-card::before{content:'';position:absolute;inset:0;opacity:0;
  background:radial-gradient(circle at 50% 0%,rgba(124,58,237,0.15),transparent 70%);transition:.25s}
[data-theme="dark"] .cat-card::before{display:block}
:root:not([data-theme="dark"]) .cat-card::before{display:none}
.cat-card:hover{border-color:rgba(124,58,237,0.35);background:var(--surface-hover);transform:translateY(-3px);
  box-shadow:0 8px 28px rgba(124,58,237,0.1)}
[data-theme="dark"] .cat-card:hover{box-shadow:none}
.cat-card:hover::before{opacity:1}
.cat-card--all{background:linear-gradient(135deg,#7c3aed,#db2777)!important;border-color:#7c3aed!important;
  display:flex!important;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.cat-card--all::before{display:none}
.cat-card--all:hover{transform:translateY(-3px);opacity:.92}
.cat-icon{width:48px;height:48px;border-radius:14px;background:rgba(124,58,237,0.15);
  border:1px solid rgba(124,58,237,0.2);display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:16px}
.cat-name{font-family:var(--font);font-weight:700;font-size:15px;margin-bottom:6px}
.cat-count{color:var(--accent2);font-size:12px;font-weight:600;margin-bottom:8px}
.cat-desc{color:var(--text2);font-size:13px;line-height:1.5}

/* Category hero */
.cat-hero{text-align:center;padding:60px 0 48px}
.cat-hero-icon{font-size:64px;margin-bottom:20px}
.cat-hero h1{font-family:var(--font);font-weight:800;font-size:clamp(36px,4vw,56px);letter-spacing:-1.5px;margin-bottom:12px}
.cat-hero-desc{color:var(--text2);font-size:18px}

/* Services grid */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.service-card{padding:20px;border-radius:16px;border:1.5px solid var(--border);
  background:var(--surface);display:flex;align-items:center;gap:16px;
  cursor:pointer;transition:.2s;text-decoration:none;color:inherit;
  box-shadow:0 1px 4px rgba(0,0,0,0.04)}
[data-theme="dark"] .service-card{box-shadow:none;border-width:1px}
.service-card:hover{border-color:rgba(124,58,237,0.35);background:var(--surface-hover);transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(124,58,237,0.08)}
[data-theme="dark"] .service-card:hover{box-shadow:none}
.svc-icon{width:44px;height:44px;border-radius:12px;background:rgba(124,58,237,0.15);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.svc-info{flex:1;min-width:0}
.svc-name{font-weight:600;font-size:14px;margin-bottom:3px}
.svc-desc{color:var(--text2);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.svc-arrow{color:var(--accent2);font-size:18px;opacity:.5;flex-shrink:0}

/* Popular grid */
.pop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pop-card{padding:20px;border-radius:16px;border:1.5px solid var(--border);
  background:var(--surface);display:flex;align-items:center;gap:16px;
  cursor:pointer;transition:.2s;text-decoration:none;color:inherit;
  box-shadow:0 1px 4px rgba(0,0,0,0.04)}
[data-theme="dark"] .pop-card{box-shadow:none;border-width:1px}
.pop-card:hover{border-color:rgba(124,58,237,0.35);background:var(--surface-hover);transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(124,58,237,0.08)}
[data-theme="dark"] .pop-card:hover{box-shadow:none}
.pop-icon{width:44px;height:44px;border-radius:12px;background:rgba(124,58,237,0.15);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.pop-info{flex:1}
.pop-name{font-weight:600;font-size:14px;margin-bottom:3px}
.pop-cat{color:var(--text2);font-size:12px}
.pop-arrow{color:var(--accent2);font-size:18px;opacity:.5}

/* Breadcrumbs */
.breadcrumbs{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:20px 40px 32px;
  display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text2);flex-wrap:wrap}
.breadcrumbs a{color:var(--text2);text-decoration:none;white-space:nowrap}
.breadcrumbs a:hover{color:var(--accent2)}
.breadcrumbs span{white-space:nowrap}

/* Hero generator */
.hero-generator{position:relative;z-index:1;padding:40px 40px 0}
.hero-title-area{text-align:center;margin-bottom:40px;position:relative;z-index:2;max-width:1100px;margin:0 auto 40px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--cyan);
  font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;margin-bottom:18px}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';height:1px;width:30px;background:var(--cyan);opacity:.4}
h1{font-family:var(--font);font-weight:800;font-size:clamp(36px,4.5vw,64px);letter-spacing:-2px;margin-bottom:14px}
h1 .hl{color:inherit}
[data-theme="dark"] h1 .hl{color:inherit;text-shadow:none}
.hero-title-area .hero-sub{color:var(--text2);font-size:16px;max-width:480px;margin:0 auto}

/* Generator card */
.generator-card{max-width:1100px;margin:0 auto;background:rgba(255,255,255,0.03);
  border:1px solid rgba(124,58,237,0.2);border-radius:28px;overflow:hidden;position:relative;z-index:2;
  box-shadow:0 0 80px rgba(124,58,237,0.1)}
.generator-card::before{content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(124,58,237,0.05) 0%,transparent 50%,rgba(34,211,238,0.03) 100%);
  pointer-events:none}

/* Wheel section */
.wheel-section{display:flex;flex-direction:column;align-items:center;padding:48px 40px 40px;position:relative}

/* Meta chips above wheel */
.wheel-meta{display:flex;align-items:center;gap:10px;margin-bottom:36px;flex-wrap:wrap;justify-content:center}
.meta-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;
  border:1px solid var(--border);border-radius:100px;
  background:var(--bg2);font-weight:500;color:var(--text2);font-size:13px;white-space:nowrap}
[data-theme="dark"] .meta-tag{background:rgba(124,58,237,0.08);border-color:rgba(124,58,237,0.2);color:var(--text2)}

/* Wheel canvas wrapper */
.wheel-wrap{position:relative;width:360px;height:360px;margin-bottom:40px;flex-shrink:0}
#wheelCanvas{display:block;border-radius:50%}
.wheel-pointer{position:absolute;top:-22px;left:50%;transform:translateX(-50%);
  z-index:10;font-size:30px;filter:drop-shadow(0 2px 8px rgba(124,58,237,0.4));
  line-height:1;color:var(--text)}
.wheel-outer-ring{position:absolute;inset:-8px;border-radius:50%;
  background:conic-gradient(from 0deg,rgba(124,58,237,0.3),rgba(219,39,119,0.2),rgba(124,58,237,0.3),rgba(167,139,250,0.3));
  filter:blur(4px);z-index:-1;animation:rotateRing 8s linear infinite}
[data-theme="dark"] .wheel-outer-ring{background:conic-gradient(from 0deg,rgba(124,58,237,0.4),rgba(34,211,238,0.2),rgba(124,58,237,0.4),rgba(167,139,250,0.4))}
@keyframes rotateRing{to{transform:rotate(360deg)}}
.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:52px;height:52px;border-radius:50%;background:white;
  border:3px solid var(--border);display:flex;align-items:center;justify-content:center;
  font-size:22px;z-index:5;box-shadow:0 2px 12px rgba(124,58,237,0.15);pointer-events:none}
[data-theme="dark"] .wheel-center{background:#0a0a0a;border-color:rgba(255,255,255,0.1);box-shadow:0 0 20px rgba(124,58,237,0.4)}

/* Segment grid (settings) */
.seg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.seg-item{padding:9px 12px;background:var(--bg2);border:1px solid var(--border);
  border-radius:9px;font-size:12px;color:var(--text2);text-align:center;cursor:default;
  transition:.15s;font-weight:500;display:flex;align-items:center;justify-content:space-between;gap:4px}
.seg-item:hover{border-color:rgba(124,58,237,0.3);color:var(--accent)}
[data-theme="dark"] .seg-item{background:rgba(255,255,255,0.05)}
[data-theme="dark"] .seg-item:hover{background:rgba(124,58,237,0.1);color:var(--accent2)}
.seg-item-del{opacity:.35;font-size:10px;flex-shrink:0;cursor:pointer;transition:.15s}
.seg-item:hover .seg-item-del{opacity:.8}

/* Settings action buttons */
.settings-btns{display:flex;gap:8px;flex-wrap:wrap}
.s-btn{padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;
  border:1.5px solid rgba(124,58,237,0.3);background:rgba(124,58,237,0.06);
  color:var(--accent);font-family:var(--font2);transition:.2s}
.s-btn:hover{background:rgba(124,58,237,0.14)}
[data-theme="dark"] .s-btn{border-color:rgba(124,58,237,0.25);background:rgba(124,58,237,0.1);color:var(--accent2)}

/* Extra blocks — history + widget */
.extra-blocks{position:relative;z-index:1;max-width:1100px;margin:32px auto 0;
  padding:0 40px 48px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.history-block,.widget-block{background:white;border:1.5px solid var(--border);
  border-radius:20px;padding:24px;box-shadow:0 1px 6px rgba(0,0,0,0.04)}
[data-theme="dark"] .history-block,[data-theme="dark"] .widget-block{
  background:rgba(255,255,255,0.03);border-width:1px;box-shadow:none}
.history-title,.widget-title{font-family:var(--font);font-weight:700;font-size:15px;
  margin-bottom:16px;color:var(--text);display:flex;align-items:center;gap:8px}
.history-list{display:flex;flex-direction:column;gap:6px;min-height:88px}
.history-item{display:flex;justify-content:space-between;align-items:center;
  padding:8px 12px;border-radius:10px;background:var(--bg2);font-size:13px;color:var(--text)}
[data-theme="dark"] .history-item{background:rgba(255,255,255,0.05)}
.history-time{color:var(--text2);font-size:11px;font-family:var(--font-mono);white-space:nowrap;margin-left:8px}
.history-empty{color:var(--text2);font-size:13px;text-align:center;padding:24px 0;line-height:1.5}
.clear-history-btn{margin-top:12px;padding:6px 14px;border-radius:8px;border:1px solid var(--border);
  background:transparent;color:var(--text2);font-size:12px;cursor:pointer;font-family:var(--font2);transition:.2s}
.clear-history-btn:hover{border-color:rgba(124,58,237,0.35);color:var(--accent)}
.widget-code-area{background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;font-family:var(--font-mono);font-size:11px;color:var(--text);
  word-break:break-all;white-space:pre-wrap;margin-bottom:14px;line-height:1.6}
.copy-widget-btn{padding:10px 20px;border-radius:10px;border:none;
  background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;font-size:13px;font-weight:600;
  cursor:pointer;font-family:var(--font2);display:inline-flex;align-items:center;gap:6px;transition:.15s}
.copy-widget-btn:hover{opacity:.88;transform:translateY(-1px)}

/* Spin button */
.spin-btn{padding:20px 64px;background:linear-gradient(135deg,#7c3aed,#a78bfa);
  border:none;border-radius:100px;color:#fff;font-size:20px;font-weight:700;
  font-family:var(--font);cursor:pointer;letter-spacing:-.3px;
  box-shadow:0 8px 40px rgba(124,58,237,0.5);transition:.2s;margin-bottom:40px;
  display:inline-flex;align-items:center;gap:12px;position:relative;overflow:hidden}
.spin-btn::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  transform:translateX(-100%);transition:.4s}
.spin-btn:hover{transform:translateY(-3px);box-shadow:0 14px 52px rgba(124,58,237,0.6)}
.spin-btn:hover::after{transform:translateX(100%)}
.spin-btn.loading{opacity:.7;pointer-events:none}

/* Result area */
.result-area{width:100%;max-width:700px;text-align:center}
.result-block{padding:32px;background:rgba(124,58,237,0.08);
  border:1px solid rgba(124,58,237,0.25);border-radius:20px;margin-bottom:20px;
  transition:all .3s}
.result-block.has-result{background:rgba(124,58,237,0.12);border-color:rgba(124,58,237,0.4);
  box-shadow:0 0 40px rgba(124,58,237,0.15)}
.result-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;
  color:var(--cyan);margin-bottom:16px}
.result-main{font-family:var(--font);font-weight:800;font-size:clamp(28px,4vw,56px);
  color:#fff;text-shadow:0 0 30px rgba(167,139,250,0.5);margin-bottom:8px;
  min-height:60px;white-space:pre-wrap;word-break:break-word;line-height:1.2}
.result-sub{color:var(--text2);font-size:14px}
.result-main.animating{animation:slotAnim .4s ease-out}
@keyframes slotAnim{0%{transform:translateY(-12px);opacity:0}100%{transform:translateY(0);opacity:1}}
.result-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:20px}
.action-btn{padding:12px 22px;border-radius:12px;font-size:13px;font-weight:600;
  cursor:pointer;border:1px solid var(--border2);background:rgba(124,58,237,0.08);
  color:var(--text2);transition:.2s;font-family:var(--font2);
  display:flex;align-items:center;gap:7px}
.action-btn:hover{color:var(--text);border-color:var(--accent2);background:rgba(124,58,237,0.15)}
.action-btn.copied{color:var(--accent2);border-color:var(--accent2)}

/* Settings */
.settings-toggle{width:100%;max-width:700px;padding:12px 20px;
  border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,0.03);
  color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;font-family:var(--font2);
  margin-bottom:0;transition:.2s}
.settings-toggle:hover{border-color:var(--border2);color:var(--text)}
.settings-content{width:100%;max-width:700px;background:rgba(255,255,255,0.03);
  border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;padding:20px;margin-bottom:24px}
.param-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}
.param-row:last-child{margin-bottom:0}
.param-label{color:var(--text2);font-size:13px;font-weight:500;flex-shrink:0}
.param-select,.param-input{padding:8px 14px;background:rgba(255,255,255,0.06);border:1px solid var(--border);
  border-radius:10px;color:var(--text);font-size:13px;font-family:var(--font2);outline:none;
  transition:.2s;min-width:160px}
.param-select:focus,.param-input:focus{border-color:rgba(124,58,237,0.5);background:rgba(255,255,255,0.09)}
.param-check{display:flex;align-items:center;gap:8px;color:var(--text2);font-size:13px;cursor:pointer}
.param-check input{width:16px;height:16px;accent-color:var(--accent)}

/* Meta bar */
.service-meta-bar{background:rgba(255,255,255,0.02);border-top:1px solid var(--border);
  padding:16px 40px;display:flex;justify-content:center;gap:40px;flex-wrap:wrap}
.meta-item{display:flex;align-items:center;gap:8px;color:var(--text2);font-size:13px}
.meta-dot{color:var(--accent2)}

/* SEO + related */
.bottom{position:relative;z-index:1;max-width:1100px;margin:48px auto;padding:0 40px 64px}
.seo-block h2{font-family:var(--font);font-weight:700;font-size:22px;margin-bottom:14px}
.seo-block p{color:var(--text2);font-size:15px;line-height:1.7;margin-bottom:12px}
.seo-block h3{font-weight:600;font-size:15px;margin:22px 0 10px;color:var(--text)}
.seo-block ul{color:var(--text2);font-size:15px;padding-left:18px;line-height:1.7}
.seo-block ul li{margin-bottom:5px}
.related h2{font-family:var(--font);font-weight:700;font-size:22px;margin:40px 0 20px}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rel-card{padding:20px;border-radius:16px;border:1px solid var(--border);
  background:var(--surface);text-decoration:none;color:inherit;transition:.2s}
.rel-card:hover{border-color:rgba(124,58,237,0.4);background:rgba(124,58,237,0.1);transform:translateY(-3px)}
.rel-icon{font-size:26px;margin-bottom:10px}
.rel-name{font-weight:600;font-size:13px;margin-bottom:4px}
.rel-cat{color:var(--text2);font-size:11px}

/* Share row */
.share-row{display:flex;align-items:center;gap:10px;margin-top:16px;flex-wrap:wrap;justify-content:center}
.share-label{color:var(--text2);font-size:13px}
.share-btn{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;text-decoration:none;transition:.15s;letter-spacing:.3px;flex-shrink:0}
.share-btn.tg{background:#229ED9;color:#fff}.share-btn.tg:hover{background:#1a8ac0}
.share-btn.vk{background:#0077FF;color:#fff}.share-btn.vk:hover{background:#005ecc}
.share-btn.mx{background:#FF6700;color:#fff}.share-btn.mx:hover{background:#e05900}
.share-btn.wa{background:#25D366;color:#fff}.share-btn.wa:hover{background:#1aaa52}

/* History + Widget */
.extra-blocks{position:relative;z-index:1;max-width:1100px;margin:32px auto 0;padding:0 40px 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:24px}
.history-block,.widget-block{background:rgba(255,255,255,0.03);border:1px solid var(--border);
  border-radius:20px;padding:24px}
.history-title,.widget-title{font-family:var(--font);font-weight:700;font-size:15px;
  margin-bottom:16px;color:var(--text);display:flex;align-items:center;gap:8px}
.history-list{display:flex;flex-direction:column;gap:6px;min-height:88px}
.history-item{display:flex;justify-content:space-between;align-items:center;
  padding:8px 12px;border-radius:10px;background:rgba(255,255,255,0.05);font-size:13px;color:var(--text)}
.history-time{color:var(--text2);font-size:11px;font-family:'JetBrains Mono',monospace;white-space:nowrap;margin-left:8px}
.history-empty{color:var(--text2);font-size:13px;text-align:center;padding:24px 0;line-height:1.5}
.clear-history-btn{margin-top:12px;padding:6px 14px;border-radius:8px;border:1px solid var(--border);
  background:transparent;color:var(--text2);font-size:12px;cursor:pointer;font-family:var(--font2);transition:.2s}
.clear-history-btn:hover{border-color:rgba(124,58,237,0.4);color:var(--accent2)}
.widget-code-area{background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text);
  word-break:break-all;white-space:pre-wrap;margin-bottom:14px;line-height:1.6}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:500;
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal{background:#1a1a2e;border:1px solid var(--border2);border-radius:20px;
  padding:32px;max-width:440px;width:90%}
.modal h3{font-family:var(--font);font-weight:700;font-size:18px;margin-bottom:16px}
.modal textarea{width:100%;padding:12px 16px;background:rgba(255,255,255,0.06);
  border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:14px;
  font-family:var(--font2);resize:vertical;min-height:100px;outline:none;margin-bottom:16px}
.modal textarea:focus{border-color:var(--border2)}
.modal-actions{display:flex;gap:12px;justify-content:flex-end}

/* Footer — always dark */
footer{position:relative;z-index:1;border-top:none;padding:48px 40px 32px;background:#0f172a}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1fr repeat(3,auto);gap:60px;margin-bottom:40px}
.footer-brand .logo{margin-bottom:12px;display:inline-flex}
.footer-brand .logo-text{color:#f1f5f9!important;-webkit-text-fill-color:#f1f5f9!important;background:none!important}
.footer-brand p{color:#64748b;font-size:13px;line-height:1.6;max-width:240px}
.footer-col h4{font-weight:600;font-size:13px;color:#f1f5f9;margin-bottom:14px}
.footer-col a{display:block;color:#64748b;font-size:13px;text-decoration:none;margin-bottom:8px;transition:.15s}
.footer-col a:hover{color:#f1f5f9}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid #1e293b}
.footer-bottom p{color:#64748b;font-size:13px}
.footer-bottom .icon-btn{border-color:#1e293b!important;background:#1e293b!important;color:#64748b!important}
.footer-bottom .lang-btn{border-color:#1e293b!important;background:#1e293b!important;color:#64748b!important}
.socials{display:flex;gap:8px}

/* Toast */
.toast{position:fixed;bottom:32px;right:32px;z-index:600;
  padding:12px 20px;border-radius:12px;background:rgba(124,58,237,0.9);
  color:#fff;font-size:14px;font-weight:500;pointer-events:none;
  transform:translateY(100px);opacity:0;transition:.3s}
.toast.show{transform:translateY(0);opacity:1}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  .donate-header-link{display:none!important}
  header{padding:0 24px;gap:16px}
  nav a{padding:5px 8px;font-size:12px}
  .hero{padding:64px 24px 48px}
  .section{padding:0 24px 60px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .pop-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .hero-generator{padding:32px 24px 0}
  .generator-card{border-radius:20px}
  .wheel-section{padding:36px 24px 32px}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .bottom{padding:0 24px 48px;margin:36px auto}
  .extra-blocks{padding:0 24px 36px}
  .service-meta-bar{gap:16px 32px;padding:14px 24px}
}
@media(max-width:640px){
  header{padding:0 16px;gap:10px;height:56px}
  nav{display:none}
  .lang-btn{display:inline-flex;align-items:center;padding:6px 9px;font-size:12px}
  .header-right{gap:6px;margin-left:auto}
  .icon-btn{width:32px;height:32px;font-size:13px}
  .logo-icon{width:32px;height:32px}
  .mob-menu-btn{display:flex;width:32px;height:32px;font-size:16px}
  .donate-header-link{display:none!important}
  .header-right{margin-left:auto}
  .hero{padding:40px 16px 32px}
  .hero h1{font-size:clamp(28px,8vw,44px)!important;letter-spacing:-1px}
  .hero-sub{font-size:15px;margin-bottom:24px}
  .hero-stats{max-width:100%;border-radius:14px}
  .stat{padding:14px 8px}
  .stat-num{font-size:20px}
  .section{padding:0 16px 40px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cat-card{padding:14px}
  .cat-icon{width:40px;height:40px;font-size:18px;margin-bottom:10px}
  .cat-name{font-size:13px}
  .cat-desc{font-size:12px}
  .pop-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  footer{padding:28px 16px 20px}
  .footer-top{grid-template-columns:1fr;gap:20px}
  .footer-bottom{flex-direction:column;gap:12px;align-items:center}
  .breadcrumbs{padding:12px 16px 16px}
  .hero-generator{padding:24px 16px 0}
  .hero-title-area{margin-bottom:24px}
  h1{font-size:clamp(26px,7vw,44px)!important;letter-spacing:-1px}
  .wheel-section{padding:28px 16px 28px}
  .spin-btn{padding:16px 36px;font-size:17px;margin-bottom:28px}
  .result-block{padding:22px 16px}
  .result-main{font-size:clamp(22px,6vw,36px)}
  .result-actions{flex-direction:column;align-items:center;gap:8px}
  .action-btn{width:100%;max-width:280px;justify-content:center}
  .settings-toggle,.settings-content{max-width:100%}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .bottom{padding:0 16px 40px;margin:24px auto}
  .extra-blocks{grid-template-columns:1fr;padding:0 16px 32px}
  .service-meta-bar{flex-wrap:wrap;gap:8px 16px;padding:12px 16px}
}
@media(max-width:380px){
  .cat-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .logo-text{display:none}
  .lang-btn{padding:5px 7px;font-size:11px}
  .header-right{gap:5px}
}
/* Coming Soon card */
.coming-soon-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:56px 32px;gap:20px}
.coming-soon-icon{font-size:64px;line-height:1}
.coming-soon-title{font-size:28px;font-weight:800;color:var(--text1)}
.coming-soon-text{color:var(--text2);font-size:15px;line-height:1.7;max-width:400px}
.coming-soon-features{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin-top:4px}
.csf-item{color:var(--accent2);font-size:13px;text-align:left}
.csf-back-btn{display:inline-block;margin-top:8px;color:var(--accent);border:1.5px solid var(--accent);border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s,color .2s}
.csf-back-btn:hover{background:var(--accent);color:#fff}
/* Fortune Wheel layout */
.wheel-card{padding:0}
.wheel-layout{display:grid;grid-template-columns:420px 1fr;min-height:480px}
.wheel-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px 24px;background:rgba(124,58,237,.06);border-radius:20px 0 0 20px;position:relative}
.wheel-pointer{font-size:28px;color:var(--accent);position:absolute;top:16px;left:50%;transform:translateX(-50%);filter:drop-shadow(0 0 8px var(--accent));z-index:2}
#wheelCanvas{display:block;border-radius:50%;box-shadow:0 0 40px rgba(124,58,237,.3);cursor:pointer}
.wheel-spin-btn{margin-top:8px}
.wheel-controls{display:flex;flex-direction:column;gap:20px;padding:32px 28px}
.wheel-items-section{display:flex;flex-direction:column;gap:10px}
.wheel-items-label{font-weight:700;font-size:14px;color:var(--text1)}
.wheel-hint-inline{font-weight:400;color:var(--text2);font-size:12px}
.wheel-textarea{width:100%;background:var(--card2);border:1.5px solid var(--border);border-radius:12px;color:var(--text1);font-family:var(--font-mono),monospace;font-size:13px;padding:12px 14px;resize:vertical;min-height:160px;transition:border-color .2s}
.wheel-textarea:focus{outline:none;border-color:var(--accent)}
.update-btn{align-self:flex-start}
.wheel-history{margin-top:4px}
.history-label{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}
.history-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text1)}
.history-time{color:var(--text2);font-size:11px}
.service-icon-title{margin-right:6px}
@media(max-width:860px){
  .wheel-layout{grid-template-columns:1fr}
  .wheel-container{border-radius:20px 20px 0 0;padding:24px 16px}
  #wheelCanvas{width:300px;height:300px}
  .wheel-controls{padding:24px 16px}
}
@media(max-width:480px){
  .coming-soon-features{grid-template-columns:1fr}
  .csf-item{text-align:center}
  #wheelCanvas{width:260px;height:260px}
}

/* ===== CATEGORY PAGE ===== */

/* Hero */
.cat-hero-page{
  background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 8%,#ffecd2 22%,#a8edea 48%,#fed6e3 72%,#d299c2 88%,#ffecd2 100%);
  background-size:300% 300%;animation:gradient-shift 12s ease infinite;
  position:relative;overflow:hidden;margin-top:20px}
.cat-hero-page::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.5);pointer-events:none}
.cat-hero-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:40px 40px 44px;
  display:flex;align-items:flex-start;justify-content:space-between;gap:32px}
.cat-hero-left{flex:1}
.cat-icon-big{width:68px;height:68px;border-radius:20px;
  background:rgba(255,255,255,0.85);backdrop-filter:blur(10px);
  border:2px solid rgba(255,255,255,0.9);box-shadow:0 4px 24px rgba(0,0,0,0.08);
  display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:18px}
.cat-hero-h1{font-family:var(--font);font-weight:800;font-size:clamp(32px,4vw,52px);
  letter-spacing:-1.5px;margin-bottom:12px;color:#0f172a}
.cat-h1-accent{color:#7c3aed}
.cat-hero-desc-full{color:#475569;font-size:16px;line-height:1.6;max-width:560px;margin-bottom:24px}
.cat-badges{display:flex;gap:10px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;
  border-radius:100px;font-size:12px;font-weight:600;
  background:rgba(255,255,255,0.75);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.9);color:#475569}
.badge-accent{background:rgba(124,58,237,0.12);border-color:rgba(124,58,237,0.3);color:#7c3aed}
.cat-hero-stats{display:flex;flex-direction:column;gap:20px;flex-shrink:0;text-align:right;padding-top:8px}
.hero-stat-num{font-family:var(--font);font-weight:800;font-size:40px;color:#7c3aed}
.hero-stat-label{color:#475569;font-size:12px;font-weight:500;margin-top:2px}

/* Filter bar */
.filter-bar{max-width:1200px;margin:0 auto;padding:24px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-bottom:1px solid var(--border)}
.filter-pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{padding:7px 18px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;
  border:1px solid var(--border);background:var(--surface);color:var(--text2);transition:.2s;
  -webkit-user-select:none;user-select:none}
.pill:hover{border-color:rgba(124,58,237,0.35);color:var(--accent)}
.pill-active{border-color:var(--accent)!important;color:var(--accent)!important;background:rgba(124,58,237,0.08)!important}
.sort-wrap{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}
.sort-select{background:var(--surface);border:1px solid var(--border);color:var(--text);
  padding:7px 12px;border-radius:8px;font-size:13px;cursor:pointer;font-family:var(--font2);outline:none}

/* Service cards grid (category page) */
.svc-grid-wrap{max-width:1200px;margin:0 auto;padding:32px 40px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc-card{padding:24px;border-radius:20px;border:1px solid var(--border);
  background:#fff;cursor:pointer;transition:.25s;text-decoration:none;color:inherit;
  position:relative;overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,0.06);display:flex;flex-direction:column}
[data-theme="dark"] .svc-card{background:var(--surface);box-shadow:none}
.svc-card:hover{border-color:rgba(124,58,237,0.3);box-shadow:0 8px 30px rgba(124,58,237,0.1);transform:translateY(-3px)}
[data-theme="dark"] .svc-card:hover{box-shadow:none}
.svc-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.svc-icon-box{width:46px;height:46px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.svc-card-name{font-family:var(--font);font-weight:700;font-size:15px;margin-bottom:6px;color:var(--text)}
.svc-card-desc{color:var(--text2);font-size:13px;line-height:1.5;margin-bottom:16px;flex:1}
.svc-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.svc-card-status{font-size:11px;color:var(--text2)}
.svc-open-btn{padding:7px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;
  border:1px solid rgba(124,58,237,0.3);background:rgba(124,58,237,0.08);
  color:#7c3aed;transition:.2s;font-family:var(--font2)}
.svc-open-btn:hover{background:#7c3aed;color:#fff;border-color:#7c3aed}

/* Other categories section */
.all-cats-section{max-width:1200px;margin:0 auto;padding:8px 40px 64px}
.all-cats-title{font-family:var(--font);font-weight:700;font-size:20px;margin-bottom:20px;color:var(--text)}
.cats-chips-row{display:flex;gap:10px;flex-wrap:wrap}
.cat-chip{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:12px;
  border:1px solid var(--border);background:var(--surface);font-size:13px;font-weight:500;
  text-decoration:none;color:var(--text);cursor:pointer;transition:.2s;
  box-shadow:0 1px 2px rgba(0,0,0,0.04)}
.cat-chip:hover{border-color:rgba(124,58,237,0.3);background:rgba(124,58,237,0.05);color:var(--accent)}
.chip-count{color:var(--accent);font-size:11px;font-weight:700;margin-left:2px}

/* Responsive category page */
@media(max-width:960px){
  .cat-hero-inner{padding:32px 24px 36px}
  .svc-grid-wrap{padding:24px 24px;grid-template-columns:repeat(2,1fr)}
  .filter-bar,.all-cats-section{padding-left:24px;padding-right:24px}
}
@media(max-width:640px){
  .cat-hero-inner{padding:24px 16px 28px;flex-direction:column;gap:16px}
  .cat-icon-big{width:54px;height:54px;font-size:26px;margin-bottom:12px}
  .cat-hero-h1{font-size:clamp(26px,8vw,40px);letter-spacing:-1px}
  .cat-hero-desc-full{font-size:14px;margin-bottom:16px}
  .cat-hero-stats{flex-direction:row;gap:32px;text-align:left}
  .hero-stat-num{font-size:30px}
  .filter-bar{padding:10px 16px;flex-direction:row;align-items:center;justify-content:space-between;gap:6px;flex-wrap:nowrap}
  .filter-pills{flex-wrap:nowrap}
  .pill{padding:5px 11px;font-size:11px;white-space:nowrap}
  .sort-wrap{gap:4px;font-size:11px;flex-shrink:0;white-space:nowrap}
  .sort-select{padding:5px 6px;font-size:11px;max-width:136px}
  .svc-grid-wrap{padding:20px 16px;grid-template-columns:1fr;gap:12px}
  .svc-card{padding:18px}
  .all-cats-section{padding:0 16px 40px}
  .cats-chips-row{gap:8px}
  .cat-chip{font-size:12px;padding:8px 12px}
}

/* ===== DARK THEME OVERRIDES ===== */

/* Dark hero — remove animated gradient, use dark bg */
[data-theme="dark"] .hero{background:var(--bg);animation:none}
[data-theme="dark"] .hero::before{background:radial-gradient(ellipse 80% 60% at 50% 10%,rgba(124,58,237,0.12) 0%,transparent 60%);opacity:1}
[data-theme="dark"] .hero-badge{border-color:rgba(124,58,237,0.3);background:rgba(124,58,237,0.08);color:var(--accent2)}
[data-theme="dark"] .hero h1{color:var(--text)}
[data-theme="dark"] .hero h1 span{background:linear-gradient(135deg,#f0f0f0 0%,#a78bfa 50%,#7c3aed 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
[data-theme="dark"] .hero-sub{color:var(--text2)}
[data-theme="dark"] .hero-search input{background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:16px;color:var(--text);box-shadow:none}
[data-theme="dark"] .hero-stats{background:transparent;border:none;box-shadow:none;gap:40px}
[data-theme="dark"] .stat{border-right:none;padding:0;flex:none}
[data-theme="dark"] .stat-num{background:linear-gradient(135deg,#f0f0f0,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:28px}
[data-theme="dark"] .stat-label{color:var(--text2)}

/* Dark category hero */
[data-theme="dark"] .cat-hero-page{background:#06061a;animation:none}
[data-theme="dark"] .cat-hero-page::before{background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(124,58,237,0.15) 0%,transparent 70%);opacity:1}
[data-theme="dark"] .cat-hero-h1{color:var(--text)!important}
[data-theme="dark"] .cat-h1-accent{color:var(--accent2)!important}
[data-theme="dark"] .cat-hero-desc-full{color:var(--text2)!important}
[data-theme="dark"] .badge{color:var(--text2)!important;background:rgba(255,255,255,0.06)!important;border-color:rgba(255,255,255,0.1)!important}
[data-theme="dark"] .badge-accent{background:rgba(124,58,237,0.15)!important;border-color:rgba(124,58,237,0.3)!important;color:var(--accent2)!important}
[data-theme="dark"] .hero-stat-num{color:var(--accent2)!important}
[data-theme="dark"] .hero-stat-label{color:var(--text2)!important}

/* ===== SERVICE PAGE LIGHT MODE ===== */
[data-theme="light"] .generator-card{background:white;border:1.5px solid var(--border);box-shadow:0 4px 40px rgba(124,58,237,0.08),0 1px 6px rgba(0,0,0,0.04)}
[data-theme="light"] .generator-card::before{display:none}
[data-theme="light"] .spin-btn{background:linear-gradient(90deg,#7c3aed,#db2777,#ea580c);box-shadow:0 8px 32px rgba(124,58,237,0.35)}
[data-theme="light"] .result-main{color:var(--text);text-shadow:none}
[data-theme="light"] .result-block{background:rgba(124,58,237,0.05);border-color:rgba(124,58,237,0.18);box-shadow:0 2px 20px rgba(124,58,237,0.07)}
[data-theme="light"] .result-block.has-result{background:rgba(124,58,237,0.07);border-color:rgba(124,58,237,0.25)}
[data-theme="light"] .result-label{color:var(--accent)}
[data-theme="light"] .action-btn{background:white;border-color:var(--border);color:var(--text2);box-shadow:0 1px 4px rgba(0,0,0,0.04)}
[data-theme="light"] .action-btn:hover{color:var(--accent);border-color:rgba(124,58,237,0.35);background:rgba(124,58,237,0.04);box-shadow:none}
[data-theme="light"] .hero-eyebrow{color:var(--accent)}
[data-theme="light"] .hero-eyebrow::before,[data-theme="light"] .hero-eyebrow::after{background:var(--accent)}
[data-theme="light"] h1 .hl{color:inherit!important;text-shadow:none!important}
[data-theme="light"] .settings-toggle{background:var(--bg2);border-color:var(--border)}
[data-theme="light"] .settings-content{background:white;border-color:var(--border)}
[data-theme="light"] .service-meta-bar{background:var(--bg2)}
[data-theme="light"] .meta-dot{color:var(--accent)}
[data-theme="light"] .history-block,[data-theme="light"] .widget-block{background:white;border-color:var(--border);box-shadow:0 1px 6px rgba(0,0,0,0.04)}
[data-theme="light"] .history-item{background:var(--bg2)}
[data-theme="light"] .widget-code-area{background:var(--bg2);border-color:var(--border);color:var(--text)}
[data-theme="light"] .param-select,[data-theme="light"] .param-input{background:white;border-color:var(--border);color:var(--text)}
[data-theme="light"] .rel-card{background:white;border-color:var(--border);box-shadow:0 1px 4px rgba(0,0,0,0.04)}
[data-theme="light"] .rel-card:hover{border-color:rgba(124,58,237,0.35);background:rgba(124,58,237,0.04);box-shadow:0 6px 20px rgba(124,58,237,0.08)}
[data-theme="light"] .rel-name{color:var(--text)}
[data-theme="light"] .seo-block h2,[data-theme="light"] .related h2{color:var(--text)}
[data-theme="light"] .modal{background:#fff;border-color:var(--border)}

/* ===== STATIC PAGE ===== */
.page-hero{position:relative;overflow:hidden;padding:44px 40px;
  background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 8%,#ffecd2 22%,#a8edea 48%,#fed6e3 72%,#d299c2 88%,#ffecd2 100%);
  background-size:300% 300%;animation:gradient-shift 12s ease infinite}
[data-theme="dark"] .page-hero{background:#06061a;animation:none}
[data-theme="dark"] .page-hero::before{background:radial-gradient(ellipse 60% 40% at 70% 20%,rgba(124,58,237,0.12),transparent 60%);opacity:1}
.page-hero::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.55);pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto}
.page-hero h1{font-family:var(--font);font-weight:800;font-size:clamp(26px,4vw,44px);letter-spacing:-1.5px;color:#0f172a}
[data-theme="dark"] .page-hero h1{color:var(--text)}
.page-hero h1 span{color:var(--accent)}
.page-hero-sub{color:#475569;font-size:15px;margin-top:8px}
[data-theme="dark"] .page-hero-sub{color:var(--text2)}

.page-wrap{display:grid;grid-template-columns:1fr 260px;gap:40px;max-width:1100px;margin:0 auto;padding:48px 40px 80px}
.article h2{font-family:var(--font);font-weight:700;font-size:20px;margin:36px 0 14px;color:var(--text)}
.article h3{font-family:var(--font);font-weight:600;font-size:16px;margin:24px 0 10px;color:var(--accent)}
.article p{color:var(--text2);font-size:15px;line-height:1.75;margin-bottom:14px}
.article ul,.article ol{color:var(--text2);font-size:15px;line-height:1.7;padding-left:20px;margin-bottom:16px}
.article li{margin-bottom:6px}
.article a{color:var(--accent);border-bottom:1px solid rgba(124,58,237,0.25)}
.article a:hover{border-bottom-color:var(--accent)}
.article-meta{display:flex;align-items:center;gap:16px;margin-bottom:36px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.meta-chip{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}
.meta-chip span{color:var(--accent);font-weight:600}
.info-box{background:rgba(124,58,237,0.06);border:1px solid rgba(124,58,237,0.18);border-radius:14px;padding:20px 22px;margin:24px 0}
[data-theme="dark"] .info-box{background:rgba(124,58,237,0.08);border-color:rgba(124,58,237,0.2)}
.info-box p{color:var(--text);margin:0;font-size:14px;line-height:1.65}
.info-box-icon{font-size:20px;margin-bottom:10px}
.sidebar-col{position:sticky;top:84px;align-self:start}
.toc{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;
  box-shadow:0 1px 3px rgba(0,0,0,0.05)}
[data-theme="dark"] .toc{box-shadow:none}
.toc-title{font-family:var(--font);font-weight:700;font-size:12px;margin-bottom:14px;color:var(--text2);text-transform:uppercase;letter-spacing:1px}
.toc a{display:block;font-size:13px;color:var(--text2);margin-bottom:8px;padding:3px 0 3px 12px;border-left:2px solid transparent;transition:.15s;text-decoration:none}
.toc a:hover{color:var(--accent);border-left-color:var(--accent)}
.toc a.active{color:var(--accent);border-left-color:var(--accent);font-weight:600}
.toc-sub{font-size:12px;padding-left:22px;border-left:none!important}
.also-see{margin-top:20px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;
  box-shadow:0 1px 3px rgba(0,0,0,0.05)}
[data-theme="dark"] .also-see{box-shadow:none}
.also-see-title{font-family:var(--font);font-weight:700;font-size:12px;margin-bottom:14px;color:var(--text2);text-transform:uppercase;letter-spacing:1px}
.also-item{display:flex;align-items:center;gap:10px;font-size:13px;margin-bottom:10px;color:var(--text2);cursor:pointer;transition:.15s;padding:6px 10px;border-radius:8px;text-decoration:none}
.also-item:hover{color:var(--accent);background:rgba(124,58,237,0.05)}
.also-item:last-child{margin:0}
.also-icon{font-size:16px}

@media(max-width:768px){.page-wrap{grid-template-columns:1fr}.sidebar-col{display:none}}
@media(max-width:640px){.page-hero{padding:28px 16px}.page-wrap{padding:24px 16px 48px}}

/* ===== QR CODE GENERATOR ===== */
.qr-card{padding:0;overflow:hidden}
.qr-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:560px}
.qr-settings{padding:28px 32px;border-right:1px solid var(--border)}
.qr-preview-area{padding:28px 32px;display:flex;flex-direction:column;align-items:center;gap:16px}
.qr-section{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:10px}
.qr-section-header{display:flex;align-items:center;gap:10px;padding:12px 16px;
  font-weight:600;font-size:13px;cursor:pointer;background:var(--bg2);
  border:none;width:100%;text-align:left;color:var(--text);transition:.15s}
.qr-section-header.static{cursor:default}
.qr-section-header:not(.static):hover{background:var(--surface-hover)}
.qr-toggle{margin-left:auto;font-size:16px;line-height:1;color:var(--accent);font-style:normal}
.qr-section-body{padding:14px 16px}
.qr-section-body label{display:block;font-size:12px;font-weight:600;color:var(--text2);
  margin-bottom:7px;margin-top:12px;text-transform:uppercase;letter-spacing:.4px}
.qr-section-body label:first-child{margin-top:0}
.qr-text-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:9px;
  background:var(--bg);color:var(--text);font-size:14px;resize:vertical;
  font-family:var(--font2);outline:none;transition:.2s;box-sizing:border-box}
.qr-text-input:focus{border-color:rgba(124,58,237,0.5);box-shadow:0 0 0 3px rgba(124,58,237,0.08)}
.qr-color-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.qr-color-row input[type="color"]{width:38px;height:38px;border:1.5px solid var(--border);
  border-radius:8px;cursor:pointer;padding:3px;background:none;flex-shrink:0}
.qr-hex-input{flex:1;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;
  background:var(--bg);color:var(--text);font-size:13px;font-family:monospace;outline:none;transition:.2s}
.qr-hex-input:focus{border-color:rgba(124,58,237,0.5)}
.qr-style-grid{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
.qr-style-btn{width:38px;height:38px;border:1.5px solid var(--border);border-radius:8px;
  background:var(--bg);color:var(--text);cursor:pointer;transition:.15s;
  display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}
.qr-style-btn:hover{border-color:var(--accent);background:rgba(124,58,237,0.06)}
.qr-style-btn.active{border-color:var(--accent);background:rgba(124,58,237,0.12);color:var(--accent)}
.qr-canvas-wrap{width:260px;height:260px;border:1.5px solid var(--border);border-radius:14px;
  overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qr-canvas-wrap canvas,.qr-canvas-wrap svg{max-width:100%!important;max-height:100%!important;display:block}
.qr-size-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;width:100%;font-size:11px;color:var(--text2)}
.qr-size-row input[type="range"]{width:100%;accent-color:var(--accent)}
.qr-size-val{font-weight:600;color:var(--accent);font-size:11px;white-space:nowrap;text-align:center;
  grid-column:1/-1;margin-top:-2px}
.qr-gen-btn{width:100%;justify-content:center}
.qr-download-row{display:flex;gap:8px;width:100%}
.qr-dl-btn{flex:1;padding:9px 14px;border-radius:10px;border:1.5px solid var(--border);
  background:var(--bg2);color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;transition:.15s}
.qr-dl-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(124,58,237,0.06)}
.qr-dl-main{flex:2;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff!important;border-color:transparent!important}
.qr-dl-main:hover{opacity:.9;background:linear-gradient(135deg,#7c3aed,#a78bfa)!important}
[data-theme="dark"] .qr-canvas-wrap{background:#1a1a2e;border-color:rgba(255,255,255,0.1)}
[data-theme="light"] .qr-section-header{background:var(--bg2)}
@media(max-width:860px){
  .qr-layout{grid-template-columns:1fr}
  .qr-settings{border-right:none;border-bottom:1px solid var(--border);padding:24px}
  .qr-preview-area{padding:24px}
  .qr-canvas-wrap{width:240px;height:240px}
}
@media(max-width:640px){
  .qr-settings,.qr-preview-area{padding:20px 16px}
  .qr-canvas-wrap{width:200px;height:200px}
}

/* Service page responsive */
@media(max-width:960px){
  .extra-blocks{padding:0 24px 36px}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .bottom{padding:0 24px 48px;margin:36px auto}
}
@media(max-width:640px){
  .hero-generator{padding:24px 16px 0}
  .hero-title-area{margin-bottom:24px}
  .wheel-section{padding:28px 16px 28px}
  .wheel-wrap{width:280px;height:280px}
  #wheelCanvas{width:280px!important;height:280px!important}
  .wheel-meta{gap:6px}
  .meta-tag{padding:4px 10px;font-size:11px}
  .spin-btn{padding:16px 32px;font-size:17px}
  .result-block{padding:22px 16px}
  .result-main{font-size:clamp(28px,6vw,44px)!important}
  .result-actions{flex-direction:column;align-items:center;gap:8px}
  .action-btn{width:100%;max-width:280px;justify-content:center}
  .settings-toggle,.settings-content{max-width:100%}
  .seg-grid{grid-template-columns:repeat(2,1fr)}
  .settings-btns{gap:6px}
  .extra-blocks{grid-template-columns:1fr;padding:0 16px 32px;margin-top:24px}
  .service-meta-bar{flex-wrap:wrap;gap:8px 16px;padding:12px 16px;justify-content:flex-start}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .bottom{padding:0 16px 40px;margin:24px auto}
}

/* ── Number generator ── */
.num-gen-wrap{width:100%;max-width:560px;margin:0 auto 32px}
.num-gen-settings{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px 32px;display:flex;flex-direction:column;gap:22px}
.num-gen-row{display:flex;flex-direction:column;gap:10px}
.num-gen-label{font-size:14px;font-weight:600;color:var(--text2);display:flex;align-items:center;gap:8px}
.num-gen-label strong{color:var(--accent);font-size:20px;font-family:var(--font-mono);min-width:32px}
.num-gen-slider{width:100%;accent-color:var(--accent);cursor:pointer;height:5px}
.num-gen-slider-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text2);margin-top:2px;padding:0 2px}
.num-gen-range{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.num-gen-range-label{font-size:14px;color:var(--text2);font-weight:500}
.num-gen-input{width:110px;padding:11px 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:17px;font-weight:700;text-align:center;font-family:var(--font-mono);transition:.2s;outline:none}
.num-gen-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,0.12)}
[data-theme="dark"] .num-gen-input{background:var(--bg2)}
.num-gen-check{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text2);user-select:none}
.num-gen-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.num-gen-exclude-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:14px;font-family:var(--font2);transition:.2s;outline:none;margin-top:8px}
.num-gen-exclude-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,0.12)}
[data-theme="dark"] .num-gen-exclude-input{background:var(--bg2)}
.num-gen-select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:15px;font-weight:500;font-family:var(--font2);cursor:pointer;transition:.2s;outline:none;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237c3aed' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.num-gen-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,0.12)}
[data-theme="dark"] .num-gen-select{background-color:var(--bg2)}
.history-item span:first-child{word-break:break-word;white-space:normal;flex:1;min-width:0}
@media(max-width:640px){
  .num-gen-settings{padding:20px 16px;gap:16px}
  .num-gen-input{width:90px;font-size:15px;padding:9px 10px}
}

/* ── Donate trigger links ── */
@keyframes shimmer-text{0%{background-position:0% center}100%{background-position:200% center}}
.donate-trigger{display:inline-flex!important;align-items:center;gap:6px;text-decoration:none;font-weight:700;font-size:14px;cursor:pointer;white-space:nowrap;border-radius:10px;transition:opacity .2s;-webkit-text-fill-color:initial;color:var(--text)}
.donate-trigger .donate-trigger-text{background:linear-gradient(90deg,#7c3aed 0%,#a78bfa 25%,#ec4899 50%,#f97316 65%,#a78bfa 80%,#7c3aed 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer-text 3s linear infinite;color:transparent}
.donate-trigger .donate-emoji{-webkit-text-fill-color:initial;color:inherit;display:inline}
.donate-trigger:hover{opacity:.8}
/* Header: desktop only */
.donate-header-link{padding:7px 14px;border:1.5px solid rgba(124,58,237,0.35);border-radius:10px;background:rgba(124,58,237,0.06)}
.donate-header-link:hover{background:rgba(124,58,237,0.12);border-color:rgba(124,58,237,0.6)}
[data-theme="dark"] .donate-header-link{background:rgba(124,58,237,0.1);border-color:rgba(124,58,237,0.3)}
/* Footer link — reset footer column overrides */
.donate-footer-link{display:inline-flex!important;margin-top:4px;font-size:13px;color:var(--text)!important;-webkit-text-fill-color:initial!important}
/* Mobile menu link — reset mob-nav overrides */
.donate-mob-link{display:inline-flex!important;font-size:15px;font-weight:700;border-bottom:1px solid rgba(124,58,237,0.2);padding-bottom:12px!important;margin-bottom:4px;color:var(--text)!important;-webkit-text-fill-color:initial!important}

/* ── Donate popup ── */
.donate-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.55);backdrop-filter:blur(4px)}
.donate-popup{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:32px 28px 28px;max-width:380px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,0.3),0 0 0 1px var(--border2);text-align:center;animation:donate-in .25s ease}
@keyframes donate-in{from{opacity:0;transform:scale(.93) translateY(10px)}to{opacity:1;transform:none}}
.donate-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:18px;color:var(--text2);cursor:pointer;line-height:1;padding:4px 8px;border-radius:8px;transition:.2s}
.donate-close:hover{background:var(--surface-hover);color:var(--text)}
.donate-title{font-family:var(--font);font-size:24px;font-weight:700;color:var(--text);margin-bottom:12px;line-height:1.35}
.donate-text{font-size:13.5px;color:var(--text2);line-height:1.65;margin-bottom:20px}
.donate-qr-wrap{display:flex;justify-content:center}
.donate-qr-img{width:200px;height:200px;object-fit:contain;border-radius:12px;border:1px solid var(--border)}
.donate-link{display:inline-block;margin-top:14px;color:var(--accent);font-size:13.5px;font-weight:600;text-decoration:none;border-bottom:1px solid rgba(124,58,237,0.35);transition:.2s}
.donate-link:hover{color:var(--accent2);border-bottom-color:var(--accent2)}
/* Fix: donate header link hidden at <960px (specificity override) */
@media(max-width:960px){header .donate-header-link,.donate-header-link.donate-trigger{display:none!important}}

/* ═══════════════════════════════════════════════════════
   VK WINNER SERVICE
   ═══════════════════════════════════════════════════════ */

/* Card */
.vk-card{display:flex;flex-direction:column;gap:20px}

/* Logo row */
.vk-logo-row{display:flex;align-items:center;justify-content:center;gap:12px;padding:4px 0 8px}
.vk-logo-svg{width:44px;height:44px;flex-shrink:0}
.vk-logo-text{font-family:var(--font);font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.5px}

/* Steps */
.vk-step{display:flex;flex-direction:column;gap:12px}
.vk-label{font-size:15px;font-weight:600;color:var(--text2);margin-bottom:2px}

/* URL input */
.vk-url-input{width:100%;padding:13px 16px;border:2px solid var(--border);border-radius:14px;background:var(--bg);color:var(--text);font-size:15px;font-family:var(--font-mono);transition:.2s;outline:none;box-sizing:border-box}
.vk-url-input:focus{border-color:#0077FF;box-shadow:0 0 0 3px rgba(0,119,255,0.14)}
.vk-url-input--error{border-color:var(--danger,#e85d5d)}
[data-theme="dark"] .vk-url-input{background:var(--bg2)}

/* Messages */
.vk-msg{padding:10px 14px;border-radius:10px;font-size:13.5px;font-weight:500}
.vk-msg-error{background:rgba(232,93,93,0.12);color:#c0392b;border:1px solid rgba(232,93,93,0.25)}
.vk-msg-info{background:rgba(0,119,255,0.1);color:#0077FF;border:1px solid rgba(0,119,255,0.2);display:flex;align-items:center;gap:8px}
[data-theme="dark"] .vk-msg-error{color:#e87c7c}
[data-theme="dark"] .vk-msg-info{color:#4da9ff}

/* Spinner */
.vk-spinner{display:inline-block;width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:vk-spin .7s linear infinite;flex-shrink:0}
@keyframes vk-spin{to{transform:rotate(360deg)}}

/* Auth button */
.vk-btn-auth{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 20px;background:#0077FF;color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:700;font-family:var(--font);cursor:pointer;transition:.2s}
.vk-btn-auth:hover{background:#0065da;transform:translateY(-1px)}
.vk-btn-auth:active{transform:none}

/* Auth badge */
.vk-auth-badge{display:flex;align-items:center;gap:12px;background:rgba(0,119,255,0.1);border:1px solid rgba(0,119,255,0.2);border-radius:14px;padding:10px 14px}
.vk-auth-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;display:none}
.vk-auth-label{font-size:13px;color:var(--text2);display:block;line-height:1.2}
.vk-auth-badge strong{font-size:15px;color:var(--text);font-family:var(--font)}
.vk-logout-btn{margin-left:auto;background:rgba(0,0,0,0.06);border:none;border-radius:8px;padding:4px 9px;font-size:14px;color:var(--text2);cursor:pointer;transition:.15s;flex-shrink:0}
.vk-logout-btn:hover{background:rgba(232,93,93,0.15);color:#e85d5d}

/* Post card */
.vk-post-card{display:flex;align-items:center;gap:14px;background:var(--bg2,#f8f7ff);border:1px solid var(--border);border-radius:14px;padding:14px 16px}
[data-theme="dark"] .vk-post-card{background:var(--bg3)}
.vk-group-avatar{width:48px;height:48px;border-radius:12px;object-fit:cover;flex-shrink:0;display:none}
.vk-post-info{display:flex;flex-direction:column;gap:6px;min-width:0}
.vk-group-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.3;word-break:break-word}
.vk-post-stats{display:flex;gap:16px;flex-wrap:wrap}
.vk-stat{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:600;color:var(--text2)}
.vk-stat svg{width:16px;height:16px;flex-shrink:0}
.vk-stat-likes span{color:#e85d5d}
.vk-stat-comments span{color:#2687fb}
.vk-stat-reposts span{color:#27ae60}

/* Criteria */
.vk-criteria-label{font-size:16px;font-weight:700;color:var(--text);text-align:center}
.vk-criteria-btns{display:flex;gap:8px;flex-wrap:wrap}
.vk-criteria-btn{flex:1;min-width:90px;padding:11px 8px;border:2px solid var(--border);background:var(--bg);color:var(--text2);border-radius:12px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:.2s}
.vk-criteria-btn:hover{border-color:#0077FF;color:#0077FF}
.vk-criteria-btn.active{background:#0077FF;border-color:#0077FF;color:#fff}
[data-theme="dark"] .vk-criteria-btn{background:var(--bg2)}

/* Count */
.vk-count-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.vk-count-row .vk-label{margin:0;white-space:nowrap}
.vk-count-input{width:80px;padding:10px 12px;border:2px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:17px;font-weight:700;text-align:center;font-family:var(--font-mono);outline:none;transition:.2s}
.vk-count-input:focus{border-color:#0077FF}
[data-theme="dark"] .vk-count-input{background:var(--bg2)}

/* Pick button */
.vk-pick-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px 20px;background:linear-gradient(135deg,#0077FF 0%,#0055cc 100%);color:#fff;border:none;border-radius:16px;font-size:17px;font-weight:700;font-family:var(--font);cursor:pointer;transition:.2s;box-shadow:0 4px 18px rgba(0,119,255,0.35)}
.vk-pick-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,119,255,0.45)}
.vk-pick-btn:disabled{opacity:.6;cursor:default;transform:none}

/* Loading */
.vk-loading{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text2);padding:4px 0}

/* ── Results ── */
.vk-results{max-width:1100px;margin:24px auto 0;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:18px}
.vk-results-title{font-family:var(--font);font-size:26px;font-weight:800;color:var(--text);margin:0;text-align:center}

.vk-results-group{display:flex;flex-direction:column;align-items:center;gap:10px}
.vk-res-group-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid rgba(0,119,255,0.3);display:block}
.vk-results-stats{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;font-size:15px;font-weight:600;color:var(--text2)}
.vk-results-stats span{display:flex;align-items:center;gap:4px}
.vk-total-label{color:var(--accent);font-weight:700}

/* Roulette */
.vk-roulette{width:100%;overflow:hidden;height:44px;background:var(--bg2,#f3f0ff);border-radius:12px;position:relative;border:1px solid var(--border)}
.vk-roulette::before,.vk-roulette::after{content:'';position:absolute;top:0;bottom:0;width:40px;z-index:2;pointer-events:none}
.vk-roulette::before{left:0;background:linear-gradient(to right,var(--bg,#fff),transparent)}
.vk-roulette::after{right:0;background:linear-gradient(to left,var(--bg,#fff),transparent)}
.vk-roulette-inner{display:flex;align-items:center;gap:0;white-space:nowrap;will-change:transform}
.vk-roulette-inner span{display:inline-block;padding:0 20px;font-size:16px;font-weight:700;color:var(--text);line-height:44px;flex-shrink:0}
.vk-roulette-run{animation:vk-roulette-scroll 2s cubic-bezier(.16,1,.3,1) forwards}
@keyframes vk-roulette-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-80%)}
}

/* Winners grid */
.vk-winners-grid{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;width:100%}
.vk-winner-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 20px;background:var(--bg2,#f8f7ff);border:1px solid var(--border);border-radius:16px;min-width:130px;flex:1;max-width:180px}
[data-theme="dark"] .vk-winner-card{background:var(--bg3)}
.vk-winner-avatar-wrap{position:relative;display:inline-block}
.vk-winner-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid #0077FF}
.vk-winner-avatar-placeholder{width:72px;height:72px;border-radius:50%;background:var(--bg3,#e8e5ff);display:flex;align-items:center;justify-content:center;font-size:28px;border:3px solid #0077FF}
.vk-winner-badge{position:absolute;bottom:-4px;right:-4px;background:#0077FF;color:#fff;font-size:12px;font-weight:800;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg)}
.vk-winner-name{font-size:14px;font-weight:700;color:var(--text);text-align:center;word-break:break-word}
.vk-winner-link{font-size:12px;color:#0077FF;text-decoration:none;font-weight:600;border-bottom:1px solid rgba(0,119,255,0.3);transition:.15s}
.vk-winner-link:hover{border-bottom-color:#0077FF}

/* Result time */
.vk-result-time{font-size:13px;color:var(--text2);text-align:center}

/* Retry */
.vk-retry-btn{padding:11px 28px;background:var(--bg2,#f3f0ff);border:1.5px solid var(--border);border-radius:12px;font-size:14px;font-weight:600;color:var(--text2);cursor:pointer;font-family:var(--font);transition:.2s}
.vk-retry-btn:hover{background:var(--surface-hover);color:var(--text)}

/* Mobile */
@media(max-width:640px){
  .vk-logo-text{font-size:21px}
  .vk-criteria-btns{flex-direction:column}
  .vk-criteria-btn{width:100%}
  .vk-count-row{flex-direction:column;align-items:flex-start;gap:8px}
  .vk-winner-card{max-width:160px}
  .vk-results{padding:20px 16px}
}

/* ═══════════════════════════════════════════════════════
   VK WINNER SERVICE
   ═══════════════════════════════════════════════════════ */

/* Brand row */
.vk-brand-row{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:24px}
.vk-brand-svg{width:38px;height:38px;flex-shrink:0}
.vk-brand-text{font-size:21px;font-weight:800;color:var(--text);letter-spacing:-.3px;font-family:var(--font)}

/* Messages */
.vk-err{padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;background:rgba(220,38,38,0.08);color:#b91c1c;border:1px solid rgba(220,38,38,0.2)}
.vk-info{padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;background:rgba(124,58,237,0.08);color:var(--accent);border:1px solid rgba(124,58,237,0.2);display:flex;align-items:center;gap:8px}
[data-theme="dark"] .vk-err{color:#f87171}
[data-theme="dark"] .vk-info{color:var(--accent2)}

/* Spinner */
.vk-spinner{display:inline-block;width:15px;height:15px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:vk-spin .7s linear infinite;flex-shrink:0}
@keyframes vk-spin{to{transform:rotate(360deg)}}

/* Loading */
.vk-loading{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text2);justify-content:center}

/* Auth badge */
.vk-auth-badge{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:14px}
.vk-auth-ava{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0;display:none}
.vk-auth-info{display:flex;flex-direction:column;min-width:0}
.vk-auth-who{font-size:11px;color:var(--text2)}
.vk-auth-name{font-size:14px;font-weight:700;color:var(--text)}
.vk-logout{margin-left:auto;background:transparent;border:none;color:var(--text2);cursor:pointer;font-size:16px;line-height:1;opacity:.5;transition:.15s;flex-shrink:0;padding:2px 6px;border-radius:6px}
.vk-logout:hover{opacity:1;background:rgba(220,38,38,0.1);color:#b91c1c}

/* Post stats */
.vk-post-stats-row{display:flex;flex-direction:column;gap:4px}
.vk-post-group{font-size:14px;font-weight:700;color:var(--text)}
.vk-post-nums{display:flex;gap:14px;font-size:13px;font-weight:600;color:var(--text2)}

/* Winner avatar in result block */
.vk-winner-ava{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--accent2);display:block;margin:12px auto 0}

/* Multi-winner grid */
.vk-multi-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:12px}
.vk-wmini{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;min-width:100px}
.vk-wmini img,.vk-wmini-ph{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--accent2)}
.vk-wmini-ph{background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:22px}
.vk-wmini-num{font-size:11px;color:var(--text2);font-weight:600}
.vk-wmini-name{font-size:13px;font-weight:700;color:var(--text);text-align:center}
.vk-wmini a{font-size:12px;color:var(--accent);text-decoration:none;font-weight:600}
.vk-wmini a:hover{color:var(--accent2)}

/* Roulette */
.vk-roulette{width:100%;overflow:hidden;height:48px;background:var(--surface);border-radius:12px;position:relative;border:1px solid var(--border)}
.vk-roulette::before,.vk-roulette::after{content:'';position:absolute;top:0;bottom:0;width:40px;z-index:2;pointer-events:none}
.vk-roulette::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.vk-roulette::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.vk-roulette-inner{display:flex;align-items:center;white-space:nowrap}
.vk-roulette-inner span{display:inline-block;padding:0 20px;font-size:17px;font-weight:700;color:var(--text);line-height:48px;flex-shrink:0}
.vk-roulette-run{animation:vk-roulette-scroll 2s cubic-bezier(.16,1,.3,1) forwards}
@keyframes vk-roulette-scroll{0%{transform:translateX(0)}100%{transform:translateX(-80%)}}

/* Result time */
.vk-result-time{font-size:12px;color:var(--text2);text-align:center;margin-top:6px}

/* Light theme overrides */
[data-theme="light"] .vk-auth-badge{background:var(--bg2)}
[data-theme="light"] .vk-wmini{background:white;box-shadow:0 1px 4px rgba(0,0,0,0.05)}

/* Mobile */
@media(max-width:480px){
  .vk-brand-text{font-size:18px}
  .vk-multi-grid{gap:8px}
  .vk-wmini{min-width:80px;padding:8px 10px}
}


/* ── Instagram Winner ─────────────────────────────────────── */
:root { --ig-grad: linear-gradient(45deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%); }

.ig-brand-row { display:flex;align-items:center;justify-content:center;gap:12px;padding:18px 0 10px;border-bottom:1px solid var(--border,#e8e8f0);margin-bottom:4px; }
.ig-brand-svg { width:44px;height:44px;border-radius:11px; }
.ig-brand-text { font-size:1.35rem;font-weight:700;letter-spacing:-.5px;color:var(--text,#1a1a2e); }

.ig-btn-auth { display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border:none;border-radius:12px;background:var(--ig-grad);color:#fff;font-size:.95rem;font-weight:700;letter-spacing:.3px;cursor:pointer;transition:opacity .2s; }
.ig-btn-auth:hover { opacity:.88; }

.ig-auth-badge { display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--card-bg,#f8f8fc);border-radius:12px;border:1px solid var(--border,#e8e8f0); }
.ig-auth-ava { width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid transparent;background:var(--ig-grad);background-clip:border-box; }
.ig-auth-info { display:flex;flex-direction:column;gap:2px; }
.ig-auth-who { font-size:.72rem;color:var(--text-muted,#888);text-transform:uppercase;letter-spacing:.5px; }
.ig-auth-name { font-size:.95rem;font-weight:700;color:var(--text,#1a1a2e); }

.ig-post-preview { display:flex;align-items:center;gap:14px;padding:10px 14px;background:var(--card-bg,#f8f8fc);border-radius:12px;border:1px solid var(--border,#e8e8f0); }
.ig-post-thumb { width:68px;height:68px;object-fit:cover;border-radius:10px;flex-shrink:0; }
.ig-post-meta { display:flex;flex-direction:column;gap:4px; }
.ig-post-date { font-size:.8rem;color:var(--text-muted,#888); }
.ig-post-nums { font-size:.9rem;color:var(--text,#1a1a2e);font-weight:600; }
.ig-post-nums span { margin-right:12px; }

.ig-spinner { display:inline-block;width:14px;height:14px;border:2px solid #d6249f44;border-top-color:#d6249f;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:6px; }
.ig-err { color:#e03;font-size:.84rem;margin-top:6px;padding:8px 12px;background:#fff0f0;border-radius:8px;border-left:3px solid #e03; }
.ig-info { color:var(--text-muted,#888);font-size:.84rem;margin-top:6px; }

.ig-profile-link { display:inline-block;margin-top:10px;padding:9px 22px;border-radius:10px;background:var(--ig-grad);color:#fff;font-weight:700;font-size:.88rem;text-decoration:none;transition:opacity .2s; }
.ig-profile-link:hover { opacity:.85; }

.ig-winner-comment { font-size:.88rem;color:var(--text-muted,#888);font-style:italic;max-width:340px;margin:8px auto 0;line-height:1.5; }

/* Instagram "Похожие генераторы" related block (mirrors .rel-card) */
.similar-generators{margin-top:8px}
.similar-generators h2{font-family:var(--font);font-weight:700;font-size:22px;margin:40px 0 20px;color:var(--text)}
.similar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.sim-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:20px;border-radius:16px;border:1px solid var(--border);background:var(--surface);text-decoration:none;color:inherit;transition:.2s}
.sim-card:hover{border-color:rgba(124,58,237,0.4);background:rgba(124,58,237,0.1);transform:translateY(-3px)}
.sim-icon{font-size:26px;line-height:1}
.sim-title{font-weight:600;font-size:13px;color:var(--text)}
@media(max-width:900px){.similar-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.similar-grid{grid-template-columns:1fr}}

/* === relocated inline styles (perf) === */
/* moved from service.html.twig */
/* ── 3D dice arena ── */
    .dice-arena{display:flex;flex-wrap:wrap;gap:32px;justify-content:center;padding:36px 0 44px;min-height:220px;align-items:center}
    .die-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}
    .die-label{font-size:11px;font-weight:700;color:var(--text2,#64748b);text-transform:uppercase;letter-spacing:1px}
    /* 3D cube (D6 only) */
    .die3d-scene{width:160px;height:160px;perspective:520px}
    .die3d-cube{width:160px;height:160px;position:relative;transform-style:preserve-3d;
      transform:rotateX(-22deg) rotateY(28deg);
      transition:transform .92s cubic-bezier(.25,.46,.45,.94)}
    .die3d-face{position:absolute;width:160px;height:160px;
      background:linear-gradient(145deg,#f5f3ff,#ede9fe);
      border:2px solid rgba(109,40,217,.22);border-radius:26px;
      box-shadow:inset 0 2px 6px rgba(255,255,255,.9),inset 0 -3px 8px rgba(0,0,0,.09),0 0 0 1px rgba(109,40,217,.08);
      display:flex;flex-direction:column;justify-content:space-around;padding:20px;box-sizing:border-box}
    [data-theme="dark"] .die3d-face{background:linear-gradient(145deg,#2e1f4e,#1e153a);border-color:rgba(167,139,250,.3);box-shadow:inset 0 2px 6px rgba(255,255,255,.06),inset 0 -3px 8px rgba(0,0,0,.3)}
    .die3d-face.face-front {transform:translateZ(80px)}
    .die3d-face.face-back  {transform:rotateY(180deg) translateZ(80px)}
    .die3d-face.face-right {transform:rotateY(90deg)  translateZ(80px)}
    .die3d-face.face-left  {transform:rotateY(-90deg) translateZ(80px)}
    .die3d-face.face-top   {transform:rotateX(90deg)  translateZ(80px)}
    .die3d-face.face-bottom{transform:rotateX(-90deg) translateZ(80px)}
    .pip-row{display:flex;justify-content:space-between;align-items:center;flex:1}
    .pip{width:22px;height:22px;border-radius:50%;flex-shrink:0;
      background:radial-gradient(circle at 35% 32%,#a78bfa,#6d28d9);
      box-shadow:0 2px 5px rgba(109,40,217,.5),inset 0 1px 2px rgba(255,255,255,.25)}
    [data-theme="dark"] .pip{background:radial-gradient(circle at 35% 32%,#c4b5fd,#7c3aed)}
    .pip.inv{visibility:hidden}
    /* non-D6 dice (flat, improved) */
    .die-box{width:150px;height:150px;border-radius:20px;background:var(--surface,#f8f6ff);border:2px solid var(--border,rgba(124,58,237,.2));display:flex;align-items:center;justify-content:center;font-size:56px;font-weight:800;box-shadow:0 8px 28px rgba(0,0,0,.14),inset 0 -3px 7px rgba(0,0,0,.07);color:var(--text,#0f172a);transition:transform .1s}
    .die-box.d4{clip-path:polygon(50% 4%,96% 96%,4% 96%);border-radius:4px;font-size:38px}
    .die-box.d8,.die-box.d12{border-radius:50%;font-size:44px}
    .die-box.d20{clip-path:polygon(50% 2%,98% 38%,82% 98%,18% 98%,2% 38%);border-radius:4px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;border:none;font-size:40px}
    .die-box.d100{background:linear-gradient(135deg,#00b894,#55efc4);color:#fff;border:none;font-size:34px;border-radius:50%}
    .die-box.rolling2d{animation:diceRoll2d .9s cubic-bezier(.36,.07,.19,.97) both}
    @keyframes diceRoll2d{0%{transform:rotate(0) scale(1)}20%{transform:rotate(180deg) scale(.82)}50%{transform:rotate(540deg) scale(1.1)}80%{transform:rotate(900deg) scale(.94)}100%{transform:rotate(1080deg) scale(1)}}

/* moved from service.html.twig */
.coin-arena{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;padding:28px 0;min-height:120px;align-items:center}
    .coin-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}
    .coin{width:132px;height:132px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:52px;font-weight:900;background:radial-gradient(circle at 35% 35%,#ffe066,#f6b800 60%,#c88700);border:5px solid #e6a800;box-shadow:0 6px 26px rgba(230,168,0,.38),inset 0 -5px 10px rgba(0,0,0,.12),inset 0 5px 10px rgba(255,255,200,.3);cursor:default;color:#7a5200;text-shadow:0 1px 2px rgba(255,255,255,.4)}
    .coin.tails{background:radial-gradient(circle at 35% 35%,#e0e0e0,#b0b0b0 60%,#888);border-color:#aaa;color:#444;box-shadow:0 4px 18px rgba(0,0,0,.2),inset 0 -4px 8px rgba(0,0,0,.12)}
    .coin.flipping{animation:coinFlip .9s cubic-bezier(.36,.07,.19,.97) both}
    @keyframes coinFlip{0%{transform:rotateY(0) scale(1)}25%{transform:rotateY(360deg) scale(.85)}50%{transform:rotateY(720deg) scale(1.05)}75%{transform:rotateY(1080deg) scale(.92)}100%{transform:rotateY(1440deg) scale(1)}}
    .coin-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}

/* moved from service.html.twig */
.card-deck{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:24px 0;min-height:140px;align-items:center;perspective:1000px}
    .playing-card{width:96px;height:144px;position:relative;cursor:default;flex-shrink:0}
    .card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .7s ease}
    .playing-card.flipping .card-inner{animation:cardFlipAnim .8s ease-out both}
    @keyframes cardFlipAnim{0%{transform:rotateY(0)}30%{transform:rotateY(90deg) scaleX(.9)}60%{transform:rotateY(180deg)}80%{transform:rotateY(360deg) scaleX(1.03)}100%{transform:rotateY(360deg) scaleX(1)}}
    .card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 3px 14px rgba(0,0,0,.22)}
    .card-front{background:#fff;border:2px solid #ddd;padding:6px;justify-content:space-between}
    .card-back{background:linear-gradient(135deg,#1a237e 25%,#283593 50%,#1a237e 75%);display:flex;align-items:center;justify-content:center;font-size:40px}
    .card-corner{display:flex;flex-direction:column;align-items:center;line-height:1.1}
    .card-corner-bottom{transform:rotate(180deg);align-self:flex-end}
    .card-val{font-size:19px;font-weight:800}
    .card-suit-sm{font-size:16px}
    .card-center{font-size:42px;text-align:center;flex:1;display:flex;align-items:center;justify-content:center}
    .red-card .card-val,.red-card .card-suit-sm,.red-card .card-center{color:#d32f2f}
    .black-card .card-val,.black-card .card-suit-sm,.black-card .card-center{color:#1a1a1a}
    .joker-card .card-front{background:linear-gradient(135deg,#fffde7,#fff176)}
    .tarot-card .card-front{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e0c97b}
    .tarot-card .card-val,.tarot-card .card-suit-sm{color:#e0c97b;font-size:9px}
    .tarot-card .card-center{font-size:20px;color:#e0c97b}

/* moved from service.html.twig */
.oracle-scene{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 0 20px;user-select:none}
.oracle-ball{
  width:148px;height:148px;border-radius:50%;position:relative;cursor:default;
  background:radial-gradient(circle at 38% 32%,
    #d4aaff 0%,#8b46f5 20%,#3d1580 45%,#100435 75%,#04001a 100%);
  box-shadow:
    0 0 0 1px rgba(180,100,255,.2),
    0 0 22px rgba(140,70,255,.7),
    0 0 55px rgba(110,45,220,.45),
    0 0 90px rgba(80,20,180,.25),
    inset 0 0 35px rgba(160,100,255,.12);
  animation:oracle-float 3.6s ease-in-out infinite;
  transform-origin:center center;
}
.oracle-glare{
  position:absolute;top:11%;left:17%;width:40%;height:27%;
  background:radial-gradient(ellipse at 40% 40%,rgba(255,255,255,.6) 0%,transparent 68%);
  border-radius:50%;pointer-events:none;
}
.oracle-glare2{
  position:absolute;bottom:18%;right:15%;width:18%;height:12%;
  background:radial-gradient(ellipse,rgba(255,255,255,.2) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.oracle-mist{
  position:absolute;inset:10px;border-radius:50%;
  background:conic-gradient(from 0deg,
    transparent 0%,rgba(170,90,255,.07) 20%,
    transparent 45%,rgba(170,90,255,.07) 70%,transparent 100%);
  animation:oracle-spin 9s linear infinite;
}
.oracle-mist2{
  position:absolute;inset:20px;border-radius:50%;
  background:conic-gradient(from 90deg,
    transparent 0%,rgba(130,60,220,.06) 30%,
    transparent 60%,rgba(130,60,220,.06) 85%,transparent 100%);
  animation:oracle-spin 14s linear infinite reverse;
}
.oracle-symbol{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.oracle-eye{
  font-size:72px;line-height:1;
  animation:oracle-blink 5s ease-in-out infinite;
  filter:drop-shadow(0 0 18px rgba(255,200,255,1)) drop-shadow(0 0 40px rgba(200,120,255,.8));
}
.oracle-shadow{
  width:96px;height:14px;margin-top:-2px;
  background:radial-gradient(ellipse,rgba(110,45,200,.45) 0%,transparent 70%);
  border-radius:50%;
  animation:oracle-shadow-pulse 3.6s ease-in-out infinite;
}
@keyframes oracle-float{
  0%,100%{transform:translateY(0) rotateX(8deg) rotateY(0deg)}
  50%    {transform:translateY(-15px) rotateX(8deg) rotateY(10deg)}
}
@keyframes oracle-shadow-pulse{
  0%,100%{transform:scaleX(1);opacity:.6}
  50%    {transform:scaleX(.72);opacity:.28}
}
@keyframes oracle-spin{
  from{transform:rotate(0deg)}to{transform:rotate(360deg)}
}
@keyframes oracle-pulse{
  0%,100%{opacity:.65;filter:drop-shadow(0 0 7px rgba(210,170,255,.7))}
  50%    {opacity:1;  filter:drop-shadow(0 0 16px rgba(230,200,255,1))}
}
@keyframes oracle-blink{
  0%,88%,100%{transform:scaleY(1)}
  93%        {transform:scaleY(.08)}
}
@keyframes oracle-spin2{
  0%  {transform:rotateX(8deg) rotateY(0deg)}
  100%{transform:rotateX(8deg) rotateY(720deg)}
}
.oracle-ball.spinning{animation:oracle-spin2 1.6s ease-out}

/* moved from index.html.twig */
.ig-pro-note{margin:0 0 12px;padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:var(--surface);font-size:13px;line-height:1.55;color:var(--text2);text-align:left}
      .ig-pro-note b{color:var(--text)}
      .ig-pro-note ol{margin:8px 0 6px;padding-left:20px}
      .ig-pro-note li{margin:3px 0}

/* moved from index.html.twig */
.vk-paste-block{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.vk-paste-hint{font-size:13px;line-height:1.45;opacity:.85}
.vk-paste-hint code{font-size:12px;word-break:break-all}
.vk-paste-confirm{align-self:flex-start;padding:9px 16px;border:none;border-radius:10px;background:#0077FF;color:#fff;font-weight:600;cursor:pointer}
.vk-paste-confirm:hover{background:#0066dd}

/* === utility classes (ex-inline) === */
.u-w100{width:100%}
.u-pt64{padding-top:64px}
.u-pt0{padding-top:0}
.u-ctext{color:var(--text)}
.u-mt0{margin-top:0}
.u-mt12{margin-top:12px}
.u-mt14{margin-top:14px}
.u-mt20{margin-top:20px}
.u-h20{height:20px}
.u-resize-v{resize:vertical;min-height:80px}
.u-minh90{min-height:90px}
.u-note{font-size:14px;color:var(--text-secondary)}
.u-w120mt6{width:120px;margin-top:6px}
.u-footer-icon{width:32px;height:32px;font-size:13px}

/* === Back to top button === */
.back-top{position:fixed;bottom:28px;right:28px;width:44px;height:44px;border-radius:50%;background:var(--accent2);color:#fff;border:none;cursor:pointer;font-size:18px;line-height:1;display:none;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(124,58,237,.35);z-index:200;transition:opacity .2s,transform .2s}
.back-top.visible{display:flex}
.back-top:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(124,58,237,.5)}
@media(max-width:600px){.back-top{bottom:16px;right:16px;width:38px;height:38px;font-size:15px}}

/* === Star rating widget === */
.rating-widget{max-width:1100px;margin:24px auto;padding:0 40px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.rating-label{color:var(--text2);font-size:14px;font-weight:500}
.rating-stars{display:flex;gap:4px;cursor:pointer}
.rating-star{font-size:26px;color:#d1d5db;transition:color .15s;line-height:1;user-select:none}
.rating-star.lit,.rating-star:hover,.rating-stars:hover .rating-star{color:#f59e0b}
.rating-stars:hover .rating-star~.rating-star{color:#d1d5db}
.rating-star:hover~.rating-star{color:#d1d5db!important}
.rating-done{font-size:14px;color:var(--accent2);font-weight:600}
@media(max-width:600px){.rating-widget{padding:0 16px;gap:10px}.rating-star{font-size:22px}}

/* === Articles section === */
.articles-page .static-hero{padding:48px 40px 32px;text-align:center}
.articles-grid{max-width:1100px;margin:0 auto;padding:0 40px 64px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.article-card{display:flex;gap:14px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:16px;text-decoration:none;color:var(--text);transition:.2s;align-items:flex-start}
.article-card:hover{border-color:var(--accent2);transform:translateY(-2px);box-shadow:0 4px 20px rgba(124,58,237,.12)}
.article-card-icon{font-size:28px;flex-shrink:0;line-height:1}
.article-card-body{flex:1;min-width:0}
.article-card-cat{font-size:11px;font-weight:600;color:var(--accent2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.article-card-title{font-size:15px;font-weight:600;line-height:1.4;margin:0 0 8px;color:var(--text)}
.article-card-excerpt{font-size:13px;color:var(--text2);line-height:1.5;margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.article-card-meta{display:flex;gap:12px;font-size:12px;color:var(--text2)}

/* Article single */
.article-single{max-width:800px;margin:0 auto;padding:0 40px 64px}
.article-single-header{padding:40px 0 32px;border-bottom:1px solid var(--border);margin-bottom:32px}
.article-single-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text2);margin-bottom:16px}
.article-single-cat{background:var(--accent2);color:#fff;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.article-single-lead{font-size:18px;color:var(--text2);line-height:1.6;margin:12px 0 0}
.article-content h2{font-size:20px;font-weight:700;margin:32px 0 14px;color:var(--text)}
.article-content h3{font-size:16px;font-weight:600;margin:24px 0 10px;color:var(--text)}
.article-content p{line-height:1.7;color:var(--text2);margin:0 0 16px}
.article-content ul,.article-content ol{padding-left:20px;margin:0 0 16px;color:var(--text2);line-height:1.7}
.article-content li{margin-bottom:6px}
.article-cta-box{margin:40px 0;padding:28px;background:linear-gradient(135deg,rgba(124,58,237,.08),rgba(168,85,247,.08));border:1px solid rgba(124,58,237,.2);border-radius:16px;text-align:center}
.article-cta-text{font-size:15px;color:var(--text2);margin-bottom:14px}
.article-cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent2);color:#fff;padding:12px 28px;border-radius:12px;text-decoration:none;font-weight:600;font-size:15px;transition:.2s}
.article-cta-btn:hover{background:var(--accent);transform:translateY(-2px)}
.article-nav{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.article-nav-back{color:var(--accent2);text-decoration:none;font-size:14px;font-weight:500}
.article-nav-back:hover{color:var(--accent)}
@media(max-width:768px){.articles-grid{grid-template-columns:1fr;padding:0 16px 48px}.article-single{padding:0 16px 48px}.articles-page .static-hero{padding:32px 16px 24px}}

/* === Rating pill badge in meta-tags === */
.meta-tag--rating{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.35);color:#b45309;font-weight:600}
[data-theme='dark'] .meta-tag--rating{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.3);color:#fbbf24}
