/* ==============================================
   TYZ Media — Main Stylesheet
   Theme: Night Blue / Neon Electric
   ============================================== */

:root {
  --color-bg:           #020818;
  --color-bg2:          #040f24;
  --color-surface:      #071330;
  --color-surface2:     #0c1e45;
  --color-border:       #1a3060;
  --color-border2:      #234080;
  --color-accent:       #0ea5e9;
  --color-accent2:      #38bdf8;
  --color-accent3:      #7dd3fc;
  --color-accent-glow:  rgba(14, 165, 233, 0.25);
  --color-accent-glow2: rgba(14, 165, 233, 0.08);
  --color-neon-purple:  #a855f7;
  --color-neon-cyan:    #06b6d4;
  --color-neon-green:   #10b981;
  --color-text:   #e2eaf8;
  --color-text2:  #8ba4cc;
  --color-text3:  #4a6690;
  --color-success: #10b981;
  --color-danger:  #ef4444;
  --color-warning: #f59e0b;
  --color-info:    #0ea5e9;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --radius:    12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --shadow:    0 4px 24px rgba(0,0,0,0.6);
  --shadow-lg: 0 8px 48px rgba(0,0,0,0.8);
  --shadow-neon: 0 0 20px rgba(14,165,233,0.4), 0 0 60px rgba(14,165,233,0.15);
  --transition: 0.2s cubic-bezier(0.4,0,0.2,1);
  --nav-height: 64px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-sans);
  background:var(--color-bg);
  color:var(--color-text);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
  background-image:
    radial-gradient(ellipse at 20% 20%,rgba(14,165,233,.05) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 80%,rgba(168,85,247,.04) 0%,transparent 60%);
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--color-accent2);text-decoration:none;transition:color var(--transition);}
a:hover{color:var(--color-accent3);}

::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--color-bg);}
::-webkit-scrollbar-thumb{background:var(--color-border2);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--color-accent);}

h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25;}
h1{font-size:clamp(2rem,5vw,3.5rem);}
h2{font-size:clamp(1.5rem,3vw,2.25rem);}
h3{font-size:clamp(1.2rem,2vw,1.5rem);}
p{color:var(--color-text2);}

.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.section{padding:80px 0;}
.section-title{
  font-size:clamp(1.6rem,3vw,2.5rem);
  background:linear-gradient(135deg,var(--color-text) 30%,var(--color-accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:12px;
}
.section-subtitle{color:var(--color-text2);margin-bottom:48px;font-size:1.05rem;}

/* ─── Page Loader ─── */
#page-loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--color-bg);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;
  transition:opacity .35s ease,visibility .35s ease;
}
#page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loader-ring{
  width:52px;height:52px;
  border:3px solid var(--color-surface2);
  border-top-color:var(--color-accent);
  border-radius:50%;
  animation:spin .8s linear infinite;
}
.loader-brand{font-size:.8rem;font-weight:600;color:var(--color-text3);letter-spacing:.12em;text-transform:uppercase;}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.85);}}

/* ─── Neon Keyframes ─── */
@keyframes neon-pulse{
  0%,100%{box-shadow:0 0 8px rgba(14,165,233,.5),0 4px 20px rgba(14,165,233,.3);}
  50%{box-shadow:0 0 22px rgba(14,165,233,.9),0 4px 44px rgba(14,165,233,.5),0 0 80px rgba(14,165,233,.12);}
}
@keyframes neon-pulse-purple{
  0%,100%{box-shadow:0 0 8px rgba(168,85,247,.5),0 4px 20px rgba(168,85,247,.3);}
  50%{box-shadow:0 0 22px rgba(168,85,247,.9),0 4px 44px rgba(168,85,247,.5);}
}

/* ─── Navigation ─── */
.navbar{
  position:fixed;top:0;left:0;right:0;height:var(--nav-height);z-index:1000;
  background:rgba(2,8,24,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--color-border);
  box-shadow:0 1px 0 rgba(14,165,233,.1);
  overflow:visible;
}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;}
.nav-brand{
  font-size:1.4rem;font-weight:800;
  color:#fff;
  letter-spacing:-.02em;
  display:flex;align-items:center;gap:8px;
  line-height:1;
}
.nav-links{display:flex;gap:4px;align-items:center;}
.nav-link{padding:8px 14px;border-radius:10px;font-size:.9rem;font-weight:500;color:var(--color-text2);transition:all var(--transition);}
.nav-link:hover,.nav-link.active{color:var(--color-text);background:var(--color-surface2);}
.nav-link.active{color:var(--color-accent2);border-bottom:2px solid var(--color-accent);}
.nav-actions{display:flex;gap:8px;align-items:center;}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;}
.hamburger span{width:24px;height:2px;background:var(--color-text);border-radius:2px;transition:all var(--transition);}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-menu{
  display:none;position:fixed;top:var(--nav-height);left:0;right:0;
  background:rgba(2,8,24,.97);border-bottom:1px solid var(--color-border);
  flex-direction:column;padding:12px;z-index:999;
}
.mobile-menu.open{display:flex;}
.mobile-nav-link{padding:12px 16px;border-radius:var(--radius);color:var(--color-text2);font-weight:500;transition:all var(--transition);}
.mobile-nav-link:hover{color:var(--color-text);background:var(--color-surface2);}
.mobile-divider{height:1px;background:var(--color-border);margin:4px 0;}

/* ─── Buttons ─── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 22px;border-radius:var(--radius);border:none;
  font-weight:600;font-size:.9rem;cursor:pointer;
  transition:all var(--transition);text-decoration:none;
  white-space:nowrap;font-family:var(--font-sans);position:relative;overflow:hidden;
}
.btn:disabled,.btn.btn-loading{opacity:.7;cursor:not-allowed;}
.btn-loading::after{
  content:'';position:absolute;width:16px;height:16px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;animation:spin .6s linear infinite;right:12px;
}
.btn-primary{
  background:linear-gradient(135deg,#0369a1,var(--color-accent));color:#fff;
  animation:neon-pulse 2.5s ease-in-out infinite;
}
.btn-primary:hover{background:linear-gradient(135deg,var(--color-accent),var(--color-accent2));color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-neon);}
.btn-secondary{background:var(--color-surface2);color:var(--color-text);border:1px solid var(--color-border2);}
.btn-secondary:hover{background:var(--color-border);color:var(--color-text);border-color:var(--color-accent);box-shadow:0 0 12px rgba(14,165,233,.2);}
.btn-danger{background:var(--color-danger);color:#fff;}
.btn-danger:hover{background:#dc2626;color:#fff;box-shadow:0 0 16px rgba(239,68,68,.4);}
.btn-success{background:var(--color-success);color:#fff;}
.btn-success:hover{background:#059669;color:#fff;box-shadow:0 0 16px rgba(16,185,129,.4);}
.btn-outline{background:transparent;color:var(--color-accent2);border:1.5px solid var(--color-accent);}
.btn-outline:hover{background:var(--color-accent);color:#fff;box-shadow:var(--shadow-neon);}
.btn-neon{
  background:linear-gradient(135deg,#0c2a6b,var(--color-accent));color:#fff;
  border:1px solid var(--color-accent);animation:neon-pulse 2.5s ease-in-out infinite;
}
.btn-neon:hover{transform:translateY(-3px);box-shadow:var(--shadow-neon);color:#fff;}
.btn-neon-purple{
  background:linear-gradient(135deg,#3b0f6f,var(--color-neon-purple));color:#fff;
  border:1px solid var(--color-neon-purple);animation:neon-pulse-purple 2.5s ease-in-out infinite;
}
.btn-neon-purple:hover{transform:translateY(-3px);color:#fff;}
.btn-lg{padding:14px 36px;font-size:1.05rem;border-radius:16px;}
.btn-sm{padding:6px 14px;font-size:.8rem;border-radius:8px;}

/* ─── Cards ─── */
.card{
  background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:24px;
  transition:all var(--transition);position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(14,165,233,.03) 0%,transparent 60%);
  pointer-events:none;
}
.card:hover{border-color:var(--color-accent);box-shadow:0 0 30px rgba(14,165,233,.15);}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--color-border);}
.card-title{font-size:1.15rem;font-weight:700;margin-bottom:4px;}
.card-subtitle{color:var(--color-text2);font-size:.9rem;}

/* ─── Forms ─── */
.form-group{margin-bottom:20px;}
.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--color-text2);margin-bottom:8px;}
.form-control{
  width:100%;padding:11px 16px;background:var(--color-surface2);
  border:1.5px solid var(--color-border2);border-radius:var(--radius);
  color:var(--color-text);font-size:.9rem;font-family:var(--font-sans);
  transition:border-color var(--transition),box-shadow var(--transition);
}
.form-control:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(14,165,233,.15);}
.form-control::placeholder{color:var(--color-text3);}
textarea.form-control{resize:vertical;min-height:120px;}
.form-check{display:flex;align-items:center;gap:10px;}
.form-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer;}
.form-hint{font-size:.8rem;color:var(--color-text3);margin-top:6px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ─── Flash Messages ─── */
.flash-container{padding:16px 0;}
.alert{padding:14px 18px;border-radius:var(--radius);display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:#6ee7b7;}
.alert-danger {background:rgba(239,68,68,.1) ;border:1px solid rgba(239,68,68,.3) ;color:#fca5a5;}
.alert-warning{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:#fcd34d;}
.alert-info   {background:rgba(14,165,233,.1) ;border:1px solid rgba(14,165,233,.3) ;color:#7dd3fc;}

/* ─── Hero ─── */
.hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding-top:var(--nav-height);position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 0%,rgba(14,165,233,.12) 0%,transparent 60%),
    radial-gradient(ellipse at 20% 80%,rgba(168,85,247,.08) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 60%,rgba(6,182,212,.06) 0%,transparent 50%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(14,165,233,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(14,165,233,.04) 1px,transparent 1px);
  background-size:60px 60px;pointer-events:none;
}
.hero-content{position:relative;z-index:1;text-align:center;max-width:900px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;padding:8px 20px;
  background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.3);
  border-radius:99px;font-size:.85rem;font-weight:600;color:var(--color-accent2);
  margin-bottom:24px;letter-spacing:.02em;
}
.hero-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--color-success);animation:pulse 2s infinite;box-shadow:0 0 8px var(--color-success);}
.hero-title{margin-bottom:20px;}
.hero-title .highlight{
  background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent2) 50%,var(--color-neon-purple) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 20px rgba(14,165,233,.4));
}
.hero-desc{font-size:1.15rem;max-width:600px;margin:0 auto 40px;}

/* ─── Visitor Counter ─── */
.visitor-counter{
  display:inline-flex;align-items:center;gap:10px;padding:10px 24px;
  background:rgba(14,165,233,.07);border:1px solid rgba(14,165,233,.2);
  border-radius:99px;margin-bottom:32px;font-size:.9rem;color:var(--color-text2);
}
.visitor-counter-num{font-size:1.2rem;font-weight:800;color:var(--color-accent2);font-variant-numeric:tabular-nums;text-shadow:0 0 16px rgba(14,165,233,.5);}

/* ─── Social Buttons ─── */
.social-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:28px;}
.social-btn{
  width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;background:var(--color-surface2);border:1.5px solid var(--color-border2);
  color:var(--color-text2);transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;
}
.social-btn::before{content:'';position:absolute;inset:0;border-radius:50%;opacity:0;transition:opacity .25s;}
.social-btn:hover{transform:translateY(-4px) scale(1.12);color:#fff;border-color:transparent;}
.social-btn.instagram::before{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);}
.social-btn.instagram:hover::before{opacity:1;}
.social-btn.instagram:hover{box-shadow:0 0 20px rgba(220,39,67,.5);}
.social-btn.youtube::before{background:#ff0000;}
.social-btn.youtube:hover::before{opacity:1;}
.social-btn.youtube:hover{box-shadow:0 0 20px rgba(255,0,0,.5);}
.social-btn.discord::before{background:#5865F2;}
.social-btn.discord:hover::before{opacity:1;}
.social-btn.discord:hover{box-shadow:0 0 20px rgba(88,101,242,.5);}
.social-btn.tiktok::before{background:linear-gradient(135deg,#010101,#69C9D0);}
.social-btn.tiktok:hover::before{opacity:1;}
.social-btn.tiktok:hover{box-shadow:0 0 20px rgba(105,201,208,.5);}
.social-btn.linkedin::before{background:#0077B5;}
.social-btn.linkedin:hover::before{opacity:1;}
.social-btn.linkedin:hover{box-shadow:0 0 20px rgba(0,119,181,.5);}
.social-btn svg,.social-btn .icon{position:relative;z-index:1;width:22px;height:22px;}

/* ─── CV Button ─── */
.cv-btn-wrapper{display:flex;justify-content:center;}
.btn-cv{
  display:inline-flex;align-items:center;gap:10px;padding:14px 36px;
  background:linear-gradient(135deg,#0c3578,var(--color-accent));color:#fff;
  border-radius:16px;font-weight:700;font-size:1rem;border:1px solid var(--color-accent);
  animation:neon-pulse 2.5s ease-in-out infinite;cursor:pointer;transition:transform var(--transition);
}
.btn-cv:hover{transform:translateY(-3px);color:#fff;box-shadow:var(--shadow-neon);}
.btn-cv.locked{background:var(--color-surface2);color:var(--color-text3);border-color:var(--color-border);animation:none;cursor:not-allowed;}
.btn-cv.locked:hover{transform:none;}

/* ─── Discord Widget ─── */
.discord-widget{
  background:linear-gradient(160deg,#0c1a4e,#1a1f6e);
  border:1px solid rgba(88,101,242,.4);border-radius:var(--radius-xl);
  max-width:480px;margin:0 auto;position:relative;overflow:hidden;
}
.discord-widget-banner{
  width:100%;height:110px;
  background:linear-gradient(135deg,#2a3896 0%,#5865F2 100%);
  background-size:cover;background-position:center top;
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  flex-shrink:0;
}
.discord-widget-body{
  padding:20px 28px 28px;position:relative;
}
.discord-widget-header{display:flex;align-items:flex-end;gap:14px;margin-bottom:20px;position:relative;}
.discord-logo{
  width:68px;height:68px;background:#5865F2;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;overflow:hidden;flex-shrink:0;
  box-shadow:0 0 20px rgba(88,101,242,.5);
  border:4px solid #0c1a4e;
  margin-top:-36px;
}
.discord-logo img{width:100%;height:100%;object-fit:cover;border-radius:14px;}
.discord-server-name{font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:1px;}
.discord-server-sub{font-size:.75rem;color:rgba(255,255,255,.5);}
.discord-stats{display:flex;gap:32px;margin-bottom:20px;position:relative;}
.discord-stat{text-align:center;}
.discord-stat-num{font-size:1.6rem;font-weight:800;color:#fff;font-variant-numeric:tabular-nums;}
.discord-stat-label{font-size:.75rem;color:rgba(255,255,255,.5);margin-top:2px;}
.discord-online-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#23a559;box-shadow:0 0 8px #23a559;animation:pulse 2s infinite;vertical-align:middle;margin-right:4px;}
.discord-join-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:12px;background:#5865F2;color:#fff;border-radius:var(--radius);font-weight:700;font-size:.95rem;
  transition:all var(--transition);position:relative;
}
.discord-join-btn:hover{background:#4752c4;color:#fff;transform:translateY(-2px);box-shadow:0 0 20px rgba(88,101,242,.5);}

/* ─── Reviews ─── */
/* Marquee strip */
.reviews-marquee-wrap{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);
  mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);
  position:relative;
}
.reviews-marquee-track{
  display:flex;gap:20px;
  animation:marqueeScroll 40s linear infinite;
  width:max-content;
}
.reviews-marquee-wrap:hover .reviews-marquee-track{animation-play-state:paused;}
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
/* Review card */
.review-card{
  min-width:270px;max-width:290px;flex-shrink:0;
  background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:20px;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.review-card:hover{border-color:var(--color-accent);box-shadow:0 0 20px rgba(14,165,233,.12);}
.review-card-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.review-avatar-letter{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:1.15rem;font-weight:800;color:#fff;
}
.review-avatar-img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.review-card-info{min-width:0;}
.review-card-name{font-weight:700;font-size:.9rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.review-card-stars{display:flex;gap:2px;margin-top:2px;}
.star-on{color:#f59e0b;}
.star-off{color:var(--color-border2);}
.review-card-comment{font-size:.85rem;color:var(--color-text2);line-height:1.55;margin-bottom:8px;}
.review-card-date{font-size:.75rem;color:var(--color-text3);}
/* Submit review form */
.review-form-wrapper{
  max-width:560px;margin:0 auto;
  background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-xl);padding:36px 32px;
}
.form-input{
  width:100%;padding:11px 16px;background:var(--color-surface2);
  border:1.5px solid var(--color-border2);border-radius:var(--radius);
  color:var(--color-text);font-size:.9rem;font-family:var(--font-sans);
  transition:border-color var(--transition),box-shadow var(--transition);
  box-sizing:border-box;
}
.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(14,165,233,.15);}
.form-input::placeholder{color:var(--color-text3);}
textarea.form-input{resize:vertical;min-height:100px;}
.star-select{display:flex;gap:6px;margin-bottom:8px;}
.star-select input{display:none;}
.star-select label{font-size:1.8rem;color:var(--color-border2);cursor:pointer;transition:color .15s,transform .15s;line-height:1;}
.star-select label:hover,.star-select label.active{color:#f59e0b;transform:scale(1.2);}
.review-char-count{font-size:.75rem;color:var(--color-text3);text-align:right;margin-top:4px;}
/* Auth-gate card */
.review-gate-card{
  max-width:420px;margin:0 auto;
  background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-xl);padding:40px 32px;text-align:center;
}
.review-gate-card p{font-size:1rem;color:var(--color-text2);margin-bottom:24px;line-height:1.6;}
/* Preset avatars */
.preset-avatar-label{
  font-size:.8rem;font-weight:600;color:var(--color-text3);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;display:block;
}
.preset-avatar-grid{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-bottom:16px;}
.preset-avatar-item{
  width:60px;height:60px;border-radius:50%;cursor:pointer;overflow:hidden;
  border:3px solid transparent;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.preset-avatar-item img{width:100%;height:100%;display:block;}
.preset-avatar-item:hover{border-color:var(--color-accent);transform:scale(1.1);}
.preset-avatar-item.selected{
  border-color:var(--color-accent);
  box-shadow:0 0 0 3px rgba(14,165,233,.35);
  transform:scale(1.08);
}

/* ─── Media Grid ─── */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.media-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition);}
.media-item:hover{transform:translateY(-4px);border-color:var(--color-accent);box-shadow:0 8px 32px rgba(14,165,233,.15);}

.media-item img{width:100%;height:200px;object-fit:cover;}
.media-item video{width:100%;height:200px;object-fit:cover;}
.media-item-body{padding:16px;}
.media-item-title{font-weight:600;margin-bottom:6px;color:var(--color-text);font-size:.95rem;}
.media-item-desc{color:var(--color-text2);font-size:.85rem;}
.media-doc-icon{height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-surface2);gap:12px;}
.media-doc-icon span{font-size:3rem;}
.media-doc-icon p{color:var(--color-text2);font-size:.85rem;}

/* ─── Social Hub Cards ─── */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;}
.hub-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;gap:10px;transition:all var(--transition);}
.hub-card:hover{border-color:var(--color-accent);box-shadow:0 0 24px rgba(14,165,233,.15);}
.hub-card-icon{font-size:2rem;}
.hub-card-category{font-size:.75rem;color:var(--color-accent2);font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:rgba(14,165,233,.1);padding:3px 10px;border-radius:99px;display:inline-block;width:fit-content;}
.hub-card-title{font-size:1rem;font-weight:700;}
.hub-card-desc{color:var(--color-text2);font-size:.875rem;flex:1;}
.hub-card-actions{display:flex;gap:8px;flex-wrap:wrap;}

/* ─── Shop ─── */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;}
.product-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition);position:relative;}
.product-card:hover{transform:translateY(-4px);border-color:var(--color-accent);box-shadow:0 8px 32px rgba(14,165,233,.2);}
.product-badge{position:absolute;top:12px;right:12px;background:var(--color-danger);color:#fff;padding:4px 10px;border-radius:99px;font-size:.75rem;font-weight:700;}
.product-image{width:100%;height:200px;object-fit:cover;}
.product-no-image{width:100%;height:200px;background:var(--color-surface2);display:flex;align-items:center;justify-content:center;font-size:3rem;}
.product-body{padding:20px;}
.product-name{font-size:1rem;font-weight:700;margin-bottom:8px;}
.product-desc{color:var(--color-text2);font-size:.875rem;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.product-price{display:flex;align-items:baseline;gap:8px;margin-bottom:16px;}
.product-price-current{font-size:1.5rem;font-weight:800;color:var(--color-accent2);}
.product-price-original{font-size:1rem;color:var(--color-text3);text-decoration:line-through;}
.product-price-label{font-size:.75rem;color:var(--color-danger);font-weight:700;}

/* ─── Privacy Box ─── */
.privacy-box{background:var(--color-surface2);border:1.5px solid var(--color-border2);border-radius:var(--radius);padding:16px;margin-bottom:16px;}
.privacy-box summary{cursor:pointer;font-weight:600;color:var(--color-accent2);font-size:.9rem;list-style:none;display:flex;align-items:center;gap:8px;}
.privacy-box[open] summary{margin-bottom:12px;}
.privacy-box .privacy-text{font-size:.82rem;color:var(--color-text2);line-height:1.7;max-height:200px;overflow-y:auto;}

/* ─── Auth ─── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:calc(var(--nav-height)+40px) 24px 40px;}
.auth-card{width:100%;max-width:440px;}
.auth-logo{text-align:center;margin-bottom:32px;}
.auth-logo a{font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,#fff,var(--color-accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.auth-title{text-align:center;margin-bottom:8px;font-size:1.5rem;}
.auth-subtitle{text-align:center;color:var(--color-text2);font-size:.9rem;margin-bottom:32px;}
.auth-divider{text-align:center;color:var(--color-text3);font-size:.85rem;margin:16px 0;position:relative;}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:calc(50% - 30px);height:1px;background:var(--color-border);}
.auth-divider::before{left:0;}.auth-divider::after{right:0;}
.auth-switch{text-align:center;margin-top:24px;color:var(--color-text2);font-size:.9rem;}

/* ─── Badge ─── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.75rem;font-weight:600;}
.badge-success{background:rgba(16,185,129,.1);color:#6ee7b7;border:1px solid rgba(16,185,129,.25);}
.badge-danger {background:rgba(239,68,68,.1) ;color:#fca5a5;border:1px solid rgba(239,68,68,.25);}
.badge-warning{background:rgba(245,158,11,.1);color:#fcd34d;border:1px solid rgba(245,158,11,.25);}
.badge-info   {background:rgba(14,165,233,.1) ;color:#7dd3fc;border:1px solid rgba(14,165,233,.25);}
.badge-accent {background:rgba(14,165,233,.1) ;color:var(--color-accent2);border:1px solid rgba(14,165,233,.25);}
.badge-neutral{background:var(--color-surface2);color:var(--color-text2);border:1px solid var(--color-border);}

/* ─── Tables ─── */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--color-border);}
table{width:100%;border-collapse:collapse;}
thead{background:var(--color-surface2);}
th{padding:14px 16px;text-align:left;font-size:.8rem;font-weight:600;color:var(--color-text2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);}
td{padding:14px 16px;font-size:.9rem;border-bottom:1px solid var(--color-border);}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(14,165,233,.04);}

/* ─── Profile ─── */
.profile-layout{display:grid;grid-template-columns:260px 1fr;gap:32px;padding-top:calc(var(--nav-height)+56px);padding-bottom:80px;}
.profile-layout>main{min-width:0;overflow:hidden;}
.profile-sidebar{min-width:0;}
.profile-sidebar>.card{position:sticky;top:calc(var(--nav-height) + 16px);}
.profile-avatar-wrap{text-align:center;margin-bottom:24px;}
.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--color-accent);box-shadow:0 0 20px rgba(14,165,233,.3);margin:0 auto 16px;display:block;}
.profile-name{font-size:1.1rem;font-weight:700;margin-bottom:4px;}
.profile-email{color:var(--color-text2);font-size:.85rem;}
.profile-nav{display:flex;flex-direction:column;gap:4px;}
.profile-nav-link{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);color:var(--color-text2);font-weight:500;font-size:.9rem;transition:all var(--transition);}
.profile-nav-link:hover,.profile-nav-link.active{background:var(--color-surface2);color:var(--color-text);}
.profile-nav-link.active{color:var(--color-accent2);border-left:3px solid var(--color-accent);}

/* ─── Admin ─── */
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh;padding-top:var(--nav-height);}
.admin-sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);padding:24px 12px;position:sticky;top:var(--nav-height);height:calc(100vh - var(--nav-height));overflow-y:auto;}
.admin-sidebar-title{font-size:.7rem;font-weight:700;color:var(--color-text3);text-transform:uppercase;letter-spacing:.1em;padding:6px 12px;margin-top:16px;margin-bottom:4px;}
.admin-sidebar-title:first-child{margin-top:0;}
.admin-nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);color:var(--color-text2);font-size:.875rem;font-weight:500;transition:all var(--transition);}
.admin-nav-link:hover,.admin-nav-link.active{background:var(--color-surface2);color:var(--color-text);}
.admin-nav-link.active{color:var(--color-accent2);border-left:3px solid var(--color-accent);}
.admin-nav-link .nav-icon{font-size:1.1rem;width:20px;text-align:center;}
.admin-main{padding:32px;overflow-x:hidden;}
.admin-page-title{font-size:1.6rem;font-weight:800;margin-bottom:8px;}
.admin-page-sub{color:var(--color-text2);font-size:.9rem;margin-bottom:32px;}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:32px;}
.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;text-align:center;transition:all var(--transition);}
.stat-card:hover{border-color:var(--color-accent);box-shadow:0 0 16px rgba(14,165,233,.1);}
.stat-number{font-size:2rem;font-weight:800;color:var(--color-accent2);}
.stat-label{color:var(--color-text2);font-size:.8rem;margin-top:4px;}

/* ─── Nav Logo ─── */
/* ─── Nav Logo ─── */
/* To change logo+text size: edit .nav-logo { height } and .nav-brand { font-size } */
.nav-logo{height:28px;width:28px;object-fit:contain;border-radius:5px;flex-shrink:0;}
.nav-brand:hover .nav-logo{opacity:.85;}

/* ─── Like Button ─── */
.like-btn{background:rgba(14,165,233,.07);border:1px solid var(--color-border);color:var(--color-text2);display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s;}
.like-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:rgba(14,165,233,.12);}
.like-btn.liked{border-color:#ef4444;color:#ef4444;background:rgba(239,68,68,.08);}
.like-btn.liked:hover{background:rgba(239,68,68,.14);}
.like-heart{font-size:1rem;line-height:1;}
.like-count{font-weight:600;}

/* ─── Cart Button ─── */
.cart-btn{background:rgba(14,165,233,.07);border:1px solid var(--color-border);color:var(--color-text2);display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s;}
.cart-btn:hover{border-color:var(--color-warning);color:var(--color-warning);background:rgba(245,158,11,.1);}
.cart-btn.in-cart{border-color:var(--color-warning);color:var(--color-warning);background:rgba(245,158,11,.1);}

/* ─── Search Toggle Button ─── */
.search-toggle-btn{background:none;border:none;cursor:pointer;color:var(--color-text2);padding:7px 8px;border-radius:10px;display:flex;align-items:center;transition:all .2s;}
.search-toggle-btn:hover{color:var(--color-accent);background:var(--color-surface2);}
.search-toggle-btn.active{color:var(--color-accent);}

/* ─── Search Overlay ─── */
.search-overlay{position:absolute;top:100%;left:0;right:0;background:rgba(2,8,24,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1),padding .35s ease;padding:0 24px;z-index:999;}
.search-overlay.open{max-height:500px;padding:14px 24px;}
.search-overlay-inner{max-width:640px;margin:0 auto;display:flex;align-items:center;gap:10px;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:12px;padding:10px 16px;}
.search-overlay-inner svg{color:var(--color-text3);flex-shrink:0;}
.search-overlay #search-input{flex:1;background:none;border:none;color:var(--color-text);font-size:.95rem;outline:none;width:unset;padding:0;background-image:none;transition:none;}
.search-overlay #search-input:focus{border-color:transparent;width:unset;box-shadow:none;}
.search-overlay-close{background:none;border:none;cursor:pointer;color:var(--color-text3);font-size:1.1rem;padding:2px 6px;border-radius:6px;transition:all .2s;flex-shrink:0;line-height:1;}
.search-overlay-close:hover{color:var(--color-text);background:rgba(255,255,255,.08);}
.search-overlay .search-results{position:static;width:100%;max-width:640px;margin:8px auto 0;}
.search-results{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;display:none;}
.search-results.open{display:block;}
.search-result-item{display:flex;align-items:center;gap:10px;padding:12px 16px;color:var(--color-text);font-size:.9rem;transition:background .15s;text-decoration:none;}
.search-result-item:hover{background:var(--color-surface2);}
.search-result-icon{font-size:1.2rem;width:24px;text-align:center;}
.search-result-meta{font-size:.75rem;color:var(--color-text3);margin-top:2px;}
.search-no-results{padding:16px;text-align:center;color:var(--color-text3);font-size:.875rem;}

/* ─── Hero Search ─── */
.hero-search-wrap{margin-top:18px;}
.hero-search-form{display:flex;align-items:center;gap:0;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:50px;padding:6px 8px 6px 18px;max-width:440px;margin:0 auto;transition:border-color .2s,box-shadow .2s;}
.hero-search-form:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(14,165,233,.15);}
.hero-search-form svg{color:var(--color-text3);flex-shrink:0;}
.hero-search-input{flex:1;background:none;border:none;color:var(--color-text);font-size:.9rem;padding:4px 10px;outline:none;}
.hero-search-input::placeholder{color:var(--color-text3);}
.hero-search-btn{background:var(--color-accent);color:#fff;border:none;border-radius:50px;padding:7px 20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;flex-shrink:0;}
.hero-search-btn:hover{background:var(--color-accent2);transform:scale(1.03);}


.upload-zone{border:2px dashed var(--color-border2);border-radius:var(--radius-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:all var(--transition);}
.upload-zone:hover,.upload-zone.dragging{border-color:var(--color-accent);background:rgba(14,165,233,.05);}
.upload-zone-icon{font-size:2.5rem;margin-bottom:12px;}
.upload-zone-text{color:var(--color-text2);margin-bottom:8px;}
.upload-zone-hint{color:var(--color-text3);font-size:.8rem;}

/* ─── Footer ─── */
footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:60px 0 32px;margin-top:80px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.footer-brand-name{font-size:1.4rem;font-weight:900;background:linear-gradient(135deg,#fff,var(--color-accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px;}
.footer-brand-desc{color:var(--color-text2);font-size:.875rem;max-width:280px;}
.footer-title{font-size:.8rem;font-weight:700;color:var(--color-text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;}
.footer-links{display:flex;flex-direction:column;gap:8px;}
.footer-link{color:var(--color-text2);font-size:.875rem;transition:color var(--transition);}
.footer-link:hover{color:var(--color-accent2);}
.footer-bottom{border-top:1px solid var(--color-border);padding-top:24px;display:flex;align-items:center;justify-content:space-between;}
.footer-copy{color:var(--color-text3);font-size:.8rem;}

/* ─── Password Strength ─── */
.pw-strength-bar{height:4px;border-radius:2px;background:var(--color-border);margin-top:8px;transition:width .3s,background .3s;}
.pw-strength-text{font-size:.75rem;color:var(--color-text3);margin-top:4px;}

/* ─── Pagination ─── */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:32px;}
.page-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text2);font-size:.9rem;transition:all var(--transition);}
.page-btn:hover,.page-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;box-shadow:0 0 12px rgba(14,165,233,.4);}

/* ─── Helpers ─── */
.card-hidden{opacity:.45;}
.msg-unread-border{border-color:var(--color-warning)!important;}
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease;}
[data-reveal].revealed{opacity:1;transform:translateY(0);}
.text-center{text-align:center;}.text-small{font-size:.85rem;}.text-muted{color:var(--color-text2);}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.w-full{width:100%;}
.mb-4{margin-bottom:4px;}.mb-8{margin-bottom:8px;}.mb-12{margin-bottom:12px;}.mb-16{margin-bottom:16px;}.mb-24{margin-bottom:24px;}.mb-32{margin-bottom:32px;}
.mt-8{margin-top:8px;}.mt-16{margin-top:16px;}.mt-24{margin-top:24px;}.mt-32{margin-top:32px;}
.flex{display:flex;}.items-center{align-items:center;}.justify-between{justify-content:space-between;}
.gap-4{gap:4px;}.gap-8{gap:8px;}.gap-16{gap:16px;}.gap-24{gap:24px;}

/* ─── Responsive ─── */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
  .nav-links,.nav-actions .btn-nav-desktop{display:none;}
  .hamburger{display:flex;}
  .form-row{grid-template-columns:1fr;}
  .profile-layout{grid-template-columns:1fr;}
  .admin-layout{grid-template-columns:1fr;}
  .admin-sidebar{display:none;}
  .footer-grid{grid-template-columns:1fr;gap:24px;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
}
@media(max-width:480px){
  .container{padding:0 16px;}.section{padding:60px 0;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .social-btn{width:46px;height:46px;}
}

/* ─── Light Theme ─── */
[data-theme="light"] {
  --color-bg:           #e8f4fe;
  --color-bg2:          #d0e9fc;
  --color-surface:      #f0f8ff;
  --color-surface2:     #dbeeff;
  --color-border:       #9dcde8;
  --color-border2:      #76b8de;
  --color-accent:       #0077b6;
  --color-accent2:      #0096c7;
  --color-accent3:      #00b4d8;
  --color-accent-glow:  rgba(0,119,182,0.22);
  --color-accent-glow2: rgba(0,119,182,0.09);
  --color-neon-purple:  #4c1d95;
  --color-neon-cyan:    #0369a1;
  --color-neon-green:   #065f46;
  --color-text:   #0a1f2e;
  --color-text2:  #1d3f56;
  --color-text3:  #4a7a9b;
  --shadow:    0 4px 24px rgba(0,80,140,0.12);
  --shadow-lg: 0 8px 48px rgba(0,80,140,0.16);
  --shadow-neon: 0 0 20px rgba(0,119,182,0.25), 0 0 60px rgba(0,119,182,0.10);
}
[data-theme="light"] body {
  background-image:
    radial-gradient(ellipse at 20% 20%,rgba(0,119,182,.06) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 80%,rgba(0,180,216,.05) 0%,transparent 60%);
}
[data-theme="light"] ::-webkit-scrollbar-track{background:var(--color-bg2);}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--color-border2);}
[data-theme="light"] .section-title{
  background:linear-gradient(135deg,#0a1f2e 30%,var(--color-accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
[data-theme="light"] .hero::after{
  background-image:linear-gradient(rgba(0,119,182,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,119,182,.07) 1px,transparent 1px);
}
[data-theme="light"] .hero::before{
  background:
    radial-gradient(ellipse at 50% 0%,rgba(0,119,182,.12) 0%,transparent 60%),
    radial-gradient(ellipse at 20% 80%,rgba(0,180,216,.08) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 60%,rgba(0,150,199,.07) 0%,transparent 50%);
}
[data-theme="light"] .navbar{background:rgba(232,244,254,.94);border-bottom-color:var(--color-border);}
[data-theme="light"] .card{background:var(--color-surface);border-color:var(--color-border);}
[data-theme="light"] .nav-link:hover,[data-theme="light"] .nav-link.active{color:var(--color-accent);}
[data-theme="light"] .btn-primary{background:var(--color-accent);}
[data-theme="light"] .btn-outline{border-color:var(--color-accent);color:var(--color-accent);}
[data-theme="light"] .btn-outline:hover{background:var(--color-accent);color:#fff;}
[data-theme="light"] .review-form-wrapper,[data-theme="light"] .review-gate-card,[data-theme="light"] .hub-card{background:var(--color-surface);border-color:var(--color-border);}
[data-theme="light"] .review-card{background:var(--color-surface2);border-color:var(--color-border);}
[data-theme="light"] .section:nth-child(even),[data-theme="light"] section[style*="bg2"]{background:var(--color-bg2) !important;}
[data-theme="light"] .page-loader{background:var(--color-bg);}
[data-theme="light"] .footer{background:var(--color-bg2);border-top-color:var(--color-border);}
[data-theme="light"] .discord-widget{border-color:rgba(0,119,182,.3);}
[data-theme="light"] .search-overlay{background:rgba(232,244,254,.97);}
[data-theme="light"] .search-overlay-inner{background:var(--color-surface);border-color:var(--color-border);}
[data-theme="light"] .search-overlay #search-input{color:var(--color-text);}
[data-theme="light"] .hero-search-form{background:var(--color-surface);border-color:var(--color-border);}
[data-theme="light"] .discord-widget-banner{background:linear-gradient(135deg,#cde8f7 0%,#90c7e8 100%);}
[data-theme="light"] .hero-badge{background:rgba(0,119,182,.08);border-color:rgba(0,119,182,.25);}

/* ─── Theme Toggle Button ─── */
.theme-toggle{
  background:var(--color-surface2);
  border:1px solid var(--color-border);
  border-radius:50%;
  width:36px;height:36px;
  cursor:pointer;
  font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition);
  color:var(--color-text);
  flex-shrink:0;
}
.theme-toggle:hover{background:var(--color-surface);border-color:var(--color-accent);box-shadow:0 0 8px var(--color-accent-glow);}

/* ─── Language Selector ─── */
.lang-select{position:relative;}
.lang-btn{
  background:var(--color-surface2);
  border:1px solid var(--color-border);
  border-radius:8px;
  padding:5px 10px;
  cursor:pointer;
  font-size:.78rem;
  font-weight:700;
  color:var(--color-text2);
  display:flex;align-items:center;gap:5px;
  transition:all var(--transition);
  letter-spacing:.04em;
  text-transform:uppercase;
  white-space:nowrap;
}
.lang-btn:hover{border-color:var(--color-accent);color:var(--color-text);}
.lang-btn .lang-arrow{font-size:.65rem;transition:transform var(--transition);}
.lang-select.open .lang-arrow{transform:rotate(180deg);}
.lang-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  padding:6px;
  min-width:130px;
  z-index:2000;
  box-shadow:var(--shadow);
  display:none;
}
.lang-select.open .lang-dropdown{display:block;}
.lang-option{
  display:flex;align-items:center;gap:8px;
  padding:8px 10px;
  border-radius:8px;
  cursor:pointer;
  font-size:.875rem;
  color:var(--color-text2);
  transition:all var(--transition);
}
.lang-option:hover{background:var(--color-surface2);color:var(--color-text);}
.lang-option.active{background:var(--color-accent-glow2);color:var(--color-accent2);font-weight:600;}
.lang-flag{font-size:1.1rem;}

/* ─── Wave Background Animation ─── */
/* Very slow, barely visible wave of dark blue hues across all pages */
@keyframes wave-bg {
  0%   { background-position: 0%   30%; }
  33%  { background-position: 80% 70%; }
  66%  { background-position: 100% 20%; }
  100% { background-position: 0%   30%; }
}
#wave-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 80% 60% at 15% 40%, rgba(14,165,233,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 85% 60%, rgba(99,102,241,0.05) 0%, transparent 55%),
    radial-gradient(ellipse 70% 40% at 50% 90%, rgba(14,165,233,0.04) 0%, transparent 50%);
  background-size: 300% 300%;
  animation: wave-bg 28s ease-in-out infinite;
}
[data-theme="light"] #wave-bg {
  background:
    radial-gradient(ellipse 80% 60% at 15% 40%, rgba(0,119,182,0.05) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 85% 60%, rgba(99,102,241,0.04) 0%, transparent 55%),
    radial-gradient(ellipse 70% 40% at 50% 90%, rgba(0,119,182,0.03) 0%, transparent 50%);
  background-size: 300% 300%;
  animation: wave-bg 28s ease-in-out infinite;
}

/* ═══════════════════════════════════════════════════════
   TYZ BOT — Floating Chatbot Widget
   ═══════════════════════════════════════════════════════ */

#tyz-bot-btn {
  position: fixed;
  bottom: 28px;
  right: 28px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #7c6ff7, #a78bfa);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 9000;
  box-shadow: 0 4px 20px rgba(124,111,247,0.5);
  font-size: 1.5rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  user-select: none;
}
#tyz-bot-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(124,111,247,0.7);
}

#tyz-bot-panel {
  position: fixed;
  bottom: 96px;
  right: 28px;
  width: 330px;
  height: 420px;
  background: #16161f;
  border: 1px solid #2a2a3a;
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  z-index: 9001;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
  overflow: hidden;
  transform: translateY(20px) scale(0.95);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.22s cubic-bezier(.16,1,.3,1), opacity 0.22s ease;
}
#tyz-bot-panel.open {
  transform: translateY(0) scale(1);
  opacity: 1;
  pointer-events: all;
}

#tyz-bot-header {
  background: linear-gradient(135deg, #7c6ff7, #a78bfa);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
#tyz-bot-close {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.8);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 6px;
  transition: background 0.15s;
}
#tyz-bot-close:hover { background: rgba(0,0,0,0.2); }

#tyz-bot-messages {
  flex: 1;
  overflow-y: auto;
  padding: 14px 14px 8px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  scrollbar-width: thin;
  scrollbar-color: #2a2a3a transparent;
}

.tyz-msg {
  max-width: 85%;
  padding: 10px 13px;
  border-radius: 14px;
  font-size: 0.87rem;
  line-height: 1.5;
  word-break: break-word;
}
.tyz-msg.bot {
  background: #1e1e2a;
  border: 1px solid #2a2a3a;
  color: #e8e8f0;
  align-self: flex-start;
  border-bottom-left-radius: 4px;
}
.tyz-msg.user {
  background: linear-gradient(135deg, #7c6ff7, #a78bfa);
  color: #fff;
  align-self: flex-end;
  border-bottom-right-radius: 4px;
}
.tyz-msg.typing {
  color: #5a5a78;
  font-style: italic;
}

#tyz-bot-input-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 12px;
  border-top: 1px solid #2a2a3a;
  flex-shrink: 0;
}
#tyz-bot-input {
  flex: 1;
  background: #1e1e2a;
  border: 1px solid #3a3a5a;
  border-radius: 10px;
  color: #e8e8f0;
  padding: 8px 12px;
  font-size: 0.88rem;
  outline: none;
  transition: border-color 0.15s;
}
#tyz-bot-input:focus { border-color: #7c6ff7; }
#tyz-bot-input::placeholder { color: #5a5a78; }
#tyz-bot-send {
  background: linear-gradient(135deg, #7c6ff7, #a78bfa);
  border: none;
  border-radius: 10px;
  color: #fff;
  padding: 8px 13px;
  font-size: 1rem;
  cursor: pointer;
  transition: opacity 0.15s;
  flex-shrink: 0;
}
#tyz-bot-send:hover { opacity: 0.85; }
#tyz-bot-send:disabled { opacity: 0.5; cursor: default; }

@media (max-width: 480px) {
  #tyz-bot-panel { width: calc(100vw - 24px); right: 12px; bottom: 80px; }
  #tyz-bot-btn   { right: 16px; bottom: 16px; }
}
