/* ==========================================
   C2C CONSULTING LLC — CINEMATIC EDITION
   Premium dark + motion + compliance-ready
   ========================================== */

:root{
  --green:#00B86B;--green-bright:#00FF88;--green-dim:rgba(0,184,107,0.07);
  --green-glow:rgba(0,184,107,0.22);--bg:#050505;--bg2:#080808;--bg3:#0c0c0c;
  --card:#0f0f0f;--card-hover:#161616;--border:rgba(255,255,255,0.045);
  --border-green:rgba(0,184,107,0.15);--text:#ffffff;--text2:#a8a8a8;
  --text3:#555555;--font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --r:10px;--r-lg:16px;
}

/* Base */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none;transition:all .25s}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}

/* Typography */
h1,h2,h3,h4{font-weight:800;line-height:1.08;letter-spacing:-.035em}
h1{font-size:clamp(2.8rem,8vw,6.5rem)}h2{font-size:clamp(1.8rem,5vw,3.4rem)}h3{font-size:clamp(1.05rem,2vw,1.35rem)}
p{color:var(--text2);line-height:1.75}

.label{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--green);margin-bottom:1.25rem}
.label::before{content:'';width:20px;height:1.5px;background:var(--green)}

.text-gradient{background:linear-gradient(135deg,var(--green) 0%,var(--green-bright) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 2rem;font-family:var(--font);font-size:.85rem;font-weight:700;border-radius:var(--r);border:none;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--green) 0%,#009155 100%);color:#fff;box-shadow:0 4px 24px rgba(0,184,107,.28)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 36px rgba(0,184,107,.48)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--green);color:var(--green);background:var(--green-dim);transform:translateY(-1px)}
.btn-sm{padding:.6rem 1.4rem;font-size:.8rem}

/* Header — FIXED HEIGHT */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;height:80px;display:flex;align-items:center;transition:all .35s}
.header.scrolled{background:rgba(5,5,5,.9);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;width:100%}

/* Logo — FIXED SIZING PER SPEC */
.logo{display:flex;align-items:center}
.logo img{height:56px;width:auto;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;filter:brightness(1.15)}
.footer-brand .logo img{height:68px}
@media(max-width:768px){.logo img{height:44px}}

/* Nav */
.nav-desktop{display:flex;align-items:center;gap:.1rem}
.nav-desktop a{padding:.45rem .9rem;font-size:.82rem;font-weight:500;color:var(--text2);border-radius:6px;transition:all .2s}
.nav-desktop a:hover,.nav-desktop a.active{color:var(--text);background:rgba(255,255,255,.04)}
.nav-cta{display:flex;align-items:center;gap:.6rem}

/* Mobile Menu */
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem;background:none;border:none;cursor:pointer}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--text);transition:all .2s}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{position:fixed;top:0;right:-100%;width:100%;max-width:380px;height:100vh;background:var(--bg2);z-index:999;padding:6rem 2rem 2rem;transition:right .5s cubic-bezier(.25,.46,.45,.94);overflow-y:auto}
.mobile-menu.open{right:0}
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s}
.mobile-menu-overlay.open{opacity:1;pointer-events:all}
.mobile-menu a{display:block;padding:1rem 0;font-size:1.05rem;font-weight:500;color:var(--text2);border-bottom:1px solid var(--border)}
.mobile-menu a:hover{color:var(--green)}
@media(max-width:1024px){.nav-desktop{display:none}.nav-cta .btn-ghost{display:none}.menu-toggle{display:flex}}

/* ===== CINEMATIC HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:140px 0 100px}
.hero-bg{position:absolute;inset:0;z-index:0;background:var(--bg)}
.hero-bg .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.3;transition:transform .3s ease-out}

/* Animated gradient blobs */
.hero-blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.2;will-change:transform}
.hero-blob.b1{width:500px;height:500px;background:var(--green);top:-10%;left:-10%;animation:blob1 18s ease-in-out infinite}
.hero-blob.b2{width:400px;height:400px;background:#00ff88;top:45%;right:-15%;animation:blob2 22s ease-in-out infinite}
.hero-blob.b3{width:350px;height:350px;background:#006633;bottom:-10%;left:35%;animation:blob3 16s ease-in-out infinite}
@keyframes blob1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(80px,-50px) scale(1.15)}66%{transform:translate(-30px,40px) scale(.9)}}
@keyframes blob2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-60px,30px) scale(.92)}66%{transform:translate(40px,-60px) scale(1.08)}}
@keyframes blob3{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(50px,50px) scale(1.1)}66%{transform:translate(-50px,-30px) scale(.95)}}

/* Particle canvas */
#hero-canvas{position:absolute;inset:0;z-index:1}
.hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 40%,transparent 0%,var(--bg) 80%);z-index:2}

.hero-content{position:relative;z-index:3;text-align:center;max-width:920px;margin:0 auto;will-change:transform}
.hero-badge{display:inline-flex;align-items:center;gap:.6rem;padding:.5rem 1.25rem;background:var(--green-dim);border:1px solid var(--border-green);border-radius:100px;font-size:.78rem;font-weight:600;color:var(--green);margin-bottom:2rem;backdrop-filter:blur(10px)}
.hero-badge .pulse{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse 2.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.hero h1{margin-bottom:1.5rem;font-weight:800;letter-spacing:-.04em}
.hero p{font-size:clamp(1rem,2vw,1.25rem);color:var(--text2);max-width:620px;margin:0 auto 2.5rem}
.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Floating glass cards */
.hero-float-cards{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-float-cards .g-card{position:absolute;background:rgba(255,255,255,.025);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-lg);padding:.7rem 1.1rem;display:flex;align-items:center;gap:.6rem;font-size:.78rem;font-weight:600;color:var(--text);white-space:nowrap;pointer-events:auto;transition:all .3s}
.hero-float-cards .g-card:hover{border-color:var(--border-green);box-shadow:0 0 20px var(--green-glow);transform:translateY(-2px) !important}
.hero-float-cards .g-card svg{color:var(--green);flex-shrink:0}
.g-card.c1{top:14%;left:4%;animation:floatA 7s ease-in-out infinite}
.g-card.c2{top:22%;right:4%;animation:floatA 8s ease-in-out infinite -2s}
.g-card.c3{bottom:26%;left:7%;animation:floatA 9s ease-in-out infinite -4s}
.g-card.c4{bottom:16%;right:7%;animation:floatA 7.5s ease-in-out infinite -6s}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text3);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;z-index:3}
.hero-scroll .arrow{width:20px;height:20px;border-right:1.5px solid var(--green);border-bottom:1.5px solid var(--green);transform:rotate(45deg);animation:scrollBounce 2.5s infinite}
@keyframes scrollBounce{0%,100%{transform:rotate(45deg) translate(0,0)}50%{transform:rotate(45deg) translate(5px,5px)}}

/* ===== SECTIONS ===== */
.section{padding:110px 0;position:relative}
@media(max-width:768px){.section{padding:65px 0}}
.section-header{text-align:center;max-width:680px;margin:0 auto 3.5rem}
.section-header h2{margin-bottom:1rem}
.section-header p{font-size:1.1rem}

/* Glow dividers */
.glow-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(0,184,107,.35),rgba(0,255,136,.15),rgba(0,184,107,.35),transparent);margin:0 auto;max-width:70%;position:relative}
.glow-divider::after{content:'';position:absolute;top:-30px;left:50%;transform:translateX(-50%);width:200px;height:60px;background:radial-gradient(ellipse,rgba(0,184,107,.06),transparent 70%);pointer-events:none}

/* ===== CARDS with TILT ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem;transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;will-change:transform}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent);opacity:0;transition:opacity .4s}
.card:hover{border-color:var(--border-green);box-shadow:0 0 40px var(--green-glow)}
.card:hover::before{opacity:1}
.card-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--green-dim);border:1px solid var(--border-green);border-radius:var(--r);margin-bottom:1.25rem;color:var(--green);font-size:1.3rem;flex-shrink:0}
.product-logo{height:64px;width:auto;margin-bottom:.75rem;object-fit:contain}
.card h3{margin-bottom:.55rem;font-size:1.15rem}
.card p{font-size:.88rem;margin-bottom:1rem}
.card-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:700;color:var(--green)}
.card-link:hover{gap:.7rem}

/* ===== GRIDS ===== */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ===== FEATURE BLOCK ===== */
.feature-block{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.feature-block.reverse{direction:rtl}.feature-block.reverse>*{direction:ltr}
.feature-block .feature-visual{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border)}
.feature-block .feature-visual img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.feature-block:hover .feature-visual img{transform:scale(1.04)}
.feature-block ul{margin-top:1.25rem}
.feature-block ul li{display:flex;align-items:flex-start;gap:.65rem;padding:.4rem 0;font-size:.88rem;color:var(--text2)}
.feature-block ul li::before{content:'';width:18px;height:18px;min-width:18px;margin-top:1px;background:var(--green);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:12px;background-position:center;background-repeat:no-repeat}
@media(max-width:768px){.feature-block{grid-template-columns:1fr;gap:2.5rem}}

/* ===== STATS with COUNT-UP ===== */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat-item{text-align:center;padding:2rem 1rem}
.stat-number{font-size:clamp(2.2rem,4.5vw,4rem);font-weight:800;background:linear-gradient(135deg,var(--green) 0%,var(--green-bright) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}
.stat-label{font-size:.82rem;color:var(--text3);font-weight:500}
@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}

/* ===== SYSTEM FLOW ===== */
.flow-track{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;padding:2rem 0}
.flow-node{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.2rem 1.4rem;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);transition:all .3s;position:relative;animation:floatA 10s ease-in-out infinite}
.flow-node:nth-child(odd){animation-delay:-3s}
.flow-node:hover{border-color:var(--border-green);box-shadow:0 0 24px var(--green-glow);transform:translateY(-4px) !important;animation-play-state:paused}
.flow-node .flow-icon{width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:var(--green-dim);border:1px solid var(--border-green);border-radius:50%;color:var(--green);font-size:1.15rem}
.flow-node .flow-label{font-size:.82rem;font-weight:700;color:var(--text)}
.flow-arrow{font-size:1.5rem;color:var(--green);animation:flowPulse 2s infinite}
@keyframes flowPulse{0%,100%{opacity:.4;transform:translateX(0)}50%{opacity:1;transform:translateX(5px)}}
@media(max-width:768px){.flow-track{flex-direction:column}.flow-arrow{transform:rotate(90deg);animation:flowPulseMob 2s infinite}@keyframes flowPulseMob{0%,100%{opacity:.4;transform:rotate(90deg) translateY(0)}50%{opacity:1;transform:rotate(90deg) translateY(4px)}}}

/* ===== PRICING ===== */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1100px;margin:0 auto}
.pricing-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2.25rem 1.75rem;transition:all .35s;position:relative}
.pricing-card.featured{border-color:var(--green);box-shadow:0 0 40px var(--green-glow);transform:scale(1.02)}
.pricing-card.featured::before{content:'Most Popular';position:absolute;top:-11px;left:50%;transform:translateX(-50%);padding:.25rem .9rem;background:var(--green);color:#fff;font-size:.68rem;font-weight:700;border-radius:100px;letter-spacing:.04em}
.pricing-card:hover{border-color:var(--border-green)}
.pricing-name{font-size:1.25rem;font-weight:800;margin-bottom:.35rem}
.pricing-desc{font-size:.8rem;color:var(--text3);margin-bottom:1.25rem}
.pricing-price{font-size:2.8rem;font-weight:800;margin-bottom:.25rem}
.pricing-period{font-size:.82rem;color:var(--text3);margin-bottom:1.75rem}
.pricing-features{margin-bottom:1.75rem}.pricing-features li{display:flex;align-items:center;gap:.65rem;padding:.4rem 0;font-size:.85rem;color:var(--text2)}
.pricing-features li::before{content:'';width:16px;height:16px;min-width:16px;background:var(--green);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:10px;background-position:center;background-repeat:no-repeat}
@media(max-width:1024px){.pricing-grid{grid-template-columns:1fr;max-width:480px}.pricing-card.featured{transform:none}}

/* ===== FAQ ===== */
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.4rem 0;background:none;border:none;color:var(--text);font-family:var(--font);font-size:1rem;font-weight:700;cursor:pointer;text-align:left}
.faq-question::after{content:'+';font-size:1.4rem;font-weight:300;color:var(--green);transition:transform .25s;min-width:24px;text-align:center}
.faq-item.active .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .5s,padding .5s}
.faq-item.active .faq-answer{max-height:500px;padding-bottom:1.4rem}
.faq-answer p{color:var(--text2);font-size:.9rem}

/* ===== CONTACT FORM ===== */
.contact-form{max-width:600px;margin:0 auto}
.form-group{margin-bottom:1.4rem}
.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text2);margin-bottom:.45rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.85rem 1rem;background:var(--card);border:1px solid var(--border);border-radius:var(--r);color:var(--text);font-family:var(--font);font-size:.85rem;transition:all .25s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-dim)}
.form-group textarea{min-height:130px;resize:vertical}
.form-group input[type="checkbox"]{width:auto;margin-right:.5rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
@media(max-width:768px){.form-grid{grid-template-columns:1fr}}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.blog-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .4s}
.blog-card:hover{border-color:var(--border-green);box-shadow:0 0 40px var(--green-glow);transform:translateY(-5px)}
.blog-card-img{height:200px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-content{padding:1.6rem}
.blog-card-meta{display:flex;gap:1rem;font-size:.72rem;color:var(--text3);margin-bottom:.65rem}
.blog-card h3{font-size:1.05rem;margin-bottom:.55rem;line-height:1.35}
.blog-card h3 a:hover{color:var(--green)}
.blog-card p{font-size:.82rem}
@media(max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.blog-grid{grid-template-columns:1fr}}

/* ===== CTA ===== */
.cta-section{position:relative;padding:110px 0;overflow:hidden;text-align:center}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,var(--green-dim) 0%,transparent 70%);opacity:.5;pointer-events:none}
.cta-section .container{position:relative;z-index:1}
.cta-section h2{margin-bottom:1rem;max-width:650px;margin-left:auto;margin-right:auto}
.cta-section p{margin-bottom:2rem;max-width:460px;margin-left:auto;margin-right:auto}

/* ===== FOOTER ===== */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:75px 0 35px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}
.footer-brand .logo{margin-bottom:1rem}
.footer-brand p{font-size:.82rem;max-width:300px}
.footer-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:1.4rem}
.footer-links a{display:block;padding:.35rem 0;font-size:.82rem;color:var(--text2);transition:color .2s}
.footer-links a:hover{color:var(--green)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:1.75rem;border-top:1px solid var(--border);font-size:.75rem;color:var(--text3)}
.footer-bottom a{color:var(--text3);margin-left:1.5rem;transition:color .2s}
.footer-bottom a:hover{color:var(--green)}

/* Disclaimer */
.site-disclaimer{font-size:.75rem;color:var(--text3);line-height:1.6;max-width:900px;margin:0 auto;padding:1.5rem;text-align:center;border-top:1px solid var(--border)}

/* Social */
.social-links{display:flex;gap:.65rem;margin-top:1.1rem;flex-wrap:wrap}
.social-links a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r);color:var(--text2);transition:all .25s}
.social-links a:hover{background:var(--green-dim);border-color:var(--green);color:var(--green);transform:translateY(-2px)}
.whatsapp-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--green);font-weight:700;font-size:.85rem}
.whatsapp-link:hover{color:var(--green-bright)}

@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}.footer-bottom a{margin:0 .6rem}}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(45px);transition:opacity .85s cubic-bezier(.25,.46,.45,.94),transform .85s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--green);border-radius:3px}

/* Tags */
.tag{display:inline-flex;align-items:center;padding:.28rem .8rem;font-size:.7rem;font-weight:700;border-radius:100px;background:var(--green-dim);color:var(--green);border:1px solid var(--border-green)}
.tag-outline{background:transparent;border-color:var(--border);color:var(--text3)}

/* Data table */
.data-table{width:100%;border-collapse:collapse;font-size:.85rem}
.data-table th,.data-table td{padding:.9rem 1.1rem;text-align:left;border-bottom:1px solid var(--border)}
.data-table th{font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--bg2)}
.data-table a{color:var(--green);font-weight:700}

/* Legal */
.legal-content{max-width:780px;margin:0 auto;padding-top:130px;padding-bottom:70px}
.legal-content h1{margin-bottom:1rem}.legal-content h2{margin-top:2.2rem;margin-bottom:.9rem;font-size:1.3rem}
.legal-content ul{list-style:disc;padding-left:1.5rem;margin-bottom:1rem;color:var(--text2)}
.legal-content ul li{margin-bottom:.35rem}

/* Region */
.region-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2.25rem;transition:all .35s}
.region-card:hover{border-color:var(--border-green);box-shadow:0 0 30px var(--green-glow)}
.region-card .region-flag{font-size:1.8rem;margin-bottom:.75rem}
.region-card ul{margin-top:.9rem}
.region-card ul li{display:flex;align-items:flex-start;gap:.55rem;padding:.3rem 0;font-size:.85rem;color:var(--text2)}
.region-card ul li::before{content:'';width:6px;height:6px;min-width:6px;background:var(--green);border-radius:50%;margin-top:.4rem}

/* Accessibility */
a:focus,button:focus,input:focus,textarea:focus,select:focus{outline:2px solid var(--green);outline-offset:2px}
a:focus:not(:focus-visible),button:focus:not(:focus-visible){outline:none}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--green);outline-offset:2px}

/* prefers-reduced-motion */
@media(prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
.reveal{opacity:1;transform:none}.hero-blob{display:none}
}
