/* ======================================================================
   Harshit.dev v13 — SEO + timeline alignment fix
   ====================================================================== */

:root{
  --bg:#0a0a0a; --ink:#f6f6f6;
  --ink-dim:rgba(246,246,246,.62); --ink-soft:rgba(246,246,246,.82);
  --line:rgba(246,246,246,.12);
  --accent:#ff4042; --accent-2:#ffb84d;
  --serif:'Instrument Serif', serif;
  --sans:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);
  --ease-smooth:cubic-bezier(.22,1,.36,1);
  --container-max:1320px;
}
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:#0a0a0a; overflow-x:hidden; scroll-behavior:smooth; }
body{ color:var(--ink); font-family:var(--sans); -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
a{ color:inherit; text-decoration:none; } img,video{ max-width:100%; display:block; }
b{ font-weight:600; } em,i{ font-family:var(--serif); font-style:italic; font-weight:400; }
p{ line-height:1.6; margin:0 0 16px; color:var(--ink-soft); }

/* ===== VIDEO BACKDROP (fixed) ===== */
.video-backdrop{ position:fixed; inset:0; width:100vw; height:100vh; z-index:0; overflow:hidden; background:#0a0a0a; pointer-events:none; }
.bg-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.video-tint-1{ position:absolute; inset:0; background:linear-gradient(135deg,#1a0707 0%,rgba(10,10,10,.55) 55%,rgba(33,10,10,1) 100%); mix-blend-mode:multiply; opacity:.38; pointer-events:none; }
.video-tint-2{ position:absolute; inset:0; background:radial-gradient(80% 55% at 25% 15%, rgba(255,64,66,.16), transparent 60%),radial-gradient(70% 55% at 85% 85%, rgba(184,33,31,.28), transparent 60%); pointer-events:none; }
.video-vignette{ position:absolute; inset:0; pointer-events:none; background:radial-gradient(80% 60% at 50% 40%, rgba(0,0,0,0), rgba(0,0,0,.25)),linear-gradient(180deg, rgba(10,10,10,.12) 0%, rgba(10,10,10,0) 30%, rgba(10,10,10,.4) 100%); }
.grain{ position:fixed; inset:0; pointer-events:none; opacity:.05; z-index:1; mix-blend-mode:overlay; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>"); }

/* ===== CURSOR GLOW ===== */
.cursor-glow{ position:fixed; top:0; left:0; width:380px; height:380px; background:radial-gradient(circle, rgba(255,64,66,.16) 0%, rgba(255,64,66,0) 70%); pointer-events:none; z-index:3; transform:translate(-50%,-50%); transition:transform .15s linear; mix-blend-mode:screen; }
@media (hover:none){ .cursor-glow{ display:none; } }

.page{ position:relative; z-index:2; }

/* ===== SCROLL PROGRESS BAR ===== */
.scroll-progress{ position:fixed; top:0; left:0; height:2px; width:0; z-index:60; background:linear-gradient(90deg,var(--accent),var(--accent-2)); box-shadow:0 0 12px var(--accent); transition:width .1s linear; }

/* ===== HEADER ===== */
.site-header{ position:fixed; top:20px; left:0; right:0; z-index:50; display:flex; align-items:center; justify-content:space-between; padding:0 32px; max-width:var(--container-max); margin:0 auto; transition:transform .4s var(--ease-smooth); }
.logo{ color:#fff; font-weight:700; font-size:18px; letter-spacing:-.02em; display:flex; align-items:center; gap:10px; }
.logo em{ color:var(--accent); font-weight:400; font-size:20px; margin-left:2px; }
.logo-dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 12px var(--accent); animation:pulse 2s infinite; }
@keyframes pulse{ 0%,100%{opacity:1; transform:scale(1)} 50%{opacity:.6; transform:scale(.85)} }
.nav-pill{ display:flex; gap:4px; background:rgba(10,10,10,.55); backdrop-filter:blur(16px) saturate(160%); -webkit-backdrop-filter:blur(16px) saturate(160%); border:1px solid rgba(255,255,255,.08); border-radius:999px; padding:6px; height:44px; transition:background .3s; }
.nav-pill a{ display:flex; align-items:center; padding:0 16px; color:#fff; font-size:12px; font-weight:500; letter-spacing:.02em; text-transform:uppercase; border-radius:999px; opacity:.7; transition:opacity .25s, background .25s; }
.nav-pill a:hover{ opacity:1; background:rgba(255,255,255,.08); }
.site-header.scrolled .nav-pill{ background:rgba(10,10,10,.78); }
.site-header.scrolled .logo{ opacity:.95; }

/* ===== BUTTONS ===== */
.btn-primary{ background:#fff; color:#0a0a0a; padding:12px 22px; border-radius:999px; font-size:13px; font-weight:500; display:inline-flex; align-items:center; gap:10px; letter-spacing:.01em; transition:background .3s, color .3s, transform .3s var(--ease-bounce); }
.btn-primary:hover{ background:var(--accent); color:#fff; transform:translateY(-2px); }
.btn-primary svg{ transition:transform .3s; }
.btn-primary:hover svg{ transform:translateX(3px); }
.btn-primary-match{ height:44px; padding:0 8px 0 18px; }
.pulse-dot{ width:8px; height:8px; border-radius:50%; background:#1ece6b; box-shadow:0 0 10px #1ece6b; animation:pulse 1.8s infinite; }
.btn-underline{ position:relative; padding:12px 0; font-size:13px; color:#fff; display:inline-block; letter-spacing:.01em; transition:color .3s; }
.btn-underline::after{ content:''; position:absolute; left:0; bottom:6px; width:100%; height:1px; background:rgba(255,255,255,.4); transform-origin:right; transition:transform .5s var(--ease-smooth); }
.btn-underline:hover{ color:var(--accent); }
.btn-underline:hover::after{ transform:scaleX(0); transform-origin:left; }

/* ===== TYPE ===== */
.eyebrow{ font-size:11px; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.55); margin:0 0 28px; display:flex; align-items:center; gap:12px; }
.eyebrow::before{ content:''; width:28px; height:1px; background:var(--accent); }
.section-title{ font-weight:500; letter-spacing:-.04em; line-height:.95; font-size:clamp(40px,6vw,90px); margin:0 0 32px; color:#fff; }
.section-title em{ color:var(--accent); }
.lead{ font-size:clamp(16px,1.25vw,19px); line-height:1.55; max-width:580px; color:var(--ink-soft); margin:0 0 24px; }

/* ===== HERO ===== */
.hero{ position:relative; min-height:100vh; padding:140px 48px 120px; display:flex; flex-direction:column; justify-content:space-between; max-width:var(--container-max); margin:0 auto; overflow:visible; }
.hero-shell{ display:flex; flex-direction:column; gap:60px; flex:1; justify-content:center; position:relative; z-index:5; }
.hero-eye{ font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:rgba(255,255,255,.6); margin:0; }
.hero-eye span{ opacity:.35; margin:0 8px; }
.hero-mega{ font-weight:500; letter-spacing:-.055em; line-height:.88; font-size:clamp(56px,10vw,160px); margin:0; color:#fff; max-width:14ch; }
.mega-row{ display:block; }
.mega-row em{ color:#fff; font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:-.02em; }
.hero-foot{ display:grid; grid-template-columns:1fr auto; gap:60px; align-items:end; max-width:900px; }
.hf-label{ font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:10px; }
.hf-body{ font-size:15px; max-width:420px; line-height:1.5; color:rgba(255,255,255,.85); }
.hero-foot-cta{ display:flex; align-items:center; gap:20px; }
.hero-meta{ display:flex; gap:8px; align-items:center; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:40px; }
.hero-meta .live{ color:var(--accent); }

/* Floating hero cards */
.hero-float{ position:absolute; background:rgba(255,255,255,.06); backdrop-filter:blur(20px) saturate(140%); -webkit-backdrop-filter:blur(20px) saturate(140%); border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:16px 18px; max-width:270px; color:#fff; z-index:6; box-shadow:0 12px 50px rgba(0,0,0,.35); will-change:transform; transition:border-color .4s; }
.hero-float:hover{ border-color:rgba(255,64,66,.5); }
.hero-float p{ margin:0; font-size:13px; line-height:1.5; color:rgba(255,255,255,.85); }
.hero-float p em{ color:var(--accent); }
.hero-float-1{ top:18%; right:4%; }
.hero-float-2{ top:58%; right:8%; max-width:240px; }
.hero-float-3{ bottom:14%; right:14%; max-width:220px; }

.dc-tag{ display:inline-block; font-size:10px; letter-spacing:.18em; font-weight:600; color:#1ece6b; margin-bottom:6px; }
.dc-label{ display:inline-block; font-size:10px; letter-spacing:.2em; font-weight:600; color:var(--accent); margin-bottom:6px; }
.dc-star{ display:block; color:var(--accent-2); font-size:11px; letter-spacing:.2em; margin-bottom:6px; }
.dc-quote{ font-family:var(--serif); font-size:16px !important; line-height:1.3 !important; font-style:italic; }

/* ===== MARQUEE ===== */
.marquee{ position:relative; padding:40px 0; overflow:hidden; border-block:1px solid rgba(255,255,255,.08); background:rgba(0,0,0,.25); backdrop-filter:blur(6px); }
.marquee-track{ display:flex; gap:60px; white-space:nowrap; will-change:transform; animation:marquee 35s linear infinite; font-family:var(--serif); font-style:italic; font-size:clamp(28px,4vw,56px); color:#fff; }
.marquee-track span{ display:inline-block; }
.marquee-track span:nth-child(even){ color:var(--accent); font-family:var(--sans); font-style:normal; font-size:clamp(20px,3vw,36px); }
@keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ===== SECTIONS ===== */
.section{ position:relative; padding:140px 0; scroll-margin-top:90px; }
.hero.section{ padding:140px 48px 120px; }
.container{ max-width:var(--container-max); margin:0 auto; padding:0 48px; position:relative; }
.container.narrow{ max-width:900px; }
.section-label{ position:absolute; top:80px; left:48px; display:flex; flex-direction:column; gap:2px; font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.4); z-index:2; will-change:transform; }
.section-label span:first-child{ color:var(--accent); font-weight:600; }

/* ===== WORK ===== */
.work-section{ padding-top:180px; }
.work-head{ max-width:780px; margin-bottom:80px; }
.work-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:24px; }
.wcard{ grid-column:span 6; background:rgba(255,255,255,.04); backdrop-filter:blur(18px) saturate(140%); -webkit-backdrop-filter:blur(18px) saturate(140%); border:1px solid rgba(255,255,255,.08); border-radius:20px; overflow:hidden; transition:transform .6s var(--ease-smooth), border-color .4s, background .4s; will-change:transform; }
.wcard-lg{ grid-column:span 7; }
.wcard-lg + .wcard{ grid-column:span 5; }
.wcard-lg + .wcard + .wcard{ grid-column:span 5; }
.wcard-lg + .wcard + .wcard + .wcard-lg{ grid-column:span 7; }
.wcard:hover{ border-color:rgba(255,64,66,.4); background:rgba(255,255,255,.06); transform:translateY(-6px); }
.wcard-inner{ position:relative; padding:24px; }
.wcard-num{ position:absolute; top:24px; right:24px; font-family:var(--serif); font-style:italic; font-size:36px; color:rgba(255,255,255,.3); }
.wcard-thumb{ aspect-ratio:16/10; border-radius:14px; margin-bottom:20px; position:relative; overflow:hidden; background:#1a1a1a; border:1px solid rgba(255,255,255,.06); }
.wcard-thumb img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease-smooth), filter .6s; filter:saturate(1.05) contrast(1.02); }
.wcard:hover .wcard-thumb img{ transform:scale(1.06); filter:saturate(1.15) contrast(1.05); }
.wcard-thumb::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(10,10,10,.35) 100%); pointer-events:none; }
.wcard-meta h3{ margin:0 0 6px; font-size:22px; font-weight:500; letter-spacing:-.02em; color:#fff; }
.wcard-meta p{ margin:0 0 10px; font-size:13px; color:rgba(255,255,255,.55); }
.wcard-stat{ display:inline-block; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); font-weight:600; }

/* ===== SERVICES ===== */
.services-section{ padding-top:140px; }
.services-head{ max-width:820px; margin-bottom:72px; }
.services-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.scard{ padding:36px 32px; border-radius:20px; will-change:transform; }
.scard-ico{ display:inline-block; font-size:22px; color:var(--accent); margin-bottom:16px; }
.scard h3{ font-size:24px; font-weight:500; letter-spacing:-.02em; color:#fff; margin:0 0 12px; }
.scard p{ font-size:15px; color:var(--ink-soft); margin:0 0 18px; }
.scard-list{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:8px; }
.scard-list li{ font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.6); border:1px solid var(--line); border-radius:999px; padding:6px 12px; }

/* ===== PROCESS TIMELINE (number beside dot) ===== */
.process-section{ padding-top:140px; }
.process-head{ max-width:820px; margin-bottom:72px; }

.timeline{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  position:relative;
  align-items:start;
}
.timeline::before{
  content:''; position:absolute; top:18px; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--line),var(--line),transparent);
}

.tl-step{
  position:relative;
  padding-top:56px;          /* room for the dot + number row */
  will-change:transform;
}

/* the dot — pinned top-left */
.tl-step::before{
  content:'';
  position:absolute; top:12px; left:0;
  width:12px; height:12px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 14px var(--accent);
}

/* the number — now sits to the RIGHT of the dot, on the left side */
.tl-num{
  position:absolute;
  top:0; left:24px;          /* 24px = just right of the 12px dot */
  right:auto;                /* clears the old right-side rule */
  line-height:1;
  font-family:var(--serif);
  font-style:italic;
  font-size:30px;
  color:rgba(255,255,255,.25);
}

.tl-step h3{ font-size:22px; font-weight:500; letter-spacing:-.02em; color:#fff; margin:0 0 10px; }
.tl-step p{ font-size:14px; color:var(--ink-soft); margin:0; }

/* ===== TECH STACK ===== */
.stack-section{ padding-top:120px; }
.stack-head{ max-width:820px; margin-bottom:56px; }
.stack-grid{ display:flex; flex-wrap:wrap; gap:14px; }
.stack-chip{ font-size:15px; font-weight:500; color:#fff; padding:12px 22px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.04); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); transition:border-color .3s, background .3s, transform .3s var(--ease-bounce); will-change:transform; }
.stack-chip:hover{ border-color:rgba(255,64,66,.5); background:rgba(255,64,66,.08); transform:translateY(-3px); }

/* ===== GLASS ===== */
.glass-trans{ background:rgba(255,255,255,.045); backdrop-filter:blur(22px) saturate(150%); -webkit-backdrop-filter:blur(22px) saturate(150%); border:1px solid rgba(255,255,255,.1); transition:background .4s, border-color .4s, transform .6s var(--ease-smooth); }
.glass-trans:hover{ background:rgba(255,255,255,.07); border-color:rgba(255,64,66,.35); }

/* ===== ABOUT ===== */
.about-section{ padding-top:140px; }
.about-grid{ display:grid; grid-template-columns:5fr 7fr; gap:80px; align-items:start; }
.about-left{ position:sticky; top:120px; will-change:transform; }
.about-right{ will-change:transform; }
.about-card{ padding:48px 44px; border-radius:24px; background:rgba(255,255,255,.045); backdrop-filter:blur(24px) saturate(150%); -webkit-backdrop-filter:blur(24px) saturate(150%); border:1px solid rgba(255,255,255,.1); box-shadow:0 20px 60px rgba(0,0,0,.3); transition:background .4s, border-color .4s; }
.about-card:hover{ background:rgba(255,255,255,.07); border-color:rgba(255,64,66,.3); }
.about-card p{ color:rgba(255,255,255,.85); }
.about-lead{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,2.4vw,34px); line-height:1.25; color:#fff; margin-bottom:24px; }
.about-lead b{ font-family:var(--sans); font-style:normal; color:var(--accent); font-weight:500; }
.about-stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:32px 40px; margin-top:40px; padding-top:32px; border-top:1px solid rgba(255,255,255,.15); }
.as b{ display:block; font-family:var(--serif); font-style:italic; font-size:72px; font-weight:400; line-height:1; color:#fff; letter-spacing:-.04em; }
.as span{ display:block; margin-top:8px; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.5); }

/* ===== TESTIMONIALS ===== */
.quotes-section{ padding-top:140px; }
.quotes-head{ max-width:820px; margin-bottom:72px; }
.quotes-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.qcard{ padding:32px 28px; border-radius:20px; will-change:transform; }
.qcard blockquote{ margin:14px 0 18px; font-family:var(--serif); font-style:italic; font-size:19px; line-height:1.4; color:#fff; }
.qcard figcaption{ font-size:13px; color:rgba(255,255,255,.55); }

/* ===== FAQ ===== */
.faq-section{ padding-top:140px; }
.faq-head{ margin-bottom:48px; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--line); border-radius:16px; padding:4px 24px; background:rgba(255,255,255,.03); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); transition:border-color .3s, background .3s; will-change:transform; }
.faq-item[open]{ border-color:rgba(255,64,66,.35); background:rgba(255,255,255,.05); }
.faq-item summary{ list-style:none; cursor:pointer; padding:18px 0; font-size:17px; font-weight:500; color:#fff; display:flex; justify-content:space-between; align-items:center; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; color:var(--accent); font-size:22px; line-height:1; transition:transform .3s; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ margin:0 0 18px; font-size:15px; color:var(--ink-soft); }

/* ===== SEO COPY ===== */
.seo-copy{ padding-top:120px; }

/* ===== CONTACT ===== */
.contact-section{ padding:180px 0 140px; text-align:center; }
.contact-mega{ position:relative; display:flex; flex-direction:column; align-items:center; gap:8px; font-weight:500; letter-spacing:-.05em; line-height:.92; font-size:clamp(44px,9vw,128px); margin:0 0 40px; color:#fff; }
.contact-mega em{ color:var(--accent); }
.cm-line{ display:block; }
.cm-line-2{ transform:translateX(6%); }
.cm-line-3{ position:relative; background:linear-gradient(180deg,#fff 0%, var(--accent) 90%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:-.02em; padding-bottom:8px; }
.cm-line-3::after{ content:''; position:absolute; left:50%; bottom:-4px; transform:translateX(-50%); width:60%; height:1px; background:linear-gradient(90deg, transparent, var(--accent), transparent); }
.cm-stamp{ display:inline-block; margin-top:22px; font-family:var(--sans); font-size:11px; font-weight:500; letter-spacing:.4em; text-transform:uppercase; color:rgba(255,255,255,.5); }
.email-big{ display:inline-block; margin:40px 0 50px; font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(26px,5vw,64px); color:#fff; letter-spacing:-.02em; border-bottom:1px solid rgba(255,255,255,.3); padding-bottom:10px; transition:border-color .4s, color .4s; max-width:100%; overflow-wrap:anywhere; }
.email-big em{ color:var(--accent); }
.email-big:hover{ border-color:var(--accent); color:var(--accent); }
.contact-ctas{ justify-content:center; display:flex; gap:24px; align-items:center; flex-wrap:wrap; }
.hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }

/* ===== TRUST BAR ===== */
.trust-bar{ position:relative; padding:60px 0; border-bottom:1px solid var(--line); }
.trust-eye{ text-align:center; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:28px; }
.trust-logos{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:clamp(24px,5vw,64px); }
.trust-logo{ font-family:var(--serif); font-style:italic; font-size:clamp(20px,2.4vw,30px); color:rgba(255,255,255,.45); transition:color .3s; }
.trust-logo:hover{ color:var(--accent); }

/* ===== FOOTER ===== */
.site-footer{ padding:60px 0 40px; border-top:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.55); backdrop-filter:blur(14px); }
.footer-inner{ display:grid; grid-template-columns:1fr auto; gap:40px; align-items:start; }
.f-logo{ color:#fff; font-weight:700; font-size:18px; display:flex; align-items:center; gap:10px; margin:0 0 10px; }
.f-logo em{ color:var(--accent); font-weight:400; }
.f-copy{ margin:0; font-size:12px; color:rgba(255,255,255,.5); line-height:1.6; }
.f-right{ text-align:right; display:flex; flex-direction:column; gap:8px; }
.f-label{ font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.4); margin:0 0 8px; }
.f-right a{ font-size:13px; color:#fff; opacity:.75; transition:opacity .25s, color .25s; }
.f-right a:hover{ opacity:1; color:var(--accent); }

.reveal{ opacity:0; transform:translateY(40px); transition:opacity 1s var(--ease-smooth), transform 1.2s var(--ease-smooth); }
.reveal.is-in{ opacity:1; transform:translateY(0); }

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1200px){
  .container{ padding:0 36px; }
  .hero{ padding:130px 36px 100px; }
  .hero-float-1{ top:16%; right:3%; max-width:240px; }
  .hero-float-2{ top:58%; right:5%; max-width:220px; }
  .hero-float-3{ bottom:12%; right:10%; max-width:210px; }
  .about-card{ padding:40px 36px; }
  .contact-mega{ font-size:clamp(40px,8vw,104px); }
}
@media (max-width:980px){
  .hero-mega{ font-size:clamp(52px,11vw,96px); max-width:none; }
  .hero-float{ max-width:220px; padding:14px 16px; }
  .hero-float-1{ top:14%; right:4%; }
  .hero-float-2{ top:auto; bottom:36%; right:4%; max-width:200px; }
  .hero-float-3{ bottom:10%; right:4%; max-width:200px; }
  .work-grid{ grid-template-columns:repeat(2,1fr); gap:18px; }
  .work-grid .wcard,.work-grid .wcard-lg{ grid-column:auto; }
  .about-grid{ grid-template-columns:1fr; gap:40px; }
  .about-left{ position:static; }
  .contact-mega{ font-size:clamp(40px,9vw,80px); }
  .cm-line-2{ transform:translateX(4%); }
  .services-grid{ grid-template-columns:1fr; }
  .timeline{ grid-template-columns:repeat(2,1fr); gap:40px 24px; }
  .timeline::before{ display:none; }
  .quotes-grid{ grid-template-columns:1fr; }
}
@media (max-width:720px){
  .cursor-glow{ display:none; }
  .site-header{ top:12px; padding:0 16px; }
  .logo{ font-size:16px; }
  .logo em{ font-size:17px; }
  .btn-primary-match{ height:40px; padding:0 6px 0 14px; font-size:12px; }
  .nav-pill{ display:none; }
  .hero{ padding:100px 20px 70px; min-height:auto; }
  .hero-shell{ gap:36px; }
  .hero-eye{ font-size:10px; letter-spacing:.22em; }
  .hero-mega{ font-size:clamp(40px,11vw,60px); line-height:.92; max-width:none; }
  .hero-foot{ grid-template-columns:1fr; gap:24px; }
  .hero-foot-cta{ flex-direction:column; align-items:stretch; gap:14px; }
  .hero-foot-cta .btn-primary{ width:100%; justify-content:center; }
  .hero-meta{ font-size:9px; margin-top:24px; flex-wrap:wrap; }
  .hero-float{ display:none; }
  .marquee{ padding:22px 0; }
  .marquee-track{ gap:36px; font-size:clamp(22px,6vw,32px); }
  .section{ padding:80px 0; }
  .section-label{ top:28px; left:20px; font-size:9px; }
  .section-label span:first-child{ font-size:10px; }
  .container{ padding:0 20px; }
  .work-section,.approach-section,.about-section,
  .services-section,.process-section,.stack-section,
  .quotes-section,.faq-section,.seo-copy{ padding-top:110px; }
  .section-title{ font-size:clamp(34px,9vw,52px); margin-bottom:22px; }
  .lead{ font-size:15px; }
  .work-head,.services-head,.process-head,.stack-head,.quotes-head{ margin-bottom:48px; }
  .work-grid{ grid-template-columns:1fr; gap:14px; }
  .wcard-inner{ padding:18px; }
  .wcard-num{ font-size:28px; top:18px; right:18px; }
  .wcard-thumb{ aspect-ratio:16/11; border-radius:12px; margin-bottom:16px; }
  .wcard-meta h3{ font-size:19px; }
  .services-grid{ grid-template-columns:1fr; }
  .scard{ padding:26px 22px; }
  .timeline{ grid-template-columns:1fr; }
  .stack-chip{ font-size:13px; padding:10px 16px; }
  .quotes-grid{ grid-template-columns:1fr; }
  .faq-item summary{ font-size:15px; }
  .trust-bar{ padding:40px 0; }
  .about-card{ padding:28px 22px; border-radius:18px; }
  .about-lead{ font-size:20px; line-height:1.3; }
  .about-card p{ font-size:14px; }
  .about-stats{ grid-template-columns:1fr 1fr; gap:20px; margin-top:28px; padding-top:22px; }
  .as b{ font-size:44px; }
  .as span{ font-size:10px; letter-spacing:.14em; }
  .contact-section{ padding:110px 0 80px; }
  .contact-mega{ font-size:clamp(36px,11vw,60px); gap:4px; margin-bottom:28px; }
  .cm-line-2{ transform:none; }
  .cm-stamp{ font-size:10px; letter-spacing:.32em; margin-top:14px; }
  .email-big{ font-size:clamp(22px,6vw,36px); margin:24px 0 32px; }
  .contact-ctas{ flex-direction:column; width:100%; gap:14px; }
  .contact-ctas .btn-primary{ width:100%; justify-content:center; }
  .site-footer{ padding:40px 0 28px; }
  .footer-inner{ grid-template-columns:1fr; gap:24px; text-align:center; }
  .f-logo{ justify-content:center; font-size:16px; }
  .f-right{ text-align:center; align-items:center; }
  .f-copy{ font-size:11px; }
}
@media (max-width:460px){
  .hero{ padding:90px 16px 60px; }
  .hero-mega{ font-size:36px; }
  .hero-eye{ font-size:9px; }
  .section-title{ font-size:30px; }
  .container{ padding:0 16px; }
  .about-card{ padding:22px 18px; }
  .about-lead{ font-size:18px; }
  .about-stats{ grid-template-columns:1fr; gap:16px; }
  .contact-mega{ font-size:34px; }
  .wcard-meta h3{ font-size:17px; }
  .email-big{ font-size:22px; }
  .site-header{ padding:0 12px; }
  .btn-primary-match{ font-size:11px; padding:0 4px 0 12px; }
  .btn-primary-match .pulse-dot{ width:6px; height:6px; }
}
@media (max-width:360px){
  .hero-mega{ font-size:32px; }
  .section-title{ font-size:26px; }
  .contact-mega{ font-size:30px; }
  .as b{ font-size:36px; }
}
@media (max-height:520px) and (orientation:landscape){
  .hero{ padding:90px 32px 60px; min-height:100vh; }
  .hero-mega{ font-size:44px; }
  .hero-shell{ gap:20px; }
  .hero-float{ display:none; }
}
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:.001s !important; transition-duration:.001s !important; }
  .marquee-track{ animation:none; }
}

/* ===== ANTI-COPY / SELECTION ===== */
html, body{ -webkit-user-select:none; -moz-user-select:none; -ms-user-select:none; user-select:none; -webkit-touch-callout:none; }
img, video{ -webkit-user-drag:none; user-drag:none; pointer-events:none; }
a, button, .clickable{ pointer-events:auto; }