:root{
  --bg:#040506;
  --bg-2:rgba(232,237,245,.025);
  --bg-3:rgba(232,237,245,.04);
  --text:#E8EDF5;
  --muted:#A0B4CC;
  --accent:#E8EDF5;
  --accent-2:#A0B4CC;
  --accent-3:#5A7A99;
  --border:rgba(232,237,245,.08);
  --border-strong:rgba(232,237,245,.15);
  --light:#E8EDF5;
  --glow: 0 0 50px rgba(160,180,204,.12), 0 0 100px rgba(160,180,204,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html{background:var(--bg)}
body{background:transparent;color:var(--text);font-family:Arial,Helvetica,sans-serif;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:Georgia,'Times New Roman',serif;font-weight:normal;color:var(--text);letter-spacing:-.5px}
h1{font-size:clamp(2.4rem,6vw,5.5rem);line-height:1.05;margin-bottom:1.5rem;letter-spacing:-1.5px}
h2{font-size:clamp(1.8rem,3.6vw,3.2rem);margin-bottom:1.2rem;letter-spacing:-.8px;line-height:1.15}
h3{font-size:1.4rem;margin-bottom:.6rem;letter-spacing:-.3px}
p{color:var(--muted);margin-bottom:1rem;font-size:1.02rem}
a{color:var(--accent);text-decoration:none;transition:color .25s}
a:hover{color:var(--muted)}
strong{font-weight:normal;color:var(--accent)}

::selection{background:rgba(160,180,204,.25);color:var(--accent)}

/* Lang visibility - bulletproof */
[data-lang]:not(.is-visible){display:none !important}

/* Neural canvas */
#neural-bg{position:fixed;inset:0;z-index:0;width:100vw;height:100vh;pointer-events:none;background:#040506;display:block;opacity:0;transition:opacity .5s ease}
body.intro-done #neural-bg,body:not(.intro-pending) #neural-bg{opacity:1}

/* Intro bar (loading detonator) */
.intro-bar{position:relative;width:260px;max-width:70vw;height:2px;margin:2.2rem auto 0;background:rgba(232,237,245,.08);border-radius:2px;overflow:visible}
.intro-bar::before{content:"";position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg, transparent, #A0B4CC 30%, #E8EDF5 100%);border-radius:2px;box-shadow:0 0 14px rgba(232,237,245,.6)}
body.intro-running .intro-bar::before{animation:introFill 2.5s cubic-bezier(.6,.04,.3,1) forwards}
.intro-bar::after{content:"";position:absolute;inset:-1px;border-radius:999px;background:radial-gradient(circle, rgba(232,237,245,.9), rgba(160,180,204,.4) 35%, transparent 70%);opacity:0;transform:scale(.3);pointer-events:none}
body.intro-done .intro-bar::after{animation:introBurst .9s ease-out forwards}
body.intro-done .intro-bar::before{opacity:0;transition:opacity .5s ease}
@keyframes introFill{
  0%{width:0}
  60%{width:100%}
  75%{width:100%;box-shadow:0 0 14px rgba(232,237,245,.6)}
  85%{width:100%;box-shadow:0 0 40px rgba(232,237,245,1), 0 0 90px rgba(160,180,204,.8)}
  100%{width:100%;box-shadow:0 0 14px rgba(232,237,245,.6)}
}
@keyframes introBurst{
  0%{opacity:1;transform:scaleX(1) scaleY(1)}
  40%{opacity:.95;transform:scaleX(4) scaleY(8)}
  100%{opacity:0;transform:scaleX(14) scaleY(20)}
}
.intro-hint{margin-top:.9rem;font-size:.65rem;letter-spacing:4px;color:var(--accent-3);text-transform:uppercase;text-align:center}
.intro-hint.is-visible{display:inline-block;margin-left:auto;margin-right:auto}
.intro-bar + .intro-hint{margin-top:1rem}
body.intro-done .intro-bar,body.intro-done .intro-hint{opacity:0;pointer-events:none;transition:opacity .6s ease .6s}
.bg-vignette{position:fixed;inset:0;z-index:1;pointer-events:none;background:
  radial-gradient(ellipse 100% 90% at 50% 50%, transparent 30%, rgba(10,10,10,.35) 100%);
}
/* Bring all content above canvas */
.nav,section,footer{position:relative;z-index:2}
.particle{display:none}

/* Container */
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
section{padding:6rem 0;position:relative}
section.tight{padding:3rem 0}

/* Navbar - glass */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:rgba(10,10,10,.55);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1320px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.85rem;color:var(--text);transition:opacity .2s}
.brand:hover{opacity:.85}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{color:var(--muted);font-size:.88rem;position:relative;padding:.4rem 0;letter-spacing:.3px;transition:color .25s}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--accent)}

.lang-switch{display:flex;gap:.3rem;align-items:center;margin-left:1rem;border:1px solid var(--border);border-radius:100px;padding:3px;background:rgba(232,237,245,.02)}
.lang-switch button{background:transparent;border:none;color:var(--muted);padding:.4rem .8rem;cursor:pointer;font-size:.75rem;border-radius:100px;font-family:inherit;letter-spacing:1.5px;transition:all .25s;display:flex;align-items:center;gap:.35rem}
.lang-switch button.active{background:rgba(232,237,245,.08);color:var(--accent)}
.lang-switch button:hover:not(.active){color:var(--accent)}
.flag{width:14px;height:10px;display:inline-block;border-radius:1px;overflow:hidden;vertical-align:middle;opacity:.85}

/* Hamburger */
.hamburger{display:none;background:transparent;border:1px solid var(--border);border-radius:8px;width:42px;height:42px;cursor:pointer;padding:0;align-items:center;justify-content:center;flex-direction:column;gap:5px;margin-left:.5rem;transition:border-color .25s}
.hamburger:hover{border-color:var(--border-strong)}
.hamburger span{display:block;width:18px;height:1.5px;background:var(--text);transition:all .3s ease;transform-origin:center}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Logo */
.brand-logo{height:36px;width:auto;flex-shrink:0;filter:drop-shadow(0 0 12px rgba(160,180,204,.18))}
.footer-logo{height:32px;width:auto;display:block;margin-bottom:.8rem;opacity:.9}
.brand-logo .sq1,.footer-logo .sq1,.hero-logo .sq1{animation:rotate1 14s linear infinite;transform-origin:center;transform-box:fill-box}
.brand-logo .sq2,.footer-logo .sq2,.hero-logo .sq2{animation:rotate2 11s linear infinite;transform-origin:center;transform-box:fill-box}
.brand-logo .sq3,.footer-logo .sq3,.hero-logo .sq3{animation:rotate3 8s linear infinite;transform-origin:center;transform-box:fill-box}
@keyframes rotate1{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes rotate2{from{transform:rotate(22.5deg)}to{transform:rotate(-337.5deg)}}
@keyframes rotate3{from{transform:rotate(45deg)}to{transform:rotate(405deg)}}

/* Hero - big & bold */
.hero{padding:8rem 0 6rem;text-align:center;position:relative;min-height:90vh;display:flex;align-items:center}
.hero .container{width:100%}
.hero-logo{width:min(520px,90vw);height:auto;margin:0 auto 2rem;display:block;filter:drop-shadow(0 0 60px rgba(160,180,204,.25));animation:heroFloat 7s ease-in-out infinite}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero .kicker{display:inline-flex;align-items:center;gap:.6rem;font-size:.72rem;letter-spacing:4px;color:var(--muted);text-transform:uppercase;margin-bottom:2rem;padding:.55rem 1.1rem;border:1px solid var(--border);border-radius:100px;background:rgba(232,237,245,.025);backdrop-filter:blur(10px)}
.hero .kicker::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 10px var(--accent-2);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
.hero h1 span.accent{background:linear-gradient(180deg, var(--accent) 0%, var(--muted) 120%);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.hero .lede{max-width:720px;margin:1.8rem auto 3rem;font-size:1.25rem;color:var(--muted);line-height:1.55}
.hero .lede strong{color:var(--accent);font-weight:normal}

/* Typing */
.typing{display:inline-block;font-family:Georgia,serif;font-style:italic;color:var(--accent-2);letter-spacing:3px;font-size:.95rem;position:relative;overflow:hidden;white-space:nowrap;animation:typeIn 2.8s steps(30,end) forwards}
@keyframes typeIn{from{width:0}to{width:100%}}

/* Buttons - glassmorphic */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;border-radius:100px;font-size:.82rem;letter-spacing:2px;cursor:pointer;border:1px solid transparent;font-family:inherit;transition:all .35s cubic-bezier(.2,.8,.2,1);text-transform:uppercase;text-align:center;font-weight:normal;position:relative;overflow:hidden}
.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 40px rgba(232,237,245,.25);color:var(--bg)}
.btn-ghost{background:rgba(232,237,245,.02);border-color:var(--border-strong);color:var(--text);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(232,237,245,.06);border-color:var(--accent-2);color:var(--accent);transform:translateY(-2px);box-shadow:0 0 30px rgba(160,180,204,.15)}
.btn-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Glass card base */
.glass{background:rgba(232,237,245,.025);border:1px solid var(--border);border-radius:18px;backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);transition:all .5s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg, rgba(232,237,245,.2), transparent 40%, transparent 60%, rgba(160,180,204,.1));-webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.5;transition:opacity .5s}
.glass:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.5), 0 0 80px rgba(160,180,204,.08), inset 0 1px 0 rgba(232,237,245,.08)}
.glass:hover::before{opacity:1}

/* Punch phrases */
.punch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.2rem;margin:4rem 0 2rem}
.punch{padding:2rem 2rem;font-family:Georgia,serif;font-size:1.1rem;color:var(--text);line-height:1.45;font-style:italic}
.punch{background:rgba(232,237,245,.025);border:1px solid var(--border);border-radius:18px;backdrop-filter:blur(16px);transition:all .5s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}
.punch::before{content:"\201C";position:absolute;top:1rem;left:1.2rem;font-size:4rem;color:var(--accent-3);opacity:.25;font-family:Georgia,serif;line-height:1;pointer-events:none}
.punch:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4), 0 0 60px rgba(160,180,204,.1)}

/* Section title */
.section-title{text-align:center;margin-bottom:4rem;max-width:760px;margin-left:auto;margin-right:auto}
.section-title .eyebrow{display:inline-block;font-size:.7rem;letter-spacing:5px;color:var(--accent-2);text-transform:uppercase;margin-bottom:1.2rem;padding:.35rem .9rem;border:1px solid var(--border);border-radius:100px;background:rgba(232,237,245,.025)}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.step{padding:2.5rem 2rem;background:rgba(232,237,245,.025);border:1px solid var(--border);border-radius:18px;backdrop-filter:blur(16px);position:relative;transition:all .5s cubic-bezier(.2,.8,.2,1)}
.step:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4), 0 0 60px rgba(160,180,204,.1)}
.step-num{font-family:Georgia,serif;font-size:3.5rem;color:var(--accent-3);line-height:1;margin-bottom:1rem;font-style:italic;opacity:.7}
.step h3{color:var(--accent);margin-bottom:.8rem}

/* Cases */
.cases{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.case-card{padding:2.5rem;background:rgba(232,237,245,.025);border:1px solid var(--border);border-radius:18px;backdrop-filter:blur(16px);transition:all .5s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}
.case-card:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4), 0 0 80px rgba(160,180,204,.1)}
.case-icon{width:48px;height:48px;margin-bottom:1.5rem;color:var(--accent-2);opacity:.9}

/* Feature list (small grid used in come-funziona) */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:2rem}
.feature{padding:1.3rem 1.4rem;background:rgba(232,237,245,.02);border:1px solid var(--border);border-radius:12px;backdrop-filter:blur(10px);font-size:.95rem;display:flex;gap:.8rem;align-items:flex-start;transition:all .35s}
.feature:hover{border-color:var(--border-strong);background:rgba(232,237,245,.04)}
.feature .dot{width:5px;height:5px;border-radius:50%;background:var(--accent-2);margin-top:.6rem;flex-shrink:0;box-shadow:0 0 8px var(--accent-2)}
.feature .ic{width:22px;height:22px;color:var(--accent-2);flex-shrink:0;margin-top:.1rem;filter:drop-shadow(0 0 6px rgba(160,180,204,.4))}
.feature strong{color:var(--accent);display:block;font-weight:normal;font-family:Georgia,serif;margin-bottom:.2rem}
.feature span{color:var(--muted);font-size:.85rem}

/* Feature table */
.feature-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:18px;background:rgba(232,237,245,.02);backdrop-filter:blur(16px);-webkit-overflow-scrolling:touch}
.feature-table{width:100%;min-width:600px;border-collapse:collapse;font-size:.95rem}
.feature-table thead th{background:rgba(232,237,245,.03);color:var(--accent);font-family:Georgia,serif;font-weight:normal;text-align:left;padding:1.2rem 1.5rem;font-size:.75rem;letter-spacing:3px;text-transform:uppercase;border-bottom:1px solid var(--border)}
.feature-table td{padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);vertical-align:top;color:var(--muted)}
.feature-table tr:last-child td{border-bottom:none}
.feature-table tr{transition:background .25s}
.feature-table tr:hover{background:rgba(232,237,245,.025)}
.feature-table tr:hover td{color:var(--text)}
.feature-table td.cat{color:var(--accent-2);font-size:.72rem;letter-spacing:3px;text-transform:uppercase;white-space:nowrap;width:180px;font-family:Arial,sans-serif}

/* Comparison table */
.compare-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:18px;background:rgba(232,237,245,.02);backdrop-filter:blur(16px)}
.compare{width:100%;min-width:520px;border-collapse:collapse}
.compare th,.compare td{padding:1.2rem 1.5rem;text-align:center;border-bottom:1px solid var(--border)}
.compare thead th{background:rgba(232,237,245,.03);color:var(--accent);font-family:Georgia,serif;font-weight:normal;font-size:.8rem;letter-spacing:3px;text-transform:uppercase}
.compare tbody tr:last-child td{border-bottom:none}
.compare tbody td:first-child{text-align:left;color:var(--text);font-family:Georgia,serif;font-size:1.02rem;font-style:italic}
.compare .yes{color:var(--accent);font-size:1.3rem;text-shadow:0 0 12px rgba(232,237,245,.4)}
.compare .no{color:var(--accent-3);font-size:1.3rem;opacity:.6}
.compare .warn{color:var(--accent-2);font-size:1.3rem}
.compare .intimum-col{background:rgba(160,180,204,.04)}

/* Data flow */
.flow{display:flex;align-items:center;justify-content:center;gap:.8rem;flex-wrap:wrap;margin:3rem auto 1rem;padding:3rem 1.5rem;background:rgba(232,237,245,.02);border:1px solid var(--border);border-radius:24px;backdrop-filter:blur(16px)}
.flow-node{min-width:130px;padding:1.5rem 1rem;text-align:center;background:rgba(232,237,245,.03);border:1px solid var(--border);border-radius:14px;position:relative;transition:all .4s;backdrop-filter:blur(10px)}
.flow-node:hover{border-color:var(--accent-3);background:rgba(232,237,245,.05);transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.3), 0 0 40px rgba(160,180,204,.15)}
.flow-node .icon{width:32px;height:32px;margin:0 auto .7rem;color:var(--accent-2);opacity:.9}
.flow-node .lbl{display:block;font-family:Georgia,serif;color:var(--accent);font-size:.95rem;letter-spacing:.3px}
.flow-arrow{width:40px;height:1px;background:linear-gradient(to right, transparent, var(--accent-3) 50%, transparent);position:relative;overflow:hidden;flex-shrink:0}
.flow-arrow::after{content:"";position:absolute;top:-2px;left:-25px;width:25px;height:5px;background:linear-gradient(to right, transparent, var(--accent));border-radius:2px;filter:blur(1px);animation:flowPulse 2.4s ease-in-out infinite}
.flow-arrow:nth-of-type(2)::after{animation-delay:.3s}
.flow-arrow:nth-of-type(3)::after{animation-delay:.6s}
.flow-arrow:nth-of-type(4)::after{animation-delay:.9s}
.flow-arrow:nth-of-type(5)::after{animation-delay:1.2s}
@keyframes flowPulse{0%{left:-25px;opacity:0}20%{opacity:1}80%{opacity:1}100%{left:100%;opacity:0}}

/* Compliance */
.compliance{padding:3.5rem;border-radius:24px;background:rgba(232,237,245,.025);border:1px solid var(--border);backdrop-filter:blur(16px);position:relative;overflow:hidden}
.compliance::before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg, rgba(232,237,245,.15), transparent 30%, transparent 70%, rgba(160,180,204,.1));-webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.compliance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2rem}
.comp-item{padding:1.3rem;border:1px solid var(--border);background:rgba(232,237,245,.02);border-radius:12px;transition:all .3s}
.comp-item:hover{border-color:var(--border-strong);background:rgba(232,237,245,.04)}
.comp-item strong{color:var(--accent);display:block;margin-bottom:.35rem;font-family:Georgia,serif;font-weight:normal;font-size:1rem}
.comp-item span{color:var(--muted);font-size:.88rem}

/* Form */
.form-wrap{max-width:720px;margin:0 auto;padding:3rem;border:1px solid var(--border);border-radius:24px;background:rgba(232,237,245,.025);backdrop-filter:blur(20px) saturate(150%);position:relative;overflow:hidden}
.form-wrap::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg, rgba(232,237,245,.18), transparent 40%, transparent 60%, rgba(160,180,204,.08));-webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;position:relative}
.form-grid .full{grid-column:1/-1}
label{display:block;font-size:.72rem;color:var(--muted);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:.55rem}
input,textarea,select{width:100%;padding:.95rem 1.1rem;background:rgba(232,237,245,.02);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:.95rem;transition:all .25s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-2);background:rgba(232,237,245,.04);box-shadow:0 0 0 3px rgba(160,180,204,.08)}
textarea{min-height:130px;resize:vertical}
select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23A0B4CC' stroke-width='1.5' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 1.1rem center;padding-right:2.8rem}

/* Contact info (kept minimal if used) */
.contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem}
.contact-info .info{padding:1.5rem;border:1px solid var(--border);border-radius:14px;background:rgba(232,237,245,.025);backdrop-filter:blur(10px)}
.contact-info strong{color:var(--accent-2);font-size:.7rem;letter-spacing:3px;text-transform:uppercase;display:block;margin-bottom:.5rem}

/* Quote banner */
.quote-banner{text-align:center;padding:6rem 2rem;margin:4rem 0;position:relative}
.quote-banner::before,.quote-banner::after{content:"";position:absolute;left:50%;transform:translateX(-50%);width:100px;height:1px;background:linear-gradient(to right, transparent, var(--accent-3), transparent)}
.quote-banner::before{top:0}.quote-banner::after{bottom:0}
.quote-banner blockquote{font-family:Georgia,serif;font-size:clamp(1.6rem,3.4vw,2.8rem);color:var(--accent);font-style:italic;line-height:1.35;max-width:900px;margin:0 auto;letter-spacing:-.5px}
.quote-banner cite{display:block;margin-top:2rem;color:var(--accent-3);font-style:normal;font-size:.72rem;letter-spacing:5px;text-transform:uppercase}

/* Footer */
footer{border-top:1px solid var(--border);padding:2.5rem 0 2rem;margin-top:4rem;background:rgba(10,10,10,.5);backdrop-filter:blur(12px)}
.footer-min{text-align:center;padding:.5rem 0}
.footer-min .tag{display:block;font-family:Georgia,serif;color:var(--accent);letter-spacing:4px;font-size:.85rem;margin-bottom:.6rem;font-style:italic}
.footer-min .vat{display:block;color:var(--accent-3);font-size:.68rem;letter-spacing:2px;text-transform:uppercase}

.footer-grid{display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:center;padding:.5rem 0}
.footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:.3rem}
.footer-brand .tag{font-family:Georgia,serif;color:var(--accent);letter-spacing:3px;font-size:.8rem;font-style:italic;letter-spacing:2.5px}
.footer-nav{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.footer-nav a{color:var(--muted);font-size:.82rem;letter-spacing:1.5px;transition:color .2s}
.footer-nav a:hover{color:var(--accent)}
.footer-meta{text-align:right;display:flex;flex-direction:column;gap:.3rem}
.footer-meta .powered{color:var(--muted);font-size:.78rem;letter-spacing:1px}
.footer-meta .vat{color:var(--accent-3);font-size:.65rem;letter-spacing:2px;text-transform:uppercase}
@media (max-width:760px){
  .footer-grid{grid-template-columns:1fr;text-align:center;gap:1.2rem}
  .footer-brand{align-items:center}
  .footer-meta{text-align:center;align-items:center}
  .footer-nav{gap:1rem}
}

/* Fade-in on load (hero) */
.fade-in{opacity:0;transform:translateY(16px);animation:fadeUp 1s ease forwards}
.fade-in.d1{animation-delay:.2s}
.fade-in.d2{animation-delay:.4s}
.fade-in.d3{animation-delay:.6s}
.fade-in.d4{animation-delay:.8s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s ease, transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal.in-view{opacity:1;transform:translateY(0)}

/* Divider */
.divider{width:60px;height:1px;background:var(--accent-3);margin:2rem auto;opacity:.5}

/* Tablet */
@media (max-width:960px){
  .nav-inner{padding:.9rem 1.2rem}
  section{padding:4.5rem 0}
  .compliance{padding:2rem}
  .hero{padding:5rem 0 4rem;min-height:auto}
  .hero-logo{width:180px;height:180px;margin-bottom:2rem}
  .punch-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
  .cases{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
  .flow-node{min-width:120px;padding:1.2rem .8rem}
  .flow-arrow{width:26px}
  .container{padding:0 1.5rem}
  .form-wrap{padding:2rem}
}

/* Mobile */
@media (max-width:760px){
  .hamburger{display:flex}
  .nav-inner{padding:.75rem 1rem}
  .nav-links{
    position:fixed;top:64px;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:rgba(10,10,10,.95);
    backdrop-filter:blur(20px) saturate(180%);
    border-bottom:1px solid var(--border);
    padding:1rem 1.2rem 1.5rem;
    gap:.2rem;
    transform:translateY(-110%);
    transition:transform .4s cubic-bezier(.2,.8,.2,1);
    max-height:calc(100vh - 64px);
    overflow-y:auto;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:.95rem .5rem;border-bottom:1px solid var(--border);font-size:1rem}
  .nav-links a.active::after{display:none}
  .nav-links a.active{color:var(--accent)}
  .lang-switch{margin:1.2rem 0 0;justify-content:center}
  body.nav-open{overflow:hidden}

  section{padding:3.5rem 0}
  .hero{padding:3rem 0 2rem}
  .hero-logo{width:140px;height:140px;margin-bottom:1.5rem}
  .hero .kicker{font-size:.65rem;letter-spacing:3px;padding:.4rem .8rem}
  .hero .lede{font-size:1.05rem;margin:1.2rem auto 2rem}
  .btn-row{flex-direction:column;align-items:stretch;gap:.7rem}
  .btn{width:100%;padding:.9rem 1.2rem;font-size:.78rem;letter-spacing:1.5px}

  .form-grid{grid-template-columns:1fr}
  .form-wrap{padding:1.6rem}
  .compliance{padding:1.5rem}
  .compliance-grid{grid-template-columns:1fr;gap:.7rem}
  .steps{grid-template-columns:1fr;gap:1rem}
  .step{padding:1.8rem 1.5rem}
  .step-num{font-size:2.8rem}
  .cases{grid-template-columns:1fr;gap:1rem}
  .case-card{padding:1.8rem 1.5rem}
  .features{grid-template-columns:1fr;gap:.7rem}
  .punch-grid{grid-template-columns:1fr;gap:.8rem;margin:2.5rem 0 1rem}
  .punch{padding:1.5rem 1.5rem 1.5rem 2rem;font-size:1.02rem}
  .contact-info{grid-template-columns:1fr}
  .quote-banner{padding:3.5rem 1rem;margin:2rem 0}
  .container{padding:0 1.1rem}

  .logo-svg{width:36px;height:36px}
  h1{font-size:2.3rem;line-height:1.1;letter-spacing:-1px}
  h2{font-size:1.7rem}
  h3{font-size:1.2rem}
  .section-title{margin-bottom:2.5rem}

  .flow{flex-direction:column;padding:2rem 1rem;gap:.4rem}
  .flow-node{width:100%;max-width:260px}
  .flow-arrow{width:1px;height:32px;background:linear-gradient(to bottom, transparent, var(--accent-3) 50%, transparent)}
  .flow-arrow::after{top:-25px;left:-2px;width:5px;height:25px;background:linear-gradient(to bottom, transparent, var(--accent));animation:flowPulseV 2.4s ease-in-out infinite}
  @keyframes flowPulseV{0%{top:-25px;opacity:0}20%{opacity:1}80%{opacity:1}100%{top:100%;opacity:0}}

  .feature-table-wrap,.compare-wrap{position:relative}
  .feature-table-wrap::after,.compare-wrap::after{content:"→";position:absolute;right:.6rem;top:.6rem;color:var(--accent-3);font-size:.85rem;pointer-events:none;animation:nudge 1.6s ease-in-out infinite;opacity:.7}
  @keyframes nudge{0%,100%{transform:translateX(0);opacity:.3}50%{transform:translateX(5px);opacity:.9}}
  .feature-table,.compare{font-size:.88rem}
  .feature-table td.cat{width:130px}
}

/* Small */
@media (max-width:430px){
  h1{font-size:2rem}
  .hero-logo{width:120px;height:120px}
  .hero .lede{font-size:1rem}
  .quote-banner blockquote{font-size:1.35rem}
  .form-wrap{padding:1.3rem}
  .step,.case-card,.punch{padding:1.4rem}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .logo-svg .sq1,.logo-svg .sq2,.logo-svg .sq3,.fade-in,.flow-arrow::after,.typing,.hero-logo{animation:none !important}
  .fade-in{opacity:1;transform:none}
  .typing{border-right:none;white-space:normal;width:auto}
  .reveal{opacity:1;transform:none;transition:none}
}
