:root{
  --purple:#3D0E5C;
  --purple-deep:#250635;
  --purple-ink:#1A0425;
  --purple-soft:#6A2E8F;
  --panel-bg:#1A0425;        /* always-dark panel bg (process, footer, form) */
  --panel-fg:#F3EEE3;        /* text on panel-bg */
  --panel-muted:#B9A9C9;
  --accent:#E9FF70;
  --paper:#F3EEE3;
  --paper-2:#EAE3D4;
  --ink:#1A0425;
  --muted:#6B5E77;
  --line:rgba(26,4,37,.14);
  --radius:14px;
  --serif:'Instrument Serif', ui-serif, Georgia, serif;
  --sans:'Inter', -apple-system, system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --maxw:1320px;
  --pad: clamp(20px, 4vw, 56px);
}
[data-theme="dark"]{
  --paper:#140220;
  --paper-2:#1C0730;
  --ink:#F3EEE3;
  --muted:#B9A9C9;
  --line:rgba(243,238,227,.14);
  --purple:#B388E0;
  --purple-soft:#8C4FBE;
  /* --purple-ink / --purple-deep / --panel-* stay the same deep-purple values */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11"}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img{max-width:100%;display:block}

/* ---------- Noise overlay for warmth ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:80;
  width:min(calc(100% - 32px), 1180px);
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px 10px 20px;
  background:color-mix(in oklab, var(--paper) 78%, transparent);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  border:1px solid var(--line);
  border-radius:100px;
}
.nav .brand{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;letter-spacing:.01em}
.nav .brand img.full{height:26px;width:auto;display:block}
[data-theme="dark"] .nav .brand img.full{filter:invert(1) hue-rotate(180deg) brightness(1.4)}
.nav ul{display:flex;gap:4px;list-style:none;padding:0;margin:0}
.nav ul a{display:inline-block;padding:10px 14px;font-size:13.5px;color:var(--ink);border-radius:100px;transition:background .2s}
.nav ul a:hover{background:color-mix(in oklab, var(--purple) 8%, transparent)}
.nav ul a.active{background:var(--ink);color:var(--paper)}
.nav .cta{
  background:var(--purple);color:#fff;border:none;border-radius:100px;padding:11px 18px;font-size:13.5px;font-weight:500;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:transform .15s, background .2s;
}
.nav .cta:hover{background:var(--purple-ink);transform:translateY(-1px)}
.nav .cta .arr{width:14px;height:14px}
.nav-mobile-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:100px;padding:10px 14px;cursor:pointer;color:inherit}
@media (max-width:860px){
  .nav ul{display:none}
  .nav-mobile-toggle{display:inline-flex}
  .nav .cta{display:none}
}

/* ---------- Shared ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--muted)}
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:100px;
  border:1px solid transparent;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;
}
.btn.primary{background:var(--ink);color:var(--paper)}
.btn.primary:hover{background:var(--purple);color:#fff}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--ink)}
.btn .arr{width:16px;height:16px;transition:transform .2s}
.btn:hover .arr{transform:translate(2px,-2px)}

/* ---------- Hero ---------- */
.hero{
  position:relative;padding:160px clamp(28px, 5vw, 88px) 130px;min-height:100vh;display:flex;align-items:center;
  overflow:hidden;
}
.hero-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:24px;position:relative;z-index:2;width:100%}
.hero h1{
  font-family:var(--serif);font-weight:400;font-size:clamp(52px, 8.5vw, 138px);
  line-height:.95;letter-spacing:-.02em;margin:0;position:relative;
  perspective:1200px;
}
.hero h1 .line{display:block;position:relative;will-change:transform;transform-style:preserve-3d;animation:floatLine 9s ease-in-out infinite}
.hero h1 .line:nth-child(1){animation-delay:0s}
.hero h1 .line:nth-child(2){animation-delay:-3s}
.hero h1 .line:nth-child(3){animation-delay:-6s}
@keyframes floatLine{
  0%,100%{transform:translate3d(0,0,0) rotateX(0deg)}
  50%{transform:translate3d(0,-14px,40px) rotateX(-2deg)}
}
.hero h1 .line::after{
  content:"";position:absolute;left:4%;right:4%;bottom:-.08em;height:.18em;
  background:radial-gradient(ellipse at center, color-mix(in oklab, var(--purple) 40%, transparent) 0%, transparent 70%);
  filter:blur(10px);opacity:.55;z-index:-1;
  animation:floatShadow 9s ease-in-out infinite;
}
.hero h1 .line:nth-child(2)::after{animation-delay:-3s}
.hero h1 .line:nth-child(3)::after{animation-delay:-6s}
@keyframes floatShadow{
  0%,100%{transform:scale(1);opacity:.55}
  50%{transform:scale(.85);opacity:.3}
}
.hero h1 .it{font-style:italic;color:var(--purple)}
.hero h1 .orbit{display:inline-flex;align-items:center;vertical-align:middle;gap:0}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;padding:8px 14px 8px 10px;border:1px solid var(--line);
  border-radius:100px;font-size:12.5px;color:var(--muted);background:color-mix(in oklab, var(--paper-2) 60%, transparent);
}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:#2ec27e;box-shadow:0 0 0 4px color-mix(in oklab, #2ec27e 22%, transparent)}
.hero-sub{
  display:grid;grid-template-columns:1fr;gap:28px;margin-top:8px;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
}
.hero-sub p{font-size:17px;line-height:1.55;color:var(--muted);max-width:48ch;margin:0}
.hero-meta{display:flex;gap:32px;align-items:flex-end;justify-content:flex-end;flex-wrap:wrap}
.hero-meta .stat{text-align:right}
.hero-meta .n{font-family:var(--serif);font-size:44px;line-height:1;letter-spacing:-.02em}
.hero-meta .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.hero-ctas{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap;align-items:center}
.hero-scroll{
  position:absolute;bottom:28px;left:var(--pad);display:flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);z-index:2;
}
.hero-scroll .line{width:44px;height:1px;background:var(--muted);position:relative;overflow:hidden}
.hero-scroll .line::after{content:"";position:absolute;inset:0;background:var(--purple);transform:translateX(-100%);animation:slide 2.4s ease-in-out infinite}
@keyframes slide{50%{transform:translateX(0)}100%{transform:translateX(100%)}}

/* Orbital SVG */
.orbital{
  position:absolute;top:50%;right:-14vw;transform:translateY(-50%);width:min(640px, 50vw);aspect-ratio:1;pointer-events:none;opacity:.85;
}
.orbital svg{width:100%;height:100%;animation:rot 60s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.orb-dot{animation:bob 6s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(-8px)}}

.hero-runner{
  position:absolute;left:0;right:0;bottom:0;padding:14px 0;border-top:1px solid var(--line);
  background:color-mix(in oklab, var(--paper) 90%, transparent);
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  overflow:hidden;white-space:nowrap;z-index:3;
}
.hero-runner .track{display:inline-flex;gap:48px;animation:marq 40s linear infinite}
.hero-runner .track span{display:inline-flex;align-items:center;gap:14px}
.hero-runner .track span::after{content:"✦";color:var(--purple);opacity:.7}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Section heads ---------- */
section{position:relative;padding:110px var(--pad) 110px}
.section-head{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:end;max-width:var(--maxw);margin:0 auto 56px}
.section-head h2{
  font-family:var(--serif);font-weight:400;font-size:clamp(40px, 6vw, 84px);line-height:1;letter-spacing:-.02em;margin:12px 0 0;
}
.section-head h2 .it{font-style:italic;color:var(--purple)}
.section-head p{color:var(--muted);font-size:17px;line-height:1.55;max-width:44ch;margin:0 0 0 auto}
@media (max-width:800px){.section-head{grid-template-columns:1fr}.section-head p{margin-left:0}}

/* ---------- About ---------- */
.about{background:var(--paper)}
.about-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.2fr .9fr;gap:56px;align-items:start}
.about-copy p{font-size:18px;line-height:1.6;color:var(--ink);max-width:58ch}
.about-copy p + p{margin-top:18px;color:var(--muted)}
.about-bullets{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:14px}
.about-bullets li{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:var(--paper-2)}
.about-bullets li .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--purple);text-transform:uppercase;margin-top:4px;min-width:32px}
.about-bullets li .v{font-size:15.5px;line-height:1.5}
.about-card{
  border-radius:28px;padding:28px;background:var(--panel-bg);color:var(--panel-fg);position:relative;overflow:hidden;
  background-image:radial-gradient(circle at 80% 20%, color-mix(in oklab, #6A2E8F 60%, transparent) 0%, transparent 60%);
}
.about-card h3{font-family:var(--serif);font-size:34px;font-weight:400;letter-spacing:-.01em;margin:32px 0 10px;line-height:1.1}
.about-card p{color:var(--panel-muted);font-size:14.5px;line-height:1.6;margin:0}
.about-card .rings{position:absolute;right:-60px;top:-60px;width:260px;opacity:.35}
.about-card .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.about-card .tags span{font-family:var(--mono);font-size:10.5px;padding:6px 10px;border-radius:100px;background:rgba(243,238,227,.08);letter-spacing:.08em;text-transform:uppercase;border:1px solid rgba(243,238,227,.12)}
.about-card .sig{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:#c8b7d6}
@media (max-width:900px){.about-grid{grid-template-columns:1fr}}

/* ---------- Services ---------- */
.services{background:var(--paper-2)}
.svc-list{max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.svc{
  display:grid;grid-template-columns:90px 1.2fr 1.6fr 140px;gap:32px;align-items:center;
  padding:32px 4px;border-bottom:1px solid var(--line);cursor:pointer;position:relative;
  transition:padding .3s;
}
.svc .num{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--muted)}
.svc .name{font-family:var(--serif);font-size:clamp(28px, 3.4vw, 44px);line-height:1;letter-spacing:-.01em}
.svc .desc{font-size:15px;line-height:1.55;color:var(--muted);max-width:48ch}
.svc .tools{display:flex;flex-wrap:wrap;gap:6px;justify-self:end}
.svc .tools span{font-family:var(--mono);font-size:10.5px;padding:5px 9px;border-radius:100px;background:var(--paper);border:1px solid var(--line)}
.svc::after{
  content:"→";position:absolute;right:-4px;top:50%;transform:translateY(-50%) translateX(10px);
  opacity:0;transition:all .3s;font-family:var(--serif);font-size:28px;color:var(--purple);
}
.svc:hover{padding-left:18px}
.svc:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}
.svc:hover .name{color:var(--purple)}
@media (max-width:900px){
  .svc{grid-template-columns:60px 1fr;gap:6px}
  .svc .desc, .svc .tools{grid-column:2}
  .svc .tools{justify-self:start;margin-top:10px}
}

/* ---------- Portfolio ---------- */
.portfolio{background:var(--paper)}
.pf-filter{max-width:var(--maxw);margin:0 auto 28px;display:flex;gap:6px;flex-wrap:wrap}
.pf-filter button{
  background:transparent;border:1px solid var(--line);padding:8px 14px;border-radius:100px;cursor:pointer;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
}
.pf-filter button.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pf-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(12, 1fr);gap:20px}
.pf-card{
  position:relative;overflow:hidden;border-radius:20px;background:var(--paper-2);
  min-height:320px;display:flex;flex-direction:column;justify-content:flex-end;padding:22px;
  border:1px solid var(--line);cursor:pointer;transition:transform .4s;
}
.pf-card:hover{transform:translateY(-4px)}
.pf-card .ph{
  position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;
}
.pf-card .ph.placeholder{
  background:
    repeating-linear-gradient(45deg, color-mix(in oklab, var(--purple) 14%, transparent) 0 10px, transparent 10px 20px),
    linear-gradient(135deg, color-mix(in oklab, var(--purple) 22%, var(--paper-2)) 0%, var(--paper-2) 100%);
}
.pf-card .ph.placeholder::after{
  content:attr(data-ph);position:absolute;top:18px;left:18px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--purple);text-transform:uppercase;
}
.pf-card .tag{position:relative;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--paper);text-transform:uppercase;margin-bottom:8px;text-shadow:0 1px 0 rgba(0,0,0,.3)}
.pf-card h4{position:relative;font-family:var(--serif);font-weight:400;font-size:30px;line-height:1;letter-spacing:-.01em;color:#fff;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.25)}
.pf-card .shade{position:absolute;inset:0;background:linear-gradient(180deg, transparent 40%, rgba(37,6,53,.75) 100%)}

.pf-card.a{grid-column:span 7}
.pf-card.b{grid-column:span 5}
.pf-card.c{grid-column:span 4}
.pf-card.d{grid-column:span 4}
.pf-card.e{grid-column:span 4}
.pf-card.f{grid-column:span 5}
.pf-card.g{grid-column:span 7}
@media (max-width:900px){.pf-card{grid-column:span 12 !important;min-height:260px}}

/* ---------- Process ---------- */
.process{background:var(--panel-bg);color:var(--panel-fg)}
.process .eyebrow{color:var(--panel-muted)}
.process .eyebrow::before{background:var(--panel-muted)}
.process .section-head h2{color:var(--panel-fg)}
.process .section-head h2 .it{color:var(--accent)}
.process .section-head p{color:var(--panel-muted)}
.proc-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.proc{
  border:1px solid rgba(243,238,227,.14);border-radius:22px;padding:24px;background:rgba(243,238,227,.03);
  position:relative;overflow:hidden;min-height:260px;display:flex;flex-direction:column;justify-content:space-between;
}
.proc .st{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:#B9A9C9;text-transform:uppercase}
.proc h3{font-family:var(--serif);font-weight:400;font-size:28px;letter-spacing:-.01em;margin:10px 0 8px;line-height:1.05}
.proc p{font-size:14.5px;line-height:1.55;color:#B9A9C9;margin:0}
.proc .big{font-family:var(--serif);font-size:84px;line-height:1;letter-spacing:-.02em;color:color-mix(in oklab, var(--accent) 60%, var(--purple));opacity:.55;margin-top:auto}
@media (max-width:900px){.proc-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.proc-grid{grid-template-columns:1fr}}

/* ---------- Testimonials ---------- */
.testi{background:var(--paper)}
.t-wrap{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.t-quote{font-family:var(--serif);font-size:clamp(28px, 3.6vw, 44px);line-height:1.2;letter-spacing:-.01em;margin:0 0 28px}
.t-quote .q{color:var(--purple);font-style:italic}
.t-person{display:flex;gap:14px;align-items:center}
.t-person .av{
  width:56px;height:56px;border-radius:50%;background:var(--purple);display:grid;place-items:center;color:#fff;
  font-family:var(--serif);font-size:22px;
}
.t-person .n{font-weight:600;font-size:15px}
.t-person .r{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-top:4px}
.t-side{display:grid;gap:12px}
.t-btn{
  display:flex;align-items:center;gap:14px;padding:18px;border:1px solid var(--line);border-radius:16px;
  background:transparent;cursor:pointer;text-align:left;width:100%;transition:all .2s;
}
.t-btn.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.t-btn .av{width:36px;height:36px;border-radius:50%;background:var(--purple);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-size:15px}
.t-btn .nm{font-weight:500;font-size:14px}
.t-btn .rr{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;opacity:.7;text-transform:uppercase;margin-top:3px}
@media (max-width:800px){.t-wrap{grid-template-columns:1fr}}

/* ---------- Contact ---------- */
.contact{background:var(--paper-2)}
.c-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.c-info .addr{display:grid;gap:22px;margin-top:24px}
.c-info .addr li{list-style:none;padding:18px;border:1px solid var(--line);border-radius:16px;background:var(--paper);display:grid;grid-template-columns:40px 1fr;gap:14px;align-items:center}
.c-info .addr .ic{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--mono);font-size:14px}
.c-info .addr .lb{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}
.c-info .addr .vv{font-size:15.5px;margin-top:2px}
.c-form{background:var(--panel-bg);color:var(--panel-fg);padding:32px;border-radius:24px;position:relative;overflow:hidden}
.c-form h3{font-family:var(--serif);font-weight:400;font-size:32px;margin:0 0 6px;letter-spacing:-.01em}
.c-form .sub{color:color-mix(in oklab, var(--panel-fg) 60%, transparent);font-size:14px;margin-bottom:22px}
.c-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.c-form label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:color-mix(in oklab, var(--panel-fg) 60%, transparent);text-transform:uppercase;margin-bottom:6px}
.c-form input, .c-form textarea, .c-form select{
  width:100%;background:rgba(243,238,227,.06);border:1px solid rgba(243,238,227,.14);color:var(--panel-fg);
  padding:12px 14px;border-radius:12px;font:inherit;font-size:14.5px;margin-bottom:14px;
}
.c-form input::placeholder, .c-form textarea::placeholder{color:color-mix(in oklab, var(--panel-fg) 45%, transparent)}
.c-form select option{color:var(--purple-ink);background:var(--panel-fg)}
.c-form input:focus, .c-form textarea:focus, .c-form select:focus{outline:none;border-color:var(--accent)}
.c-form textarea{min-height:96px;resize:vertical}
.c-form .chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.c-form .chip{
  padding:8px 12px;border-radius:100px;border:1px solid rgba(243,238,227,.18);background:transparent;color:var(--panel-fg);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;cursor:pointer;text-transform:uppercase;transition:all .2s;
}
.c-form .chip.on{background:var(--accent);color:var(--purple-ink);border-color:var(--accent)}
.c-form .send{
  width:100%;background:var(--accent);color:var(--purple-ink);border:none;padding:15px;border-radius:14px;
  font-weight:600;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .15s;
}
.c-form .send:hover{transform:translateY(-1px)}
.c-form .send .arr{width:18px;height:18px;flex-shrink:0}
.c-form .sent{display:none;text-align:center;padding:20px 0;color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase}
.c-form.ok .sent{display:block}
.c-form.ok .form-body{display:none}
@media (max-width:860px){.c-grid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
footer{background:var(--panel-bg);color:#E5D7EE;padding:80px var(--pad) 32px}
.foot{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr .8fr .8fr 1.2fr;gap:40px}
.foot h5{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:#B9A9C9;margin:0 0 16px}
.foot ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.foot ul a{font-size:14.5px;color:#E5D7EE;transition:color .2s}
.foot ul a:hover{color:#fff}
.foot .big{
  font-family:var(--serif);font-size:clamp(44px,5vw,72px);line-height:.95;letter-spacing:-.02em;color:#fff;margin:0 0 16px;
}
.foot .big .it{font-style:italic;color:var(--accent)}
.foot .news input{
  background:transparent;border:none;border-bottom:1px solid rgba(229,215,238,.3);padding:10px 0;color:#fff;font:inherit;font-size:14.5px;width:100%;outline:none;
}
.foot .news input:focus{border-color:var(--accent)}
.foot .news button{margin-top:10px;background:transparent;border:1px solid rgba(229,215,238,.3);color:#fff;padding:10px 18px;border-radius:100px;font-size:13px;cursor:pointer}
.foot .news button:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
.foot-bottom{max-width:var(--maxw);margin:60px auto 0;padding-top:24px;border-top:1px solid rgba(229,215,238,.14);display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:#B9A9C9;letter-spacing:.08em;flex-wrap:wrap;gap:12px}
@media (max-width:900px){.foot{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.foot{grid-template-columns:1fr}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Animation layer ---------- */
/* Custom cursor */
.cursor-dot, .cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:difference}
.cursor-dot{width:6px;height:6px;border-radius:50%;background:#fff;transition:transform .15s ease}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(255,255,255,.5);border-radius:50%;transition:transform .25s cubic-bezier(.2,.7,.2,1), width .25s, height .25s, border-color .25s}
.cursor-ring.hover{width:64px;height:64px;border-color:var(--accent);background:color-mix(in oklab, var(--accent) 10%, transparent)}
@media (hover:none), (max-width:860px){.cursor-dot,.cursor-ring{display:none}}

/* Word-split reveal for big headings */
.split .w{display:inline-block;overflow:hidden;vertical-align:bottom}
.split .w > span{display:inline-block;transform:translateY(110%);transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.split.in .w > span{transform:translateY(0)}
.split .w:nth-child(1) > span{transition-delay:.05s}
.split .w:nth-child(2) > span{transition-delay:.15s}
.split .w:nth-child(3) > span{transition-delay:.25s}
.split .w:nth-child(4) > span{transition-delay:.35s}
.split .w:nth-child(5) > span{transition-delay:.45s}
.split .w:nth-child(6) > span{transition-delay:.55s}
.split .w:nth-child(7) > span{transition-delay:.65s}

/* Magnetic buttons (translate applied inline via JS) */
.magnetic{transition:transform .2s cubic-bezier(.2,.7,.2,1)}

/* Tilt cards */
.tilt{transition:transform .25s ease-out;transform-style:preserve-3d;will-change:transform}
.tilt > *{transform:translateZ(0)}

/* Parallax elements */
.parallax{will-change:transform}

/* Aurora blob for process + contact */
.aurora{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(80px);opacity:.4;pointer-events:none;z-index:0;animation:aur 18s ease-in-out infinite alternate}
.aurora.a{background:var(--purple);top:-120px;left:-120px}
.aurora.b{background:var(--accent);bottom:-160px;right:-120px;opacity:.22;animation-delay:-6s}
@keyframes aur{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(60px,40px) scale(1.1)}
  100%{transform:translate(-40px,20px) scale(.95)}
}

/* Hover lift for portfolio cards (image zoom) */
.pf-card .ph{transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.pf-card:hover .ph{transform:scale(1.06)}

/* Gradient text breathe on hero italic */
.hero h1 .it{
  background:linear-gradient(120deg, var(--purple) 0%, var(--purple-soft) 40%, var(--purple) 80%);
  background-size:200% 100%;background-clip:text;-webkit-background-clip:text;color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{to{background-position:200% 0}}

/* Service row slide-in accent bar on hover */
.svc{background:linear-gradient(to right, var(--purple) 0%, var(--purple) 100%) left / 0 100% no-repeat; transition:background-size .5s cubic-bezier(.2,.7,.2,1), padding .3s, color .3s}
.svc:hover{background-size:4px 100%}

/* Marquee enhancement - variable speed on hover */
.hero-runner:hover .track{animation-play-state:paused}

/* Section headline scroll underline */
.section-head h2 .it{position:relative;display:inline-block}
.section-head h2 .it::after{
  content:"";position:absolute;left:0;bottom:.08em;height:.08em;width:0;background:var(--purple);opacity:.35;
  transition:width 1.2s cubic-bezier(.2,.8,.2,1) .3s;
}
.reveal.in .section-head h2 .it::after, .section-head.reveal.in h2 .it::after{width:100%}

/* Stats counter */
.stat .n{display:inline-block}

/* Pulse ring on status dot */
.hero-badge .dot{position:relative}
.hero-badge .dot::before{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid #2ec27e;animation:pulse 2s ease-out infinite}
@keyframes pulse{0%{transform:scale(.8);opacity:1}100%{transform:scale(2.4);opacity:0}}

/* Nav items hover lift */
.nav ul a{position:relative}
.nav ul a::after{content:"";position:absolute;left:14px;right:14px;bottom:6px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.nav ul a:hover::after{transform:scaleX(1)}
.nav ul a.active::after{display:none}

/* CTA shine */
.btn.primary{position:relative;overflow:hidden}
.btn.primary::before{
  content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.25), transparent);
  transition:left .6s ease;
}
.btn.primary:hover::before{left:120%}

/* Process cards hover glow */
.proc{transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .3s, background .3s}
.proc:hover{transform:translateY(-6px);border-color:color-mix(in oklab, var(--accent) 40%, transparent);background:rgba(243,238,227,.06)}
.proc .big{transition:color .3s, transform .4s}
.proc:hover .big{color:var(--accent);transform:translateX(-6px)}

/* About card float */
.about-card{animation:float 8s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-10px)}}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important}
  .cursor-dot,.cursor-ring,.aurora{display:none}
}
