/* ===== Vadrame Magicien — feuille de style partagée ===== */
:root{
  --bg:#0a0711; --bg-2:#0e0a18;
  --surface:rgba(255,255,255,.035); --surface-2:rgba(255,255,255,.055);
  --hair:rgba(255,255,255,.09); --hair-strong:rgba(255,255,255,.16);
  --text:#efebf6; --muted:#a8a1ba; --muted-2:#7e7793;
  --violet:#9b6bff; --violet-2:#c4a0ff; --violet-glow:rgba(139,92,246,.45);
  --gold:#e8c87a;
  --r-lg:2rem; --r-md:1.25rem;
  --ease:cubic-bezier(.32,.72,0,1);
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;width:100%}
body{background:var(--bg);color:var(--text);font-family:"Plus Jakarta Sans",system-ui,sans-serif;
  font-weight:400;line-height:1.65;overflow-x:hidden;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-weight:400;line-height:1.05;letter-spacing:-.02em}

.aura{position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60% 50% at 78% 6%, rgba(139,92,246,.22), transparent 60%),
    radial-gradient(50% 45% at 12% 26%, rgba(94,53,177,.16), transparent 60%),
    radial-gradient(70% 60% at 50% 112%, rgba(155,107,255,.14), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg-2));}
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;color:var(--violet-2);border:1px solid var(--hair);border-radius:100px;padding:7px 15px;
  background:var(--surface);backdrop-filter:blur(6px)}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--violet);box-shadow:0 0 10px var(--violet-glow)}
.muted{color:var(--muted)}

/* nav */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:center;padding:18px 16px}
.navbar{display:flex;align-items:center;gap:22px;width:100%;max-width:var(--maxw);padding:11px 12px 11px 22px;border-radius:100px;
  background:rgba(14,10,24,.6);backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--hair);
  box-shadow:0 12px 40px -18px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.06);transition:background .5s var(--ease)}
.navbar.scrolled{background:rgba(12,8,20,.86)}
.brand{display:flex;align-items:center;gap:10px;font-family:"Fraunces",serif;font-size:20px;letter-spacing:.02em;white-space:nowrap}
.brand .spade{width:24px;height:24px;color:var(--violet-2);filter:drop-shadow(0 0 8px var(--violet-glow))}
.nav-links{display:flex;gap:2px;margin-left:auto;align-items:center}
.nav-item{position:relative}
.nav-item>a{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--muted);padding:8px 13px;border-radius:100px;font-weight:500;transition:.3s var(--ease);white-space:nowrap}
.nav-item>a:hover,.nav-item>a.active{color:var(--text);background:var(--surface)}
.nav-item>a .car{width:10px;height:10px;opacity:.7;transition:transform .35s var(--ease)}
.nav-item:hover>a .car{transform:rotate(180deg)}
.drop{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);min-width:240px;
  background:rgba(16,11,26,.96);backdrop-filter:blur(20px);border:1px solid var(--hair-strong);border-radius:18px;padding:8px;
  box-shadow:0 24px 50px -20px rgba(0,0,0,.9);opacity:0;visibility:hidden;transition:.35s var(--ease)}
.nav-item:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:block;padding:10px 14px;border-radius:12px;font-size:14px;color:var(--muted);transition:.25s var(--ease)}
.drop a:hover{background:var(--surface-2);color:var(--text)}
.nav-cta{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:600;background:var(--text);color:#0a0711;
  padding:9px 9px 9px 18px;border-radius:100px;white-space:nowrap;transition:transform .3s var(--ease),box-shadow .3s var(--ease);margin-left:6px}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 26px -10px rgba(255,255,255,.4)}
.nav-cta .ic{width:28px;height:28px;border-radius:50%;background:rgba(10,7,17,.1);display:grid;place-items:center;transition:.3s var(--ease)}
.nav-cta:hover .ic{transform:translate(2px,-1px) scale(1.06)}
.nav-cta .ic svg{width:14px;height:14px}
.burger{display:none;width:44px;height:44px;border:1px solid var(--hair);border-radius:50%;background:var(--surface);
  flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;margin-left:auto}
.burger span{width:18px;height:1.6px;background:var(--text);border-radius:2px;transition:.45s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

.overlay{position:fixed;inset:0;z-index:45;background:rgba(8,5,14,.92);backdrop-filter:blur(26px);
  display:flex;flex-direction:column;justify-content:center;gap:4px;padding:90px 34px 40px;overflow-y:auto;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s}
.overlay.open{opacity:1;visibility:visible}
.overlay .ov-group{transform:translateY(24px);opacity:0;transition:.6s var(--ease)}
.overlay.open .ov-group{transform:translateY(0);opacity:1}
.overlay.open .ov-group:nth-child(1){transition-delay:.06s}.overlay.open .ov-group:nth-child(2){transition-delay:.1s}
.overlay.open .ov-group:nth-child(3){transition-delay:.14s}.overlay.open .ov-group:nth-child(4){transition-delay:.18s}
.overlay.open .ov-group:nth-child(5){transition-delay:.22s}.overlay.open .ov-group:nth-child(6){transition-delay:.26s}
.overlay.open .ov-group:nth-child(7){transition-delay:.3s}
.overlay .ov-group>a{font-family:"Fraunces",serif;font-size:27px;color:var(--text);display:block;padding:8px 0}
.overlay .ov-sub{display:flex;flex-wrap:wrap;gap:8px;padding:2px 0 12px;border-bottom:1px solid var(--hair);margin-bottom:6px}
.overlay .ov-sub a{font-size:13px;color:var(--muted);background:var(--surface);border:1px solid var(--hair);border-radius:100px;padding:6px 13px}
.overlay .ov-cta{margin-top:22px;display:inline-flex;align-items:center;gap:10px;color:#0a0711;background:var(--violet-2);
  font-weight:700;font-size:16px;padding:14px 22px;border-radius:100px;width:max-content}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:12px;font-weight:600;font-size:15px;cursor:pointer;border:none;
  padding:14px 14px 14px 26px;border-radius:100px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease);font-family:inherit}
.btn .ic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;transition:.35s var(--ease)}
.btn .ic svg{width:15px;height:15px}
.btn:active{transform:scale(.97)}
.btn-primary{background:linear-gradient(180deg,#a87bff,#7b46e6);color:#fff;box-shadow:0 14px 40px -14px var(--violet-glow),inset 0 1px 0 rgba(255,255,255,.25)}
.btn-primary .ic{background:rgba(0,0,0,.18)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 48px -14px var(--violet-glow),inset 0 1px 0 rgba(255,255,255,.3)}
.btn-primary:hover .ic{transform:translate(3px,-1px) scale(1.08)}
.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--hair-strong);padding:14px 24px}
.btn-ghost:hover{background:var(--surface-2);transform:translateY(-2px)}
.phone-link{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;color:var(--text);padding:14px 8px}
.phone-link svg{width:17px;height:17px;color:var(--violet-2)}

/* hero (home) */
.hero{min-height:100dvh;display:flex;align-items:center;padding:148px 0 70px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(40px,5.6vw,74px);margin:24px 0 22px;text-wrap:balance}
.hero h1 em,.page-hero h1 em{font-style:italic;color:var(--violet-2)}
.hero .lede{font-size:clamp(16px,1.5vw,18.5px);color:var(--muted);max-width:33em;margin-bottom:34px;line-height:1.7}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.rating{display:flex;align-items:center;gap:14px;margin-top:36px;padding-top:28px;border-top:1px solid var(--hair);max-width:440px}
.stars{display:flex;gap:2px}
.stars svg{width:18px;height:18px;color:var(--gold)}
.rating .r-txt{font-size:13.5px;color:var(--muted);line-height:1.4}
.rating .r-txt b{color:var(--text);font-weight:600}
.portrait{position:relative;padding:9px;border-radius:calc(var(--r-lg) + 6px);background:linear-gradient(150deg,var(--surface-2),transparent);
  border:1px solid var(--hair);box-shadow:0 50px 90px -40px rgba(0,0,0,.9)}
.portrait .frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:inset 0 1px 1px rgba(255,255,255,.14)}
.portrait .frame img{width:100%;height:560px;object-fit:cover;object-position:center 18%}
.portrait .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,7,17,.55))}
.float-badge{position:absolute;left:-18px;bottom:30px;z-index:2;display:flex;align-items:center;gap:12px;padding:13px 18px;border-radius:18px;
  background:rgba(14,10,24,.78);backdrop-filter:blur(14px);border:1px solid var(--hair-strong);box-shadow:0 20px 40px -18px rgba(0,0,0,.9)}
.float-badge .num{font-family:"Fraunces",serif;font-size:30px;color:var(--violet-2);line-height:1}
.float-badge small{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.tv-badge{position:absolute;right:-12px;top:26px;z-index:2;padding:9px 16px;border-radius:100px;background:rgba(14,10,24,.78);
  backdrop-filter:blur(14px);border:1px solid var(--hair-strong);font-size:12px;font-weight:600;letter-spacing:.04em}
.tv-badge span{color:var(--violet-2)}

/* page hero (interior) */
.page-hero{padding:150px 0 56px}
.page-hero .crumbs{font-size:13px;color:var(--muted-2);margin-bottom:18px}
.page-hero .crumbs a:hover{color:var(--text)}
.page-hero .crumbs span{color:var(--violet-2)}
.page-hero h1{font-size:clamp(36px,5vw,62px);margin:14px 0 18px;text-wrap:balance;max-width:14ch}
.page-hero .intro{color:var(--muted);font-size:clamp(16px,1.5vw,18px);max-width:40em;line-height:1.7;margin-bottom:30px}
.page-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.page-hero .ph-media{position:relative;padding:8px;border-radius:calc(var(--r-lg)+4px);background:var(--surface);border:1px solid var(--hair)}
.page-hero .ph-media img{width:100%;height:460px;object-fit:cover;border-radius:var(--r-lg);box-shadow:inset 0 1px 1px rgba(255,255,255,.12)}

/* clients logos */
.clients{padding:30px 0 64px;text-align:center}
.clients p.kick{font-size:13px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-2);margin-bottom:8px}
.clients h3{font-size:clamp(20px,2.4vw,27px);color:var(--text);margin-bottom:36px;font-weight:400}
.clients h3 em{font-style:italic;color:var(--violet-2)}
.logo-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:10px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--hair)}
.logo-cell{display:grid;place-items:center;min-height:96px;padding:20px;border-radius:var(--r-md);background:rgba(255,255,255,.02);border:1px solid transparent;transition:.4s var(--ease)}
.logo-cell:hover{background:var(--surface-2);border-color:var(--hair)}
.logo-cell img{max-height:34px;width:auto;filter:brightness(0) invert(1);opacity:.5;transition:.4s var(--ease)}
.logo-cell:hover img{opacity:.95}

/* section heads */
.sec{padding:96px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(30px,4vw,50px);margin:20px 0 16px;text-wrap:balance}
.sec-head h2 em{font-style:italic;color:var(--violet-2)}
.sec-head p{color:var(--muted);font-size:16.5px;line-height:1.7}

/* split content */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative;padding:8px;border-radius:calc(var(--r-lg)+4px);background:var(--surface);border:1px solid var(--hair)}
.split-media img{width:100%;height:480px;object-fit:cover;border-radius:var(--r-lg);box-shadow:inset 0 1px 1px rgba(255,255,255,.12)}
.split-text h2{font-size:clamp(28px,3.6vw,44px);margin:16px 0 20px}
.split-text h2 em{font-style:italic;color:var(--violet-2)}
.split-text p{color:var(--muted);margin-bottom:16px;font-size:16.5px;line-height:1.75;max-width:40em}
.split-text p strong{color:var(--text);font-weight:600}

/* checklist */
.checklist{list-style:none;margin:8px 0 26px;display:flex;flex-direction:column;gap:13px}
.checklist li{display:flex;gap:13px;align-items:flex-start;color:var(--muted);font-size:15.5px;line-height:1.55}
.checklist li svg{width:22px;height:22px;color:var(--violet-2);flex-shrink:0;margin-top:1px}
.checklist li b{color:var(--text);font-weight:600}

/* trust strip */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.trust .t{display:flex;align-items:center;gap:14px;padding:20px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--hair)}
.trust .t svg{width:24px;height:24px;color:var(--violet-2);flex-shrink:0}
.trust .t b{display:block;font-size:14.5px;color:var(--text);font-weight:600}
.trust .t span{font-size:12.5px;color:var(--muted)}

/* services / cards grid */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:30px;border:1px solid var(--hair);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.svc img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .8s var(--ease)}
.svc::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,7,17,.2) 30%,rgba(10,7,17,.92))}
.svc:hover{transform:translateY(-6px);box-shadow:0 40px 70px -34px rgba(0,0,0,.9)}
.svc:hover img.bg{transform:scale(1.07)}
.svc .num{font-size:12px;letter-spacing:.2em;color:var(--violet-2);font-weight:600;margin-bottom:10px}
.svc h3{font-size:30px;margin-bottom:10px}
.svc p{color:var(--muted);font-size:14.5px;margin-bottom:18px;line-height:1.6}
.svc .more{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--text)}
.svc .more svg{width:14px;height:14px;transition:transform .35s var(--ease)}
.svc:hover .more svg{transform:translateX(4px)}

/* events */
.ev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.ev{display:grid;grid-template-columns:150px 1fr;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);border:1px solid var(--hair);transition:.5s var(--ease)}
.ev:hover{border-color:var(--hair-strong);transform:translateY(-4px)}
.ev img{width:150px;height:100%;min-height:190px;object-fit:cover}
.ev .ev-body{padding:26px 28px}
.ev h3{font-size:23px;margin-bottom:9px}
.ev p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.ev a{font-size:13.5px;font-weight:600;color:var(--violet-2);display:inline-flex;align-items:center;gap:7px}
.ev a svg{width:13px;height:13px;transition:transform .35s var(--ease)}
.ev:hover a svg{transform:translateX(4px)}

/* zones */
.zones{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.zone{position:relative;border-radius:var(--r-lg);overflow:hidden;padding:38px;min-height:320px;display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--hair)}
.zone img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.zone::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,7,17,.25),rgba(10,7,17,.9))}
.zone .dep{font-size:12px;letter-spacing:.18em;color:var(--violet-2);font-weight:600;margin-bottom:6px}
.zone h3{font-size:27px;margin-bottom:10px}
.zone p{font-size:14px;color:var(--muted);line-height:1.6}

/* band */
.band{position:relative;border-radius:var(--r-lg);overflow:hidden;padding:64px 56px;
  background:linear-gradient(135deg,rgba(139,92,246,.16),rgba(20,14,32,.6));border:1px solid var(--hair-strong);box-shadow:inset 0 1px 0 rgba(255,255,255,.07)}
.band-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:48px;align-items:center}
.band h2{font-size:clamp(28px,3.6vw,44px);margin-bottom:20px}
.band h2 em{font-style:italic;color:var(--violet-2)}
.band p{color:var(--muted);font-size:16px;margin-bottom:14px;line-height:1.75;max-width:40em}
.band p strong{color:var(--text)}
.band-stats{display:flex;flex-direction:column;gap:16px}
.stat{padding:24px;border-radius:var(--r-md);background:rgba(10,7,17,.45);border:1px solid var(--hair);text-align:center}
.stat .big{font-family:"Fraunces",serif;font-size:46px;color:var(--violet-2);line-height:1}
.stat small{display:block;font-size:13px;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:.1em}
.cta-center{text-align:center}
.cta-center .btn{margin-top:6px}

/* testimonials */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tst{padding:30px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--hair);display:flex;flex-direction:column}
.tst .stars{margin-bottom:16px}
.tst .stars svg{width:15px;height:15px;color:var(--gold)}
.tst blockquote{font-family:"Fraunces",serif;font-size:18.5px;line-height:1.5;color:var(--text);font-style:italic;margin-bottom:20px;flex:1}
.tst .who{font-size:13.5px;color:var(--muted);font-weight:600}
.reviews-cta{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:30px;flex-wrap:wrap}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal a{border-radius:var(--r-md);overflow:hidden;position:relative;border:1px solid var(--hair)}
.gal a img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gal a:hover img{transform:scale(1.08)}
.gal a.tall{grid-row:span 2}.gal a.wide{grid-column:span 2}

/* press */
.press-wall{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;align-items:center}
.press-wall a{display:grid;place-items:center;padding:18px;min-height:90px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--hair);transition:.4s var(--ease)}
.press-wall a:hover{background:var(--surface-2)}
.press-wall img{max-height:54px;max-width:100%;width:auto;border-radius:6px;opacity:.82;transition:.4s var(--ease)}
.press-wall a:hover img{opacity:1}

/* faq */
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:880px;margin:0 auto}
.faq-item{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--hair);overflow:hidden;transition:border-color .4s var(--ease)}
.faq-item[open]{border-color:var(--hair-strong)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:20px;font-weight:600;font-size:16.5px;color:var(--text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .pl{position:relative;width:20px;height:20px;flex-shrink:0}
.faq-item summary .pl::before,.faq-item summary .pl::after{content:"";position:absolute;background:var(--violet-2);border-radius:2px;transition:.4s var(--ease)}
.faq-item summary .pl::before{top:9px;left:0;width:20px;height:2px}
.faq-item summary .pl::after{top:0;left:9px;width:2px;height:20px}
.faq-item[open] summary .pl::after{transform:rotate(90deg);opacity:0}
.faq-item .ans{padding:0 26px 24px;color:var(--muted);font-size:15px;line-height:1.7;max-width:64ch}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
.contact-media{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--hair);min-height:480px}
.contact-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top}
.contact-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,7,17,.92))}
.contact-media .ci{position:absolute;left:34px;right:34px;bottom:32px;z-index:2}
.contact-media .ci h3{font-size:30px;margin-bottom:14px}
.contact-media .ci .row{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-size:15px;font-weight:500}
.contact-media .ci .row svg{width:18px;height:18px;color:var(--violet-2)}
.form{padding:38px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--hair)}
.form .field{margin-bottom:18px}
.form label{display:block;font-size:13px;color:var(--muted);margin-bottom:8px;font-weight:500}
.form input,.form textarea{width:100%;background:rgba(10,7,17,.45);border:1px solid var(--hair);border-radius:14px;padding:14px 16px;color:var(--text);font-family:inherit;font-size:15px;transition:border-color .3s var(--ease),box-shadow .3s var(--ease);min-height:50px}
.form textarea{resize:vertical;min-height:120px}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(139,92,246,.2)}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.form .note{font-size:12.5px;color:var(--muted-2);margin-top:14px;text-align:center}
.form .ok{display:none;margin-top:16px;padding:14px 18px;border-radius:14px;background:rgba(139,92,246,.14);border:1px solid var(--hair-strong);font-size:14px;color:var(--violet-2);text-align:center}

/* footer */
footer{border-top:1px solid var(--hair);padding:60px 0 40px;margin-top:90px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:48px}
.foot-brand .brand{margin-bottom:16px}
.foot-brand p{color:var(--muted);font-size:14px;max-width:30em;line-height:1.7}
.foot-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted-2);margin-bottom:16px;font-weight:600}
.foot-col a,.foot-col span{display:block;color:var(--muted);font-size:14px;margin-bottom:10px;transition:color .3s var(--ease)}
.foot-col a:hover{color:var(--text)}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--surface);border:1px solid var(--hair);transition:.35s var(--ease)}
.socials a:hover{background:var(--surface-2);transform:translateY(-2px)}
.socials a svg{width:16px;height:16px;color:var(--muted)}
.socials a:hover svg{color:var(--violet-2)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:28px;border-top:1px solid var(--hair);font-size:13px;color:var(--muted-2);flex-wrap:wrap}

/* reveal */
.rv{opacity:0;transform:translateY(34px);filter:blur(6px);transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.rv.in{opacity:1;transform:none;filter:none}

/* responsive */
@media(max-width:980px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .burger{display:flex}
  .hero-grid,.split,.band-grid,.contact-grid,.page-hero-grid{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .svc-grid,.tst-grid{grid-template-columns:1fr 1fr}
  .logo-wall{grid-template-columns:repeat(3,1fr)}
  .press-wall{grid-template-columns:repeat(4,1fr)}
  .portrait,.page-hero .ph-media{order:0;max-width:480px;margin:0 auto}
  .portrait .frame img{height:440px}.split-media img,.page-hero .ph-media img{height:400px}
  .float-badge{left:10px}.tv-badge{right:10px}
}
@media(max-width:640px){
  .wrap{padding:0 18px}
  .sec{padding:62px 0}
  .hero{padding:118px 0 50px}.page-hero{padding:120px 0 40px}
  .svc-grid,.tst-grid,.ev-grid,.zones,.trust,.logo-wall{grid-template-columns:1fr}
  .logo-wall{grid-template-columns:1fr 1fr}.press-wall{grid-template-columns:1fr 1fr 1fr}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:150px}.gal a.wide{grid-column:span 1}
  .band{padding:40px 26px}
  .ev{grid-template-columns:1fr}.ev img{width:100%;height:180px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn{justify-content:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .rv{opacity:1;transform:none;filter:none}
  html{scroll-behavior:auto}
}
