/* ============================================
   SISTEMA DE TEMAS — claro por defecto
   ============================================ */

:root {
  /* Tema CLARO (por defecto) */
  --bg: #fafafa;
  --surface: #ffffff;
  --surface2: #f0f0f4;
  --border: rgba(0,0,0,0.08);
  --text: #1a1a2e;
  --text2: #4a4a66;
  --text3: #6a6a85;
  --blue: #344680;
  --pink: #C94774;
  --grad: linear-gradient(135deg, var(--blue), var(--pink));
  --grad-text: linear-gradient(90deg, var(--blue), var(--pink));

  /* Sombras sutiles para tema claro */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);

  /* Overlays específicos */
  --card-hover: rgba(52,70,128,0.04);
  --dot-color: rgba(0,0,0,0.15);
  --nav-bg: rgba(250,250,250,0.88);

  /* Variables brand-invariantes (idénticas en ambos temas) */
  --green: #25D366;
  --glow-blue: rgba(52,70,128,0.25);
  --glow-pink: rgba(201,71,116,0.2);
}

[data-theme="dark"] {
  /* Tema OSCURO */
  --bg: #040408;
  --surface: #0c0c14;
  --surface2: #121220;
  --border: rgba(255,255,255,0.07);
  --text: #e8e8f0;
  --text2: #8080a0;
  --text3: #505070;

  /* Sombras fuertes para tema oscuro */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.5);

  /* Overlays específicos */
  --card-hover: rgba(255,255,255,0.04);
  --dot-color: rgba(255,255,255,0.25);
  --nav-bg: rgba(4,4,8,0.88);
}

/* Transición suave al cambiar de tema */
* {
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}

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

/* BANNER */
.top-banner{background:var(--grad);padding:10px 20px;font-size:14px;font-weight:600;letter-spacing:0.02em;color:#ffffff}
.top-banner a{color:#fff;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.top-banner a:hover .banner-text{text-decoration:underline}
.top-banner .appstore-badge{display:inline-flex;align-items:center;gap:8px;background:#000;border:1px solid #333;border-radius:9px;padding:6px 12px;flex-shrink:0}
.top-banner .appstore-badge svg{flex-shrink:0;display:block}
.top-banner .appstore-badge-text{display:flex;flex-direction:column;line-height:1.15;text-align:left;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
.top-banner .appstore-badge .line1{font-size:9px;font-weight:400;letter-spacing:0.03em}
.top-banner .appstore-badge .line2{font-size:15px;font-weight:500;letter-spacing:-0.02em}
@media(max-width:600px){.top-banner{padding:8px 12px}.top-banner a{gap:10px}.top-banner .banner-text{font-size:12px}}

/* NAV */
nav{position:sticky;top:0;z-index:100;background:var(--nav-bg);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 24px}
.nav-inner{max-width:1200px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;font-size:18px;font-weight:700;color:var(--text)}
.nav-logo svg{flex-shrink:0}
.logo-accent{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{color:var(--text2);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-cta{background:var(--grad);color:#fff;border:none;padding:9px 20px;border-radius:22px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap;transition:opacity .2s}
.nav-cta:hover{opacity:.88}
.ham{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.ham span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.mobile-menu{display:none;flex-direction:column;gap:16px;padding:20px 24px;border-top:1px solid var(--border)}
.mobile-menu a{color:var(--text2);text-decoration:none;font-size:16px;font-weight:500}
@media(max-width:768px){.nav-links{display:none}.ham{display:flex}.mobile-menu.open{display:flex}}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,var(--glow-blue) 0%,transparent 55%),radial-gradient(ellipse at 70% 70%,var(--glow-pink) 0%,transparent 55%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(52,70,128,.15);border:1px solid rgba(52,70,128,.3);color:#7a99e8;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:28px;letter-spacing:.04em}
.hero-badge .dot{width:7px;height:7px;background:#5578d4;border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
.hero h1{font-size:clamp(42px,7vw,84px);font-weight:800;line-height:1.05;letter-spacing:-0.03em;margin-bottom:24px;max-width:900px}
.hero h1 .grad{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:clamp(16px,2.5vw,21px);color:var(--text2);max-width:680px;line-height:1.6;margin-bottom:40px;font-weight:400}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:64px}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--grad);color:#fff;text-decoration:none;padding:14px 28px;border-radius:30px;font-size:16px;font-weight:700;transition:opacity .2s,transform .15s}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text);text-decoration:none;padding:14px 28px;border-radius:30px;font-size:16px;font-weight:600;transition:all .2s}
.btn-secondary:hover{background:var(--card-hover);border-color:var(--text3)}
.hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden;max-width:700px;width:100%}
.hstat{background:var(--surface);padding:20px;text-align:center}
.hstat-n{font-size:28px;font-weight:800;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.hstat-l{font-size:12px;color:var(--text2);margin-top:4px;font-weight:500}

/* DIVIDER */
.divider{max-width:1200px;margin:0 auto;height:1px;background:var(--border)}

/* SECTION */
section{padding:80px 24px}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#6688cc;margin-bottom:12px}
.section-title{font-size:clamp(28px,4vw,48px);font-weight:800;line-height:1.1;letter-spacing:-0.02em;margin-bottom:16px}
.section-title .grad{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.section-sub{font-size:18px;color:var(--text2);max-width:600px;line-height:1.6}

/* VALIDATION STRIP */
.validation-strip{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:40px 24px}
.val-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.val-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:24px;display:flex;gap:14px;align-items:flex-start}
.val-icon{width:40px;height:40px;border-radius:10px;background:rgba(52,70,128,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
.val-card h4{font-size:14px;font-weight:700;margin-bottom:4px}
.val-card p{font-size:13px;color:var(--text2);line-height:1.5}
.val-card small{font-size:11px;color:var(--text3);display:block;margin-top:6px}

/* VERSION BADGE */
.version-card{background:linear-gradient(135deg,rgba(52,70,128,.15),rgba(201,71,116,.1));border:1px solid rgba(52,70,128,.3);border-radius:16px;padding:28px 32px;margin-bottom:48px;display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between}
.version-card h3{font-size:20px;font-weight:700}
.version-card p{font-size:14px;color:var(--text2);margin-top:4px}
.ver-tags{display:flex;flex-wrap:wrap;gap:8px}
.ver-tag{background:rgba(52,70,128,.25);border:1px solid rgba(52,70,128,.4);color:#7a99e8;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600}
.ver-tag.pink{background:rgba(201,71,116,.2);border-color:rgba(201,71,116,.35);color:#e07398}
.ver-tag.green{background:rgba(37,211,102,.1);border-color:rgba(37,211,102,.25);color:#25D366}

/* MODULES GRID */
.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:48px}
.mod-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;transition:border-color .2s,transform .15s}
.mod-card:hover{border-color:rgba(52,70,128,.5);transform:translateY(-2px)}
.mod-icon{font-size:22px;margin-bottom:12px;display:block}
.mod-card h3{font-size:15px;font-weight:700;margin-bottom:6px}
.mod-card p{font-size:13px;color:var(--text2);line-height:1.5}
.mod-paper{font-size:11px;color:var(--text3);margin-top:8px;font-style:italic}
.mod-new{display:inline-block;background:rgba(201,71,116,.2);color:#e07398;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;margin-left:6px;vertical-align:middle;letter-spacing:.04em}

/* SCREENSHOTS GALLERY */
.screenshots-gallery{position:relative;margin-top:48px}
.gallery-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:16px 8px;scrollbar-width:none}
.gallery-track::-webkit-scrollbar{display:none}
.gallery-track picture{flex:0 0 auto;scroll-snap-align:center}
.gallery-track img{width:min(280px,75vw);height:auto;border-radius:24px;box-shadow:var(--shadow-lg);background:var(--surface2);display:block;padding:8px}
.gallery-track:focus-visible{outline:2px solid var(--blue);outline-offset:4px;border-radius:8px}
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:var(--surface);box-shadow:var(--shadow-md);border:1px solid var(--border);color:var(--text);font-size:24px;font-weight:400;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s;font-family:inherit}
.gallery-nav:hover{background:var(--surface2)}
.gallery-prev{left:-8px}
.gallery-next{right:-8px}
.gallery-dots{display:flex;gap:8px;justify-content:center;margin-top:16px}
.gallery-dots .dot{width:8px;height:8px;border-radius:50%;background:var(--dot-color);transition:background .2s;cursor:pointer;border:none;padding:0;-webkit-appearance:none}
.gallery-dots .dot.active{background:#5570c8}
@media(min-width:900px){
  .gallery-track picture,
  .gallery-track img{width:300px}
}

/* TESTIMONIOS */
.testimonios-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:48px}
.testimonio-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px;transition:border-color .2s}
.testimonio-card:hover{border-color:rgba(52,70,128,.4)}
.testimonio-stars{color:#f5b942;font-size:18px;letter-spacing:2px;margin-bottom:12px}
.testimonio-card h3{font-size:18px;font-weight:700;margin-bottom:10px}
.testimonio-text{font-size:15px;color:var(--text);line-height:1.6;margin-bottom:16px;font-style:italic}
.testimonio-meta{font-size:12px;color:var(--text3);letter-spacing:.02em}
.testimonios-summary{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:center;margin-top:40px;padding:28px;background:linear-gradient(135deg,rgba(52,70,128,.12),rgba(201,71,116,.08));border:1px solid rgba(52,70,128,.25);border-radius:16px}
.testimonios-rating{text-align:center}
.rating-number{font-size:48px;font-weight:900;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.rating-stars{color:#f5b942;font-size:20px;letter-spacing:3px;margin:4px 0}
.rating-meta{font-size:13px;color:var(--text2)}

/* COMPARISON TABLE */
.comp-wrap{overflow-x:auto;margin-top:48px}
.comp-table{width:100%;border-collapse:collapse;min-width:680px}
.comp-table th{padding:14px 16px;font-size:13px;font-weight:700;text-align:center;border-bottom:2px solid var(--border)}
.comp-table th.highlight{background:linear-gradient(180deg,rgba(52,70,128,.25) 0%,rgba(52,70,128,.12) 100%);border-radius:12px 12px 0 0;border-bottom-color:#344680}
.comp-table td{padding:12px 16px;font-size:13px;text-align:center;border-bottom:1px solid var(--border)}
.comp-table td:first-child{text-align:left;color:var(--text2)}
.comp-table td.highlight{background:rgba(52,70,128,.08)}
.check{color:#25D366;font-size:16px}
.cross{color:var(--text3);font-size:14px}
.comp-price{font-size:11px;color:var(--text3);font-weight:600;display:block;margin-top:2px}

/* WHO IS IT FOR */
.roles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:48px}
.role-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px;text-align:center;transition:border-color .2s}
.role-card:hover{border-color:rgba(52,70,128,.4)}
.role-emoji{font-size:36px;display:block;margin-bottom:16px}
.role-card h3{font-size:17px;font-weight:700;margin-bottom:8px}
.role-card p{font-size:14px;color:var(--text2);line-height:1.5}
.role-badge{display:inline-block;margin-top:12px;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.25);color:#25D366;font-size:11px;font-weight:700;padding:3px 10px;border-radius:10px;letter-spacing:.04em}

/* CSD VALIDATION */
.csd-card{background:linear-gradient(135deg,rgba(52,70,128,.12),rgba(201,71,116,.08));border:1px solid rgba(52,70,128,.25);border-radius:20px;padding:40px;margin-top:48px;display:flex;flex-wrap:wrap;gap:32px;align-items:center}
.csd-shield{width:80px;height:80px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:42px}
.csd-text h3{font-size:22px;font-weight:800;margin-bottom:8px}
.csd-text p{font-size:15px;color:var(--text2);line-height:1.6;max-width:600px}
.csd-text small{font-size:12px;color:var(--text3);display:block;margin-top:10px}

/* HOW IT WORKS */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;margin-top:48px;position:relative}
.step{text-align:center}
.step-num{width:52px;height:52px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;margin:0 auto 16px;color:#fff}
.step h3{font-size:16px;font-weight:700;margin-bottom:8px}
.step p{font-size:14px;color:var(--text2);line-height:1.5}

/* PRICING */
.pricing-card{background:linear-gradient(135deg,var(--surface),var(--surface2));border:1px solid var(--border);border-radius:24px;padding:48px;max-width:560px;margin:48px auto 0;text-align:center;position:relative;overflow:hidden}
.pricing-card::before{content:'';position:absolute;top:-80px;right:-80px;width:200px;height:200px;background:radial-gradient(var(--glow-pink),transparent 70%);pointer-events:none}
.pricing-badge{display:inline-block;background:rgba(37,211,102,.15);border:1px solid rgba(37,211,102,.3);color:#25D366;font-size:13px;font-weight:700;padding:5px 14px;border-radius:20px;margin-bottom:20px;letter-spacing:.04em}
.pricing-price{font-size:64px;font-weight:900;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.pricing-sub{font-size:16px;color:var(--text2);margin:8px 0 32px}
.pricing-features{list-style:none;text-align:left;display:flex;flex-direction:column;gap:12px;margin-bottom:36px}
.pricing-features li{display:flex;gap:10px;font-size:15px;align-items:flex-start}
.pricing-features li::before{content:'✓';color:#25D366;font-weight:700;flex-shrink:0;margin-top:1px}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:48px}
.team-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px}
.team-avatar{width:56px;height:56px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#fff;margin-bottom:16px}
.team-card h3{font-size:17px;font-weight:700;margin-bottom:4px}
.team-card .role-title{font-size:13px;color:var(--text2);margin-bottom:12px}
.team-card p{font-size:13px;color:var(--text2);line-height:1.5}
.team-card a{color:#7a99e8;text-decoration:none;font-size:13px}
.team-card a:hover{text-decoration:underline}

/* FAQ */
.faq-list{max-width:800px;margin:48px auto 0;display:flex;flex-direction:column;gap:2px}
.faq-item{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:2px}
.faq-q{padding:18px 22px;font-size:15px;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;user-select:none;transition:background .15s}
.faq-q:hover{background:var(--surface)}
.faq-q .icon{font-size:18px;flex-shrink:0;transition:transform .2s;color:var(--text2)}
.faq-a{display:none;padding:0 22px 18px;font-size:14px;color:var(--text2);line-height:1.7}
.faq-item.open .faq-q{background:var(--surface)}
.faq-item.open .faq-q .icon{transform:rotate(45deg)}
.faq-item.open .faq-a{display:block}

/* FINAL CTA */
.final-cta{text-align:center;padding:100px 24px;background:linear-gradient(180deg,transparent,rgba(52,70,128,.08) 50%,transparent)}
.final-cta h2{font-size:clamp(32px,5vw,60px);font-weight:800;margin-bottom:20px;letter-spacing:-0.02em}
.final-cta p{font-size:18px;color:var(--text2);margin-bottom:40px}
.app-badges{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;align-items:center}
.app-badge{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);color:var(--text);text-decoration:none;padding:12px 22px;border-radius:12px;font-size:14px;font-weight:600;transition:all .2s}
.app-badge:hover{border-color:rgba(52,70,128,.5);background:var(--surface2)}
.countries-note{font-size:13px;color:var(--text3);margin-top:16px}

/* FOOTER */
footer{background:var(--surface);border-top:1px solid var(--border);padding:48px 24px 32px}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
.footer-brand p{font-size:13px;color:var(--text2);line-height:1.6;margin-top:12px}
.footer-col h4{font-size:13px;font-weight:700;margin-bottom:14px;color:var(--text)}
.footer-col a{display:block;color:var(--text2);text-decoration:none;font-size:13px;margin-bottom:8px;transition:color .2s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{max-width:1200px;margin:32px auto 0;padding-top:24px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:12px;color:var(--text3)}
@media(max-width:768px){.footer-inner{grid-template-columns:1fr}.hero-stats{grid-template-columns:repeat(2,1fr)}}

/* FLOATING BUTTONS */
.float-wa{position:fixed;bottom:150px;right:24px;z-index:50;width:52px;height:52px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 16px rgba(37,211,102,.4);transition:transform .2s}
.float-wa:hover{transform:scale(1.08)}
.float-up{position:fixed;bottom:90px;right:24px;z-index:50;width:44px;height:44px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;box-shadow:0 4px 12px rgba(52,70,128,.4);transition:transform .2s}
.float-up:hover{transform:scale(1.08) translateY(-2px)}

/* THEME TOGGLE FLOATING BUTTON */
.float-theme{position:fixed;bottom:218px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:900;transition:transform .2s ease,background-color .3s ease,border-color .3s ease;font-family:inherit}
.float-theme:hover{transform:scale(1.08)}
.float-theme svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.float-theme .icon-moon{display:none}
.float-theme .icon-sun{display:block}
[data-theme="dark"] .float-theme .icon-moon{display:block}
[data-theme="dark"] .float-theme .icon-sun{display:none}

/* ANIMATE ON SCROLL */
[data-anim]{opacity:0;transform:translateY(22px);transition:opacity .6s,transform .6s}
[data-anim].vis{opacity:1;transform:none}

/* LANGUAGE SUGGESTION BANNER */
.lang-banner{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:200;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:10px 16px;
  display:none;
  align-items:center;
  justify-content:center;
  gap:16px;
  font-size:14px;
  color:var(--text);
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
}
.lang-banner.show{display:flex}
.lang-banner-text{display:flex;align-items:center;gap:8px}
.lang-banner-btn{
  background:var(--grad);
  color:#fff;
  border:none;
  padding:6px 14px;
  border-radius:16px;
  font-family:inherit;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  text-decoration:none;
  transition:opacity .2s;
}
.lang-banner-btn:hover{opacity:.9}
.lang-banner-close{
  background:transparent;
  border:none;
  color:var(--text3);
  font-size:20px;
  cursor:pointer;
  padding:0 4px;
  line-height:1;
}
.lang-banner-close:hover{color:var(--text)}
@media (max-width:600px){
  .lang-banner{font-size:12px;padding:8px 12px;gap:10px}
  .lang-banner-btn{padding:5px 10px;font-size:12px}
}

/* LANGUAGE SWITCH */
.lang-switch{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;padding:0 12px}
.lang-switch .lang-active{color:var(--text);opacity:0.9}
.lang-switch .lang-link{color:var(--text3);text-decoration:none;transition:color .2s}
.lang-switch .lang-link:hover{color:var(--text)}
.lang-switch .lang-sep{color:var(--text3);opacity:0.5}
@media(max-width:768px){.lang-switch{padding:0 8px;font-size:12px}}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:24px;left:24px;right:24px;max-width:500px;background:var(--surface2);border:1px solid var(--border);border-radius:16px;padding:20px 24px;z-index:200;display:none}
.cookie-banner.show{display:block}
.cookie-banner p{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:14px}
.cookie-btns{display:flex;gap:10px;flex-wrap:wrap}
.cookie-accept{background:var(--grad);color:#fff;border:none;padding:8px 18px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Outfit',sans-serif}
.cookie-reject{background:none;border:1px solid var(--border);color:var(--text2);padding:8px 18px;border-radius:20px;font-size:13px;cursor:pointer;font-family:'Outfit',sans-serif}
.footer-legal-line {
  font-size: 13px;
  color: var(--text3);
  line-height: 1.6;
  margin-bottom: 6px;
}
.footer-legal-links {
  font-size: 13px;
  color: var(--text3);
  line-height: 1.6;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.footer-legal-links a {
  color: var(--text3);
  text-decoration: none;
}
.footer-legal-links a:hover {
  color: var(--text);
  text-decoration: underline;
}
.footer-legal-links .sep {
  opacity: 0.6;
}
.legal-notice-en {
  font-style: italic;
  margin-right: 4px;
}
