*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#f4f0e8;--cream2:#ece8df;--cream3:#e0dbd0;
  --ink:#1c1917;--ink2:#44403c;--muted:#78716c;--muted2:#a8a29e;
  --white:#fdfcfa;
  --red:#e8391a;--red2:#ff5533;--red-g:rgba(232,57,26,.15);
  --blue:#1d4fd8;--green:#059669;--amber:#d97706;--purple:#7c3aed;
  --border:rgba(28,25,23,.09);--border2:rgba(28,25,23,.15);
  --F:'Syne',sans-serif;--B:'DM Sans',sans-serif;--M:'JetBrains Mono',monospace;
  --r:16px;--r2:24px;
}
html{scroll-behavior:smooth}
body{font-family:var(--B);background:var(--cream);color:var(--ink);overflow-x:hidden}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:var(--red);border-radius:4px}

/* ── PAGE TRANSITION OVERLAY ── */
#page-curtain{
  position:fixed;inset:0;z-index:9999;pointer-events:none;
  display:grid;grid-template-columns:repeat(5,1fr);
}
.curtain-col{
  background:var(--ink);height:100vh;
  transform:translateY(-101%);
  transition:transform .7s cubic-bezier(.77,0,.175,1);
}
.curtain-col:nth-child(1){transition-delay:.00s}
.curtain-col:nth-child(2){transition-delay:.06s}
.curtain-col:nth-child(3){transition-delay:.12s}
.curtain-col:nth-child(4){transition-delay:.06s}
.curtain-col:nth-child(5){transition-delay:.00s}
body.is-loading .curtain-col{transform:translateY(0)}
body.is-leaving .curtain-col{transform:translateY(0);transition-delay:0s!important;transition:transform .5s cubic-bezier(.77,0,.175,1)!important}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:600;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 3rem;transition:all .35s}
nav.stuck{background:rgba(244,240,232,.94);backdrop-filter:blur(20px);border-bottom:1px solid var(--border2);padding:.8rem 3rem}
.logo{font-family:var(--F);font-weight:800;font-size:1.2rem;letter-spacing:-.04em;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:.55rem}
.logo-sq{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:transparent;}
.nav-pills{display:flex;list-style:none;gap:.12rem;background:rgba(255,255,255,.65);border:1px solid var(--border2);border-radius:100px;padding:.28rem}
.nav-pills a{font-size:.78rem;font-weight:500;color:var(--muted);text-decoration:none;padding:.38rem 1rem;border-radius:100px;transition:all .2s}
.nav-pills a:hover{color:var(--ink);background:rgba(28,25,23,.06)}
.nav-cta{background:var(--ink);color:#fff;font-size:.78rem;font-weight:600;text-decoration:none;padding:.55rem 1.3rem;border-radius:100px;transition:all .25s}
.nav-cta:hover{background:var(--red);transform:translateY(-1px)}

.logo-box {
  height: 120px;        /* Navbar logo height */
  width: auto;
  display: flex;
  align-items: center;
}

.logo-box img {
  height: 100%;
  width: auto;
  object-fit: contain;
}
/* ── HERO ── */
.hero{
  min-height:100vh;display:grid;grid-template-columns:1fr 1fr;
  position:relative;overflow:hidden;align-items:center;
}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 25% 50%,black 20%,transparent 100%);
}
.hero-blob{
  position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:blobFloat 8s ease-in-out infinite;
}
.hero-blob1{width:420px;height:420px;background:radial-gradient(circle,rgba(232,57,26,.18),transparent 70%);top:-80px;right:30%;animation-delay:0s}
.hero-blob2{width:300px;height:300px;background:radial-gradient(circle,rgba(124,58,237,.12),transparent 70%);bottom:10%;right:15%;animation-delay:3s}
.hero-blob3{width:200px;height:200px;background:radial-gradient(circle,rgba(29,79,216,.1),transparent 70%);top:50%;left:40%;animation-delay:5s}
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-30px) scale(1.08)}}

.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(28,25,23,.012) 2px,rgba(28,25,23,.012) 4px);
}

.hero-left{padding:7rem 2.5rem 4rem 3rem;position:relative;z-index:2}
.pill-tag{display:inline-flex;align-items:center;gap:.5rem;background:var(--white);border:1px solid var(--border2);border-radius:100px;padding:.35rem .88rem .35rem .6rem;font-size:.68rem;font-weight:600;color:var(--ink2);font-family:var(--M);letter-spacing:.04em;text-transform:uppercase;margin-bottom:1.8rem;animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.3s}
.pill-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:blink 1.4s ease infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero h1{font-family:var(--F);font-size:clamp(3rem,5.2vw,5.4rem);font-weight:800;line-height:.9;letter-spacing:-.06em;margin-bottom:1.5rem}
.h1-a{display:block;color:var(--ink);animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.45s}
.h1-b{display:block;-webkit-text-stroke:2.5px var(--ink);color:transparent;animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.55s}
.h1-c{display:block;color:var(--red);animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.65s;position:relative}
.h1-c::after{
  content:'Go Digital.';position:absolute;left:0;top:0;
  background:linear-gradient(90deg,var(--red),#ff7849);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  animation:textGlitch 6s ease infinite;animation-delay:2s;
}
@keyframes textGlitch{
  0%,94%,100%{clip-path:inset(0 0 100% 0);opacity:0}
  95%{clip-path:inset(30% 0 40% 0);opacity:1;transform:translateX(-3px)}
  96%{clip-path:inset(60% 0 10% 0);opacity:1;transform:translateX(3px)}
  97%{clip-path:inset(0 0 100% 0);opacity:0}
}

@keyframes fadeSlideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

.hero-desc{font-size:.95rem;line-height:1.88;color:var(--muted);max-width:430px;margin-bottom:2.2rem;font-weight:300;animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.75s}
.hero-btns{display:flex;gap:.8rem;flex-wrap:wrap;animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.85s}
.btn-fill{display:inline-flex;align-items:center;gap:.45rem;background:var(--ink);color:#fff;font-size:.88rem;font-weight:600;text-decoration:none;padding:.85rem 1.9rem;border-radius:100px;transition:all .25s;font-family:var(--B);border:none;cursor:pointer;position:relative;overflow:hidden}
.btn-fill::before{content:'';position:absolute;inset:0;background:var(--red);transform:translateX(-101%);transition:transform .35s cubic-bezier(.23,1,.32,1)}
.btn-fill:hover::before{transform:translateX(0)}
.btn-fill span{position:relative;z-index:1}
.btn-fill:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--red-g)}
.btn-ghost{display:inline-flex;align-items:center;gap:.45rem;background:transparent;color:var(--ink);font-size:.88rem;font-weight:500;text-decoration:none;padding:.85rem 1.9rem;border-radius:100px;border:1.5px solid var(--border2);transition:all .25s;font-family:var(--B);cursor:pointer}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.hero-metrics{display:flex;gap:2.2rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border2);animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.95s}
.metric .num{font-family:var(--F);font-size:1.8rem;font-weight:800;letter-spacing:-.04em;color:var(--ink);line-height:1}
.metric .lbl{font-size:.67rem;color:var(--muted);margin-top:.2rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}

.hero-right{
  position:relative;height:100vh;display:flex;align-items:center;justify-content:center;
  padding:5.5rem 2rem 2rem;
}
.canvas-wrap{
  width:100%;height:100%;position:relative;border-radius:var(--r2);overflow:hidden;
  animation:fadeSlideUp .8s cubic-bezier(.23,1,.32,1) both;animation-delay:.5s;
}
#hero3d{width:100%;height:100%;display:block}

.hero-stat-card{
  position:absolute;background:rgba(253,252,250,.92);backdrop-filter:blur(16px);
  border:1px solid var(--border2);border-radius:14px;padding:.75rem 1rem;
  box-shadow:0 8px 32px rgba(28,25,23,.12);
  animation:floatCard 4s ease-in-out infinite;
  font-family:var(--F);
}
.hero-stat-card:nth-child(2){top:16%;right:8%;animation-delay:0s}
.hero-stat-card:nth-child(3){bottom:22%;right:12%;animation-delay:1.5s}
.hero-stat-card:nth-child(4){top:38%;left:6%;animation-delay:2.5s}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hsc-label{font-size:.58rem;color:var(--muted2);text-transform:uppercase;letter-spacing:.08em;font-family:var(--M);margin-bottom:.2rem}
.hsc-val{font-size:1.1rem;font-weight:800;color:var(--ink);letter-spacing:-.03em;line-height:1}
.hsc-sub{font-size:.62rem;color:var(--green);font-weight:600;margin-top:.15rem;display:flex;align-items:center;gap:.25rem}
.hsc-sub::before{content:'↑'}

/* ── FLOATING AI CHAT BUTTON + PANEL ── */
#ai-fab{
  position:fixed;bottom:2rem;right:2rem;z-index:500;
  width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--red),#c42200);
  box-shadow:0 8px 32px rgba(232,57,26,.45);
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s;
  animation:fabPop .6s cubic-bezier(.23,1,.32,1) both;animation-delay:1.2s;
}
@keyframes fabPop{from{transform:scale(0) rotate(45deg);opacity:0}to{transform:scale(1) rotate(0deg);opacity:1}}
#ai-fab:hover{transform:scale(1.1);box-shadow:0 12px 40px rgba(232,57,26,.55)}
#ai-fab .fab-icon-open{transition:all .3s}
#ai-fab .fab-icon-close{position:absolute;opacity:0;transform:rotate(-45deg);transition:all .3s}
#ai-fab.active .fab-icon-open{opacity:0;transform:rotate(45deg)}
#ai-fab.active .fab-icon-close{opacity:1;transform:rotate(0deg)}
.fab-pulse{
  position:absolute;width:100%;height:100%;border-radius:50%;
  border:2px solid rgba(232,57,26,.4);animation:fabRing 2s ease-out infinite;
}
@keyframes fabRing{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.9);opacity:0}}
#fab-notif{
  position:absolute;top:-2px;right:-2px;width:18px;height:18px;border-radius:50%;
  background:var(--green);border:2px solid var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:.5rem;font-weight:700;color:#fff;font-family:var(--M);
  animation:blink 2s ease infinite;
}

/* ── CHAT PANEL ── */
#ai-panel{
  position:fixed;bottom:5.5rem;right:2rem;z-index:499;width:380px;
  background:var(--white);border:1.5px solid var(--border2);border-radius:24px;
  box-shadow:0 24px 80px rgba(28,25,23,.18),0 4px 20px rgba(28,25,23,.08);
  overflow:hidden;
  transform:translateY(20px) scale(.95);opacity:0;pointer-events:none;
  transition:transform .4s cubic-bezier(.23,1,.32,1),opacity .4s cubic-bezier(.23,1,.32,1);
  transform-origin:bottom right;
}
#ai-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}

.aip-header{
  display:flex;align-items:center;gap:.75rem;padding:.9rem 1.1rem;
  background:var(--ink);
}
.aip-avatar{
  width:38px;height:38px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--red),var(--purple));
  display:flex;align-items:center;justify-content:center;position:relative;
}
.aip-avatar::after{content:'';position:absolute;bottom:-2px;right:-2px;width:9px;height:9px;border-radius:50%;background:var(--green);border:2px solid var(--ink)}
.aip-info{flex:1;min-width:0}
.aip-name{font-family:var(--F);font-size:.9rem;font-weight:700;color:#fff;letter-spacing:-.02em}
.aip-sub{font-size:.62rem;color:rgba(255,255,255,.4);margin-top:.04rem;font-family:var(--M)}
.aip-status{display:flex;align-items:center;gap:.35rem;font-size:.6rem;color:var(--green);font-family:var(--M)}
.aip-status-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:blink 1.4s ease infinite}
.aip-close{background:rgba(255,255,255,.08);border:none;color:rgba(255,255,255,.5);cursor:pointer;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.aip-close:hover{background:rgba(255,255,255,.18);color:#fff}

.aip-suggestions{
  display:flex;gap:.4rem;padding:.65rem .85rem;overflow-x:auto;background:var(--cream2);
  border-bottom:1px solid var(--border);scrollbar-width:none;
}
.aip-suggestions::-webkit-scrollbar{display:none}
.sug-chip{
  flex-shrink:0;font-size:.65rem;padding:.3rem .75rem;border-radius:100px;
  background:var(--white);border:1px solid var(--border2);color:var(--ink2);
  cursor:pointer;transition:all .2s;font-family:var(--B);font-weight:500;white-space:nowrap;
}
.sug-chip:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-1px)}

.aip-msgs{
  height:280px;overflow-y:auto;padding:.85rem .9rem;
  display:flex;flex-direction:column;gap:.6rem;scroll-behavior:smooth;
}
.aip-msgs::-webkit-scrollbar{width:2px}
.aip-msgs::-webkit-scrollbar-thumb{background:var(--cream3)}

.msg{display:flex;gap:.45rem;align-items:flex-end;animation:msgPop .35s cubic-bezier(.23,1,.32,1) both}
@keyframes msgPop{from{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none;scale:1}}
.msg-bot .bubble{
  background:var(--cream2);border:1px solid var(--border);
  border-radius:16px 16px 16px 4px;padding:.65rem .9rem;
  font-size:.79rem;line-height:1.72;color:var(--ink2);max-width:88%;
  position:relative;
}
.msg-user{flex-direction:row-reverse}
.msg-user .bubble{
  background:var(--ink);color:#fff;
  border-radius:16px 16px 4px 16px;padding:.65rem .9rem;
  font-size:.79rem;line-height:1.72;max-width:88%;
}
.msg-av{
  width:26px;height:26px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--red),var(--purple));
  display:flex;align-items:center;justify-content:center;
}
.msg-time{font-size:.55rem;color:var(--muted2);margin-top:.25rem;font-family:var(--M);display:block;padding:0 .3rem}
.msg-bot .msg-time{text-align:left}
.msg-user .msg-time{text-align:right}

.typing-ind{display:flex;gap:3px;padding:.3rem 0;align-items:center}
.typing-ind span{width:5px;height:5px;border-radius:50%;background:var(--muted2);animation:td 1.1s ease infinite}
.typing-ind span:nth-child(2){animation-delay:.18s}
.typing-ind span:nth-child(3){animation-delay:.36s}
@keyframes td{0%,100%{transform:scale(1);opacity:.35}50%{transform:scale(1.5);opacity:1}}

.aip-input{
  display:flex;gap:.5rem;padding:.65rem .75rem;
  border-top:1px solid var(--border);background:var(--white);align-items:center;
}
.aip-inp{
  flex:1;font-family:var(--B);font-size:.8rem;color:var(--ink);
  background:var(--cream2);border:1.5px solid var(--border2);border-radius:12px;
  padding:.52rem .8rem;outline:none;transition:all .2s;resize:none;
  line-height:1.4;max-height:80px;overflow-y:auto;
}
.aip-inp:focus{border-color:var(--red);background:var(--white);box-shadow:0 0 0 3px var(--red-g)}
.aip-inp::placeholder{color:var(--muted2)}
.aip-send{
  width:36px;height:36px;border-radius:11px;border:none;
  background:var(--red);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;flex-shrink:0;
}
.aip-send:hover{background:var(--ink);transform:scale(1.08)}
.aip-send:disabled{opacity:.4;cursor:default;transform:none}
.aip-footer{text-align:center;font-size:.58rem;color:var(--muted2);padding:.4rem;font-family:var(--M)}

/* ── TICKER ── */
.ticker{background:var(--ink);padding:.8rem 0;overflow:hidden;border-top:3px solid var(--red)}
.ticker-wrap{display:flex;width:max-content;animation:tick 30s linear infinite}
.t-item{display:flex;align-items:center;gap:1.4rem;padding:0 2.5rem;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,240,232,.4);font-weight:600;white-space:nowrap;font-family:var(--M)}
.t-hi{color:var(--cream)}
.t-dot{width:4px;height:4px;border-radius:50%;background:var(--red);flex-shrink:0}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SECTIONS ── */
section{padding:6rem 3rem}
.eye{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--M);font-size:.62rem;color:var(--red);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.9rem}
.eye::before{content:'';width:16px;height:2px;background:var(--red);border-radius:2px}
.sec-title{font-family:var(--F);font-size:clamp(2.2rem,3.8vw,3.5rem);font-weight:800;letter-spacing:-.055em;line-height:.92;margin-bottom:.9rem}
.sec-sub{font-size:.93rem;color:var(--muted);line-height:1.88;max-width:480px;font-weight:300}

/* ── SERVICES ── */
#services{background:var(--white)}
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;gap:2rem;flex-wrap:wrap}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border2);border:1px solid var(--border2);border-radius:20px;overflow:hidden}
.scard{background:var(--white);padding:2.2rem 2rem;transition:all .3s;position:relative;overflow:hidden}
.scard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.23,1,.32,1)}
.scard:hover::before{transform:scaleX(1)}
.scard:hover{background:var(--cream2)}
.snum{font-family:var(--M);font-size:.58rem;color:var(--muted2);letter-spacing:.08em;margin-bottom:1.5rem}
.sico{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;border:1px solid var(--border2);transition:all .3s}
.scard:hover .sico{border-color:var(--red);background:var(--red-g)}
.stitle{font-family:var(--F);font-size:1.05rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.5rem}
.sdesc{font-size:.82rem;line-height:1.82;color:var(--muted);margin-bottom:1.2rem;font-weight:300}
.chips{display:flex;flex-wrap:wrap;gap:.3rem}
.chip{font-size:.63rem;padding:.23rem .62rem;border-radius:100px;border:1px solid var(--border2);color:var(--muted);font-weight:500;background:var(--cream2)}
.scard-dark{background:var(--ink)!important;color:var(--cream)}
.scard-dark .snum{color:rgba(244,240,232,.25)}
.scard-dark .stitle{color:var(--cream)}
.scard-dark .sdesc{color:rgba(244,240,232,.45)}
.scard-dark .sico{background:rgba(232,57,26,.15);border-color:rgba(232,57,26,.3)}
.scard-dark .chip{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1);color:rgba(244,240,232,.5)}
.scard-dark::before{background:var(--red2)}
.scard-span{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border2)}
.skill-stack{display:flex;flex-direction:column;gap:.8rem;padding-top:.4rem}
.sk-row{display:flex;flex-direction:column;gap:.3rem}
.sk-meta{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted)}
.sk-pct{color:var(--ink);font-family:var(--M);font-size:.65rem;font-weight:500}
.sk-track{height:3px;background:var(--cream3);border-radius:4px;overflow:hidden}
.sk-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--red),#ff7849);transform:scaleX(0);transform-origin:left;transition:transform 1.1s cubic-bezier(.23,1,.32,1) .3s}
.sk-fill.go{transform:scaleX(1)}

/* ── PROCESS ── */
#process{background:var(--cream2)}
.proc-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.8rem;margin-top:4rem;position:relative}
.proc-row::before{content:'';position:absolute;left:28px;right:28px;top:27px;height:1px;background:repeating-linear-gradient(to right,var(--border2) 0,var(--border2) 6px,transparent 6px,transparent 14px)}
.pstep{position:relative}
.pstep-num{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--M);font-size:.76rem;font-weight:500;border:1.5px solid var(--border2);background:var(--white);color:var(--muted);position:relative;z-index:1;margin-bottom:1.3rem;transition:all .3s}
.pstep:hover .pstep-num{border-color:var(--red);background:var(--red);color:#fff;box-shadow:0 4px 18px var(--red-g)}
.ptag{font-family:var(--M);font-size:.57rem;color:var(--red);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.ptitle{font-family:var(--F);font-size:1rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.4rem}
.pdesc{font-size:.8rem;color:var(--muted);line-height:1.78;font-weight:300}

/* ── WHY ── */
#why{background:var(--white)}
.why-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;margin-top:3.5rem;align-items:start}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.feat{border:1.5px solid var(--border2);border-radius:var(--r);padding:1.5rem;background:var(--cream2);transition:all .3s;position:relative;overflow:hidden}
.feat::after{content:'';position:absolute;top:0;left:0;width:2px;bottom:0;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .3s cubic-bezier(.23,1,.32,1)}
.feat:hover{border-color:rgba(232,57,26,.3);background:var(--white)}
.feat:hover::after{transform:scaleY(1)}
.feat-ico{width:38px;height:38px;margin-bottom:.85rem;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--white);border:1px solid var(--border2)}
.feat-title{font-family:var(--F);font-size:.9rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.3rem}
.feat-desc{font-size:.76rem;color:var(--muted);line-height:1.68;font-weight:300}
.why-right{background:var(--ink);border-radius:var(--r2);overflow:hidden;height:480px;position:relative}
#why3d{width:100%;height:100%;display:block}
.why-label{position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);background:rgba(244,240,232,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:.36rem 1rem;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(244,240,232,.5);white-space:nowrap;font-family:var(--M)}

/* ── CONTACT ── */
#contact{background:var(--cream2)}
.contact-layout{display:grid;grid-template-columns:1fr 1.55fr;gap:5rem;margin-top:3.5rem;align-items:start}
.contact-left h3{font-family:var(--F);font-size:1.75rem;font-weight:800;letter-spacing:-.04em;line-height:1.12;margin-bottom:.85rem}
.contact-left p{font-size:.88rem;color:var(--muted);line-height:1.88;margin-bottom:2.2rem;font-weight:300}
.cinfo{display:flex;flex-direction:column}
.ci{display:flex;align-items:center;gap:.9rem;padding:.9rem 0;border-bottom:1px solid var(--border)}
.ci:first-child{border-top:1px solid var(--border)}
.ci-ico{width:40px;height:40px;border-radius:12px;background:var(--white);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci strong{display:block;font-size:.62rem;color:var(--muted2);margin-bottom:.1rem;letter-spacing:.05em;text-transform:uppercase;font-weight:600}
.ci span{font-size:.84rem;color:var(--ink);font-weight:500}
.form-box{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r2);padding:2.6rem;box-shadow:0 4px 28px rgba(28,25,23,.06)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.38rem;margin-bottom:.9rem}
label{font-size:.66rem;font-weight:700;color:var(--muted);letter-spacing:.07em;text-transform:uppercase}
input,select,textarea{font-family:var(--B);font-size:.86rem;color:var(--ink);background:var(--cream2);border:1.5px solid var(--border2);border-radius:12px;padding:.78rem .95rem;outline:none;width:100%;transition:all .2s}
input:focus,select:focus,textarea:focus{border-color:var(--red);background:var(--white);box-shadow:0 0 0 3px var(--red-g)}
input::placeholder,textarea::placeholder{color:var(--muted2)}
select{cursor:pointer}
textarea{resize:vertical;min-height:108px}
.sub-btn{background:var(--ink);color:#fff;border:none;padding:.95rem 2rem;border-radius:100px;font-family:var(--B);font-size:.9rem;font-weight:600;cursor:pointer;width:100%;margin-top:.3rem;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .25s}
.sub-btn:hover{background:var(--red);transform:translateY(-2px);box-shadow:0 8px 28px var(--red-g)}
.form-note{text-align:center;font-size:.66rem;color:var(--muted2);margin-top:.65rem}
#smsg{display:none;background:rgba(5,150,105,.08);border:1px solid rgba(5,150,105,.25);border-radius:12px;padding:.85rem;margin-bottom:1rem;font-size:.82rem;color:#059669;font-weight:500}
#emsg{display:none;background:rgba(232,57,26,.07);border:1px solid rgba(232,57,26,.2);border-radius:12px;padding:.85rem;margin-bottom:1rem;font-size:.82rem;color:var(--red);font-weight:500}

/* ── FOOTER ── */
footer{background:var(--ink);color:rgba(244,240,232,.4);padding:2rem 3rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-logo{font-family:var(--F);font-weight:800;font-size:1.1rem;color:var(--cream);text-decoration:none;display:flex;align-items:center;gap:.5rem;letter-spacing:-.03em}
.foot-links{display:flex;gap:1.8rem}
.foot-links a{color:rgba(244,240,232,.38);font-size:.78rem;text-decoration:none;transition:color .2s}
.foot-links a:hover{color:var(--cream)}
.foot-copy{font-size:.7rem}

/* ── REVEAL ── */
.anim{opacity:0;transform:translateY(24px);transition:opacity .65s cubic-bezier(.23,1,.32,1),transform .65s cubic-bezier(.23,1,.32,1)}
.anim.show{opacity:1!important;transform:none!important}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  nav{padding:1rem 1.5rem}nav.stuck{padding:.75rem 1.5rem}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:6rem 1.5rem 2rem}
  .hero-right{height:55vw;min-height:300px;padding:1.5rem}
  .hero-stat-card{display:none}
  #ai-panel{width:calc(100vw - 2rem);right:1rem;bottom:5rem}
  #ai-fab{bottom:1.5rem;right:1rem}
  .svc-grid,.scard-span{grid-template-columns:1fr}
  .scard-span{grid-column:unset}
  .proc-row{grid-template-columns:1fr 1fr}
  .proc-row::before{display:none}
  .why-layout{grid-template-columns:1fr}
  .why-right{height:300px}
  .contact-layout{grid-template-columns:1fr;gap:2.5rem}
  .frow{grid-template-columns:1fr}
  section{padding:4.5rem 1.5rem}
  footer{flex-direction:column;text-align:center;padding:1.8rem 1.5rem}
  .foot-links{flex-wrap:wrap;justify-content:center}
}
@media(max-width:640px){
  .nav-pills{display:none}
  .hero h1{font-size:2.8rem}
  .feat-grid{grid-template-columns:1fr}
  .proc-row{grid-template-columns:1fr}
}

/* ── CURSOR GLOW ── */
#cursor-glow{
    position:fixed;width:300px;height:300px;border-radius:50%;pointer-events:none;z-index:0;
    background:radial-gradient(circle,rgba(232,57,26,.06),transparent 70%);
    transform:translate(-50%,-50%);transition:transform .05s;
  }