:root{
  color-scheme: dark;
  --bg:#06101f;
  --bg-2:#050b18;
  --panel:#071123;
  --panel-2:#0b1730;
  --surface:#050b18;
  --line:#182a4a;
  --line-strong:#315b76;
  --text:#f4f7fb;
  --muted:#a8b3c2;
  --muted-2:#7c8999;
  --gold:#6ec8bb;
  --gold-2:#4fb4a8;
  --cyan:#4f80ff;
  --teal:#6ec8bb;
  --green:#4ade80;
  --shadow:0 24px 70px rgba(0,0,0,.32);
  --soft-shadow:0 18px 55px rgba(4,14,30,.28);
  --radius:12px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-width:320px;
  background:#06101f;
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height:1.58;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
::selection{background:rgba(110,200,187,.34)}
.site-backdrop{position:fixed;inset:0;z-index:-10;overflow:hidden;background:linear-gradient(180deg,#0a1526 0%,#070f1e 50%,#03070f 100%);pointer-events:none}
.backdrop-aurora{position:absolute;inset:0;background:
  radial-gradient(60% 50% at 18% 12%,rgba(28,72,128,.45),transparent 70%),
  radial-gradient(55% 45% at 88% 30%,rgba(15,86,104,.34),transparent 72%),
  radial-gradient(70% 60% at 50% 108%,rgba(10,28,58,.55),transparent 70%);
  filter:blur(6px);opacity:.9}
.backdrop-grid{position:absolute;inset:0;background:
  linear-gradient(rgba(110,200,187,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(110,200,187,.022) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(120% 100% at 50% 0%,rgba(0,0,0,.55),transparent 75%)}
.backdrop-scan{display:none}
.skip-link{position:absolute;left:1rem;top:-8rem;background:var(--teal);color:#030807;padding:.65rem .9rem;border-radius:var(--radius);z-index:1000;font-weight:800}
.skip-link:focus{top:1rem}
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.25rem;
  padding:.62rem clamp(1rem,4vw,2.2rem);
  background:rgba(4,10,20,.9);
  border-bottom:1px solid rgba(110,200,187,.16);
  backdrop-filter:blur(16px);
}
.brand{display:flex;align-items:center;gap:.75rem;min-width:max-content}
.brand-mark{width:38px;height:38px;border-radius:6px;mix-blend-mode:screen}
.brand strong{display:block;font-size:1rem;line-height:1.15}
.brand small{display:block;color:var(--muted);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.site-nav{display:flex;align-items:center;gap:.15rem}
.site-nav a{padding:.5rem .72rem;color:var(--muted);font-weight:700;font-size:.9rem;border-radius:999px;transition:.18s ease}
.site-nav a:hover,.site-nav a:focus-visible{color:var(--text);background:rgba(255,255,255,.055)}
.site-nav .nav-cta{color:#03100e;background:var(--teal);border:1px solid rgba(110,200,187,.7);padding:.6rem 1rem}
.site-nav .nav-cta:hover{background:#8bded4;color:#03100e}
.nav-toggle{display:none;border:1px solid var(--line);background:var(--surface);width:42px;height:42px;border-radius:var(--radius);padding:9px;cursor:pointer}
.nav-toggle span{display:block;height:2px;background:var(--text);margin:6px 0;border-radius:999px}
.section-shell{width:min(var(--max),calc(100% - clamp(2rem,5vw,4rem)));max-width:none;margin:0 auto;padding:clamp(4.25rem,6vw,6.25rem) 0;scroll-margin-top:92px}
.section-shell+.section-shell{border-top:1px solid rgba(110,200,187,.07)}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;margin:0 0 .85rem;color:var(--teal);font-size:.72rem;letter-spacing:.11em;text-transform:uppercase;font-weight:850}
.eyebrow span{width:20px;height:1px;background:var(--teal);border-radius:999px}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(2.4rem,5.2vw,4.55rem);line-height:1.03;letter-spacing:-.045em;max-width:760px;margin-bottom:1.1rem}
h2{font-size:clamp(2rem,3.2vw,3.35rem);line-height:1.06;letter-spacing:-.04em;margin-bottom:.85rem}
h3{font-size:1.02rem;line-height:1.25;margin-bottom:.55rem}
p{color:var(--muted)}
.hero{position:relative;width:100%;display:grid;grid-template-columns:minmax(300px,480px) minmax(0,640px);justify-content:center;gap:clamp(2.5rem,5vw,5rem);align-items:center;min-height:clamp(480px,64vh,640px);padding:clamp(2rem,4vh,3.5rem) clamp(1.5rem,5vw,5.5rem) clamp(1.5rem,3vh,2.5rem);overflow:hidden;scroll-margin-top:92px}
.hero::before{content:"";position:absolute;inset:0;z-index:-4;background:
  radial-gradient(70% 80% at 78% 18%,rgba(20,58,108,.55),transparent 70%),
  radial-gradient(60% 70% at 12% 90%,rgba(12,74,90,.4),transparent 72%),
  linear-gradient(115deg,rgba(12,28,56,.94) 0%,rgba(7,16,33,.9) 48%,rgba(7,30,42,.82) 100%)}
.hero::after{content:"";position:absolute;inset:0;z-index:-3;pointer-events:none;background:
  linear-gradient(rgba(110,200,187,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(110,200,187,.03) 1px,transparent 1px);
  background-size:60px 60px,60px 60px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.32) 60%,rgba(0,0,0,.7))}
.hero-report{max-width:none;margin:0}
.hero-copy{position:relative;z-index:2;width:100%;max-width:760px;justify-self:start;align-self:center;padding:0}
.hero-name{color:var(--teal);font-size:clamp(1.05rem,1.3vw,1.3rem);font-weight:800;margin:0 0 .5rem;letter-spacing:.005em}
.hero h1{color:var(--text);font-size:clamp(2.8rem,4.4vw,5rem);line-height:1.02;letter-spacing:-.045em;margin-bottom:.9rem;max-width:760px}
.hero-tagline{color:#eef3fa;font-size:clamp(1.04rem,1.45vw,1.28rem);font-weight:700;font-style:italic;margin-bottom:1.7rem}
.hero-lead{font-size:clamp(.98rem,1.1vw,1.08rem);max-width:680px;color:#edf3fa;font-weight:520;line-height:1.62}
.hero h1.hero-headline{color:var(--teal)}
.hero-lead strong{color:#fff;font-weight:800}
.hero-lead + .hero-lead{margin-top:1.25rem}
.hero-skill-line{max-width:680px;color:#dbe5ef;font-size:clamp(.96rem,1.04vw,1.02rem);font-weight:650;line-height:1.56}
.hero-skill-line strong{color:#fff}
.hero-actions,.contact-actions{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;margin:1.35rem 0}
.hero-actions{margin:2rem 0 0}
.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.78rem 1.05rem;border-radius:999px;font-weight:850;border:1px solid transparent;min-height:44px;transition:background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease}
.button:hover{transform:translateY(-1px)}
.button:focus-visible,.filter-button:focus-visible,.dialog-close:focus-visible,.nav-toggle:focus-visible{outline:3px solid rgba(110,200,187,.55);outline-offset:3px}
.button-primary{background:var(--teal);color:#07110f;border-color:rgba(101,200,189,.75);box-shadow:0 12px 30px rgba(110,200,187,.16)}
.button-secondary{background:rgba(110,200,187,.1);color:var(--teal);border-color:rgba(110,200,187,.5)}
.button-secondary:hover{background:rgba(110,200,187,.18);border-color:var(--teal);color:#bff0e8;box-shadow:none}
.button-primary:hover{background:#91ded5;color:#07110f;box-shadow:0 16px 36px rgba(110,200,187,.22)}
.button-ghost{background:transparent;border-color:var(--line-strong);color:var(--text)}
.button-ghost:hover{border-color:var(--teal);background:rgba(110,200,187,.08)}
.tool-strip{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:1.25rem}
.tool-strip span,.tech-cloud span{display:inline-flex;align-items:center;border:1px solid var(--line);background:rgba(255,255,255,.03);color:#d5dde8;border-radius:999px;padding:.34rem .58rem;font-size:.78rem;font-weight:740}
.hero-portrait{position:relative;z-index:2;align-self:end;justify-self:end;display:flex;justify-content:flex-end;order:1;min-width:0;margin-bottom:calc(-1 * clamp(1.5rem,3vh,2.5rem))}
.hero-copy{order:2}
.hero-portrait img{width:100%;max-width:460px;height:auto;max-height:min(58vh,560px);object-fit:contain;object-position:center bottom;filter:drop-shadow(0 18px 28px rgba(0,0,0,.52))}
.hero-data-band{position:absolute;left:0;right:0;bottom:0;height:34%;z-index:-2;background:
  linear-gradient(180deg,transparent,rgba(8,22,46,.55) 55%,rgba(7,28,42,.78));
  border-top:1px solid rgba(110,200,187,.16)}
.hero-data-band::after{content:"";position:absolute;inset:0;background:
  radial-gradient(50% 120% at 30% 100%,rgba(79,128,255,.22),transparent 70%),
  radial-gradient(45% 120% at 72% 100%,rgba(110,200,187,.18),transparent 72%);
  opacity:.8}
.impact-panel{display:grid;grid-template-columns:1fr;gap:1rem;align-items:stretch}
.impact-intro{max-width:none;padding:clamp(1.4rem,2.6vw,2rem);border:1px solid rgba(110,200,187,.18);border-radius:18px;background:linear-gradient(135deg,rgba(7,17,35,.86),rgba(3,7,19,.7));box-shadow:var(--soft-shadow);display:flex;flex-direction:column;justify-content:center}
.impact-intro h2{max-width:720px;font-size:clamp(2rem,2.8vw,3rem)}
.impact-intro p{max-width:620px;font-size:1rem}
.metrics-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.7rem}
.metrics-grid article{min-height:150px;border:1px solid rgba(110,200,187,.16);border-radius:18px;background:linear-gradient(180deg,rgba(9,22,48,.82),rgba(3,7,19,.68));padding:1rem;box-shadow:0 14px 35px rgba(0,0,0,.18);display:flex;flex-direction:column;justify-content:space-between}
.metrics-grid strong{display:block;color:var(--teal);font-size:clamp(2rem,2.9vw,3rem);letter-spacing:-.045em;line-height:1;font-weight:900}
.metrics-grid span{display:block;color:#e5ebf3;margin-top:.9rem;font-weight:720;font-size:clamp(.82rem,.95vw,.96rem);line-height:1.26;max-width:18ch}
.section-heading{margin-bottom:1.8rem;display:flex;flex-direction:column;gap:.2rem;max-width:900px}
.section-heading.compact{max-width:720px}
.section-heading.with-actions{max-width:none;flex-direction:row;justify-content:space-between;align-items:end;gap:2rem}
.cards-grid{display:grid;gap:.8rem}
.service-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.glass-card{border:1px solid rgba(110,200,187,.15);border-radius:18px;background:linear-gradient(180deg,rgba(7,17,35,.82),rgba(3,7,19,.72));box-shadow:none;padding:1.1rem;position:relative;overflow:hidden}
.glass-card:hover{border-color:rgba(110,200,187,.48)}
.icon-chip{width:34px;height:28px;display:grid;place-items:center;border-radius:6px;color:var(--teal);background:rgba(110,200,187,.09);border:1px solid rgba(110,200,187,.35);font-size:.78rem;font-weight:900;margin-bottom:1rem}
.architecture{padding-top:.75rem}
.architecture-flow{display:grid;grid-template-columns:1fr 36px 1fr 36px 1fr 36px 1fr 36px 1fr;gap:.55rem;align-items:stretch;border:1px solid rgba(110,200,187,.16);border-radius:18px;padding:.85rem;background:linear-gradient(135deg,rgba(7,17,35,.82),rgba(3,7,19,.66));box-shadow:var(--soft-shadow)}
.flow-node{min-height:112px;padding:.9rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(7,17,35,.92),rgba(3,7,19,.88))}
.flow-node small{display:block;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;font-weight:900;margin-bottom:.5rem}
.flow-node strong{display:block;line-height:1.35;color:#e7edf5;font-size:.92rem}
.flow-arrow{display:flex;align-items:center;justify-content:center;color:var(--teal);opacity:.65;font-size:1.3rem;line-height:1}
.flow-arrow::after{content:"›"}
.portfolio .section-heading.with-actions{align-items:end;display:grid;grid-template-columns:minmax(0,1fr) auto}
.portfolio .section-heading.with-actions>div:first-child{max-width:760px}
.portfolio .section-heading h2{font-size:clamp(2.2rem,3.4vw,3.6rem)}
.filters{display:grid;grid-template-columns:repeat(5,max-content);align-items:center;gap:.25rem;justify-content:flex-end;padding:.3rem;border:1px solid rgba(110,200,187,.16);border-radius:999px;background:rgba(7,17,35,.62);backdrop-filter:blur(14px);white-space:nowrap}
.filter-button{border:0;background:transparent;color:#aeb8c7;border-radius:999px;padding:.58rem .82rem;cursor:pointer;font-weight:850;font-size:.84rem;transition:.18s ease}
.filter-button:hover,.filter-button.is-active{background:rgba(110,200,187,.16);color:var(--teal);box-shadow:inset 0 0 0 1px rgba(110,200,187,.28)}
.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem}
.project-card{border:1px solid rgba(110,200,187,.14);border-radius:18px;background:linear-gradient(180deg,rgba(6,15,32,.9),rgba(2,5,14,.82));overflow:hidden;box-shadow:0 18px 50px rgba(0,0,0,.18);transition:transform .18s ease,border-color .18s ease, box-shadow .18s ease;display:flex;flex-direction:column;cursor:pointer}
.project-card:hover{transform:translateY(-4px);border-color:rgba(110,200,187,.45);box-shadow:0 24px 70px rgba(0,0,0,.26)}
.project-card img{width:100%;aspect-ratio:16/8.8;object-fit:cover;background:#0b1730;border-bottom:1px solid var(--line)}
.project-body{padding:1rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.project-kicker{display:flex;align-items:center;justify-content:space-between;gap:.7rem;flex-wrap:wrap;color:var(--teal);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-weight:900}
.dialog-subtitle{color:#7fd6cb;font-size:.82rem;font-weight:800;margin:-.28rem 0 .1rem;text-transform:uppercase;letter-spacing:.05em}
.project-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin:.1rem 0 .3rem}
.project-tags span{border:1px solid var(--line);color:#bac6d5;background:rgba(255,255,255,.025);font-size:.7rem;border-radius:999px;padding:.16rem .42rem}
.project-card button{align-self:flex-start;margin-top:auto;background:rgba(110,200,187,.1);color:var(--teal);border:1px solid rgba(110,200,187,.62);border-radius:var(--radius);padding:.55rem .72rem;cursor:pointer;font-size:.86rem;font-weight:850;transition:.18s ease}
.project-card button:hover{background:rgba(110,200,187,.18)}
.timeline{position:relative;display:grid;gap:.8rem;max-width:940px}
.timeline::before{content:"";position:absolute;left:12px;top:0;bottom:0;width:1px;background:linear-gradient(var(--teal),rgba(79,128,255,.45),transparent)}
.timeline article{position:relative;margin-left:38px;border:1px solid rgba(110,200,187,.14);border-radius:14px;background:linear-gradient(180deg,rgba(7,17,35,.82),rgba(3,7,19,.7));padding:1.05rem 1.15rem}
.timeline article::before{content:"";position:absolute;left:-32px;top:1.2rem;width:10px;height:10px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 5px rgba(110,200,187,.12)}
.timeline span{display:inline-block;color:var(--teal);font-size:.75rem;font-weight:900;margin-bottom:.35rem}
.credentials .section-heading h2{max-width:780px}
.credential-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.4fr);gap:1rem;align-items:stretch}
.tech-cloud{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem;padding:clamp(1rem,2vw,1.35rem);border:1px solid rgba(110,200,187,.16);border-radius:18px;background:linear-gradient(135deg,rgba(7,17,35,.82),rgba(3,7,19,.68));box-shadow:var(--soft-shadow)}
.tech-cloud span{justify-content:center;text-align:center;padding:.62rem .72rem;font-size:clamp(.78rem,1vw,.88rem);background:rgba(255,255,255,.035);white-space:nowrap}
.credential-card h3{color:var(--teal)}
.credential-card{border-radius:18px;padding:clamp(1.2rem,2.4vw,1.75rem)}
.contact-card{text-align:left;max-width:none;margin:0 auto;border:1px solid rgba(110,200,187,.18);border-radius:22px;padding:clamp(1.9rem,4vw,3.2rem);background:linear-gradient(135deg,rgba(9,20,42,.92),rgba(3,7,19,.74));box-shadow:var(--soft-shadow);display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:clamp(2rem,4vw,4rem);align-items:center}
.contact-lead{display:flex;flex-direction:column}
.contact-card h2{max-width:none;font-size:clamp(2.4rem,3.4vw,3.6rem);margin-bottom:.55rem}
.contact-sub{max-width:440px;font-size:1.02rem;margin-bottom:1.7rem}
.contact-meta{margin:0;display:flex;flex-direction:column}
.contact-meta div{display:grid;grid-template-columns:80px minmax(0,1fr);gap:1rem;align-items:baseline;padding:.72rem 0;border-bottom:1px solid rgba(110,200,187,.1)}
.contact-meta div:last-child{border-bottom:0;padding-bottom:0}
.contact-meta dt{margin:0;color:var(--teal);font-size:.7rem;text-transform:uppercase;letter-spacing:.09em;font-weight:850}
.contact-meta dd{margin:0;color:#eef3fa;font-weight:700;font-size:1rem;overflow-wrap:anywhere}
.contact-meta a{color:#eef3fa;transition:color .18s ease}
.contact-meta a:hover{color:var(--teal)}
.contact-actions{display:flex;flex-direction:column;align-items:stretch;gap:.7rem;margin:0;align-self:center;padding:clamp(1.3rem,2vw,1.7rem);border:1px solid rgba(110,200,187,.16);border-radius:16px;background:rgba(110,200,187,.045)}
.contact-actions-label{color:var(--teal);font-size:.72rem;text-transform:uppercase;letter-spacing:.09em;font-weight:850;margin:0 0 .3rem}
.contact-actions .button{width:100%;justify-content:center;padding:.95rem 1.2rem;font-size:.98rem}
/* Full-width alternating section tints */
#services,#experience{position:relative}
#services::before,#experience::before{content:"";position:absolute;inset:0;left:50%;transform:translateX(-50%);width:100vw;background:rgba(9,20,44,.48);z-index:-1;pointer-events:none}
.site-footer{border-top:1px solid rgba(110,200,187,.12);padding:1.4rem;text-align:center;color:var(--muted);font-size:.86rem;background:rgba(5,11,24,.92)}
.project-dialog{width:min(1760px,calc(100vw - 1.4rem));max-height:calc(100vh - 1.4rem);border:1px solid rgba(110,200,187,.32);border-radius:22px;background:#050b18;color:var(--text);padding:0;box-shadow:0 35px 90px rgba(0,0,0,.72);overflow:auto}
.project-dialog::backdrop{background:rgba(0,0,0,.82);backdrop-filter:blur(10px)}
.dialog-close{position:sticky;float:right;right:.85rem;top:.85rem;z-index:5;border:1px solid rgba(110,200,187,.34);background:rgba(7,17,35,.92);color:var(--text);border-radius:999px;width:40px;height:40px;cursor:pointer;font-size:1.45rem;line-height:1;box-shadow:0 12px 30px rgba(0,0,0,.35)}
.case-study-shell{min-height:min(860px,calc(100vh - 1.5rem));padding:clamp(1rem,2vw,1.8rem);background:
  radial-gradient(circle at 50% 18%,rgba(79,128,255,.18),transparent 30rem),
  radial-gradient(circle at 12% 72%,rgba(79,128,255,.2),transparent 18rem),
  radial-gradient(circle at 90% 62%,rgba(110,200,187,.13),transparent 20rem),
  linear-gradient(180deg,#071123,#02050d 72%,#050b18)}
.case-study-header{max-width:980px;margin:0 auto clamp(1rem,2vw,1.6rem);text-align:center}
.case-study-header .eyebrow{justify-content:center}
.case-study-header h2{font-size:clamp(2rem,3vw,3.6rem);margin-bottom:.55rem}
.case-study-header p{max-width:760px;margin-left:auto;margin-right:auto}
.dialog-tools{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem;margin-top:.85rem}
.dialog-tools span{border:1px solid rgba(110,200,187,.24);border-radius:999px;padding:.24rem .58rem;color:#dbe4ef;font-size:.76rem;background:rgba(255,255,255,.035)}
.case-study-stage{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,2fr) minmax(0,.8fr);gap:clamp(.85rem,1.8vw,1.4rem);align-items:start}
.case-panel{align-self:start;display:flex;flex-direction:column;justify-content:flex-start;gap:clamp(1.5rem,2.6vh,2.3rem);border:1px solid rgba(150,182,214,.24);border-radius:22px;padding:clamp(1.5rem,2.1vw,2.3rem) clamp(1.3rem,1.8vw,1.9rem);background:linear-gradient(150deg,rgba(17,30,55,.92),rgba(8,16,34,.8));box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 26px 60px rgba(0,0,0,.3)}
.case-panel-block{display:flex;flex-direction:column;gap:.5rem}
.case-glance{margin:0;display:flex;flex-direction:column;gap:.6rem}
.case-glance div{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.3rem 1rem;padding-bottom:.55rem;border-bottom:1px solid rgba(110,200,187,.12)}
.case-glance div:last-child{border-bottom:0;padding-bottom:0}
.case-glance dt{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;font-weight:800}
.case-glance dd{margin:0;color:#eef3fa;font-weight:700;font-size:.92rem;text-align:right;min-width:0;overflow-wrap:anywhere}
.case-panel h3{color:#e89248;font-size:clamp(.95rem,1.05vw,1.12rem);font-weight:800;margin:.5rem 0 .15rem;text-decoration:underline;text-decoration-color:rgba(232,146,72,.65);text-underline-offset:5px;text-decoration-thickness:2px}
.case-panel h3:first-child{margin-top:0}
.case-panel p,.case-panel li{color:#e7edf5;font-size:clamp(.82rem,.92vw,.96rem);line-height:1.62}
.case-panel ol{margin:.2rem 0 0;padding-left:1.1rem}
.laptop-showcase{min-width:0;display:flex;flex-direction:column;align-items:center}
.carousel-controls{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;margin-top:clamp(.7rem,1.6vw,1.4rem)}
.laptop-frame{position:relative;width:100%;max-width:1040px;margin:0 auto 1.7rem;padding:clamp(.95rem,1.4vw,1.3rem) clamp(.95rem,1.4vw,1.3rem) clamp(1.1rem,1.6vw,1.45rem);border:1px solid rgba(210,224,240,.4);border-radius:18px 18px 10px 10px;background:linear-gradient(150deg,#0b0e14,#2c2f35 52%,#0e1117);box-shadow:0 30px 70px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.2)}
.laptop-camera{position:absolute;top:.62rem;left:50%;width:10px;height:10px;margin-left:-5px;border-radius:50%;background:#05070b;border:1px solid #222a35;box-shadow:inset 0 0 0 2px rgba(79,128,255,.08)}
.laptop-screen{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:#05070b;box-shadow:inset 0 0 0 1px rgba(0,0,0,.9)}
.laptop-screen img{width:100%;height:auto;display:block;background:#0b1220;cursor:zoom-in}
.img-lightbox{width:96vw;max-width:96vw;height:96vh;max-height:96vh;border:0;padding:0;background:transparent;overflow:hidden;cursor:zoom-out}
.img-lightbox::backdrop{background:rgba(2,5,12,.92);backdrop-filter:blur(6px)}
.img-lightbox img{width:100%;height:100%;object-fit:contain;display:block}
.img-lightbox-hint{position:fixed;left:50%;bottom:1.1rem;transform:translateX(-50%);color:#cdd8e6;background:rgba(7,17,35,.8);border:1px solid rgba(110,200,187,.25);border-radius:999px;padding:.4rem .9rem;font-size:.8rem;font-weight:700}
.screen-glare{position:absolute;inset:0;pointer-events:none;background:linear-gradient(70deg,transparent 0 60%,rgba(255,255,255,.05) 62% 70%,transparent 72%);mix-blend-mode:screen}
.laptop-base{position:absolute;left:-6%;right:-6%;bottom:-1.35rem;height:1.35rem;border-radius:0 0 28px 28px;background:linear-gradient(180deg,#e7eaef,#aab0b8 46%,#33373f);box-shadow:0 22px 26px rgba(0,0,0,.4)}
.laptop-base span{position:absolute;left:45%;right:45%;top:0;height:.34rem;border-radius:0 0 9px 9px;background:linear-gradient(180deg,#aeb3ba,#7d828b)}
.carousel-bar{width:100%;max-width:1040px;display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:.8rem;margin-top:.2rem}
.carousel-bar>div{text-align:center}
.carousel-bar strong{display:block;color:#fff;font-size:1rem}
.carousel-bar span{display:block;color:var(--teal);font-size:.76rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.carousel-arrow{width:44px;height:44px;border-radius:999px;border:1px solid rgba(110,200,187,.34);background:rgba(7,17,35,.86);color:#fff;font-size:1.9rem;line-height:1;cursor:pointer;transition:.18s ease}
.carousel-arrow:hover{background:rgba(110,200,187,.16);border-color:var(--teal)}
.carousel-thumbs{width:100%;max-width:1040px;display:flex;gap:.45rem;overflow-x:auto;padding:.7rem .35rem .25rem;scrollbar-width:none;-ms-overflow-style:none;mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.carousel-thumbs::-webkit-scrollbar{display:none}
.carousel-thumbs button{position:relative;flex:0 0 84px;border:1px solid rgba(110,200,187,.18);border-radius:10px;background:rgba(255,255,255,.04);padding:.25rem;cursor:pointer;opacity:.6;transition:.18s ease}
.carousel-thumbs button:hover{opacity:.92;border-color:rgba(110,200,187,.5)}
.carousel-thumbs button.is-active{opacity:1;border-color:var(--teal);box-shadow:0 0 0 2px var(--teal),0 6px 16px rgba(110,200,187,.25);transform:translateY(-2px)}
.carousel-thumbs img{width:100%;aspect-ratio:16/9;object-fit:cover;background:#eef3f7;border-radius:6px}
.carousel-thumbs span{position:absolute;left:.38rem;bottom:.34rem;color:#fff;background:rgba(0,0,0,.66);border-radius:999px;padding:.05rem .28rem;font-size:.6rem;font-weight:900}
.reveal{opacity:0;transform:translateY(12px);transition:opacity .55s ease,transform .55s ease}
.reveal.is-visible{opacity:1;transform:none}
@media (max-width:1080px){
  .hero{grid-template-columns:minmax(260px,.78fr) minmax(0,1fr);gap:clamp(1.4rem,3.5vw,3rem);padding-left:clamp(1.25rem,4vw,3rem);padding-right:clamp(1.25rem,4vw,3rem)}
  .hero h1{font-size:clamp(3rem,6vw,4.6rem)}
  .hero-portrait img{width:100%;max-width:380px}
  .case-study-stage{grid-template-columns:minmax(0,.75fr) minmax(0,2fr) minmax(0,.75fr)}
  .case-panel{padding:.9rem;border-radius:18px}
  .case-panel p,.case-panel li{font-size:.78rem}
  .impact-panel{grid-template-columns:1fr}
  .metrics-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .metrics-grid article{min-height:140px}
  .portfolio .section-heading.with-actions{grid-template-columns:1fr;align-items:flex-start}
  .filters{justify-content:flex-start}
  .credential-layout{grid-template-columns:1fr}
  .contact-card{grid-template-columns:1fr}
}
@media (max-width:980px){
  .service-grid,.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .section-heading.with-actions{align-items:start;flex-direction:column}
  .architecture-flow{grid-template-columns:1fr}
  .flow-arrow{display:block;width:1px;height:20px;margin:auto;background:linear-gradient(var(--teal),var(--cyan));font-size:0}
  .flow-arrow::after{display:none}
  .contact-actions{justify-content:flex-start}
  .case-study-stage{grid-template-columns:1fr}
  .laptop-showcase{order:1}
  .carousel-controls{order:2}
  .case-panel-left{order:3}
  .case-panel-right{order:4}
  .case-panel{justify-content:flex-start}
}
@media (max-width:760px){
  .nav-toggle{display:block}
  .site-nav{position:absolute;right:1rem;top:calc(100% + .5rem);left:1rem;display:none;flex-direction:column;align-items:stretch;background:#0d141d;border:1px solid var(--line);border-radius:var(--radius);padding:.55rem;box-shadow:var(--shadow)}
  .site-nav.is-open{display:flex}
  .site-nav a{padding:.78rem .9rem}
  .hero{grid-template-columns:1fr;min-height:auto;padding:2.4rem 1rem}
  .hero-report{padding-left:1rem;padding-right:1rem}
  .hero-portrait{order:2;max-width:360px;margin:0 auto}
  .hero-copy{order:1}
  .hero-portrait img{width:100%;max-width:300px;max-height:430px}
  .metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .metrics-grid article:nth-child(-n+3),.metrics-grid article:nth-child(n+4){grid-column:span 1}
  .metrics-grid article:last-child{grid-column:1/-1}
  .service-grid,.project-grid{grid-template-columns:1fr}
  .filters{grid-template-columns:repeat(5,max-content);max-width:100%;overflow:auto;border-radius:999px}
  .tech-cloud{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-actions{grid-template-columns:1fr}
  .contact-actions .button{width:100%}
  h1{font-size:clamp(2.2rem,11vw,3.6rem)}
  .contact-meta{justify-content:flex-start;text-align:left}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .backdrop-aurora,.backdrop-grid,.backdrop-scan{animation:none}
}
