/* =====================================================
   NETHERA — Studio styles
   Dark cinematic · graphite + deep purple · neon accents
   ===================================================== */

:root{
  --bg:        #07060d;
  --bg-2:      #0b0a14;
  --ink:       #ececf3;
  --ink-soft:  #a9a9b8;
  --ink-mute:  #6b6b7a;
  --line:      rgba(255,255,255,0.08);
  --line-2:    rgba(255,255,255,0.14);

  --violet:    #8a5cff;
  --violet-2:  #6b3df5;
  --cyan:      #00e0ff;
  --pink:      #ff5ce0;
  --green:     #7cffb0;

  --grad:      linear-gradient(120deg,#8a5cff 0%, #00e0ff 100%);
  --grad-soft: linear-gradient(120deg,rgba(138,92,255,.18), rgba(0,224,255,.18));

  --r-lg: 22px;
  --r-md: 14px;
  --r-sm: 10px;

  --container: 1320px;

  --ease-out: cubic-bezier(.22,1,.36,1);
  --ease-in-out: cubic-bezier(.65,0,.35,1);
  --ease-expo: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html,body{
  margin:0; padding:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Space Grotesk','Inter',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;
}
html{ scroll-behavior:smooth; }
body{ min-height:100vh; }
img,svg,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
::selection{ background:rgba(138,92,255,.45); color:#fff; }

/* =================== Background overlays =================== */
.bg-grid{
  position:fixed; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 80%);
  pointer-events:none;
  z-index:0;
  opacity:.5;
}
.bg-noise{
  position:fixed; inset:0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 .08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  pointer-events:none;
  z-index:1;
  opacity:.5;
  mix-blend-mode: overlay;
}
.bg-glow{
  position:fixed; pointer-events:none; z-index:0; border-radius:50%; filter: blur(120px); opacity:.55;
}
.bg-glow--a{ width:1080px; height:1080px; left:-160px; top:-200px; background: radial-gradient(circle, #7ba5ff 0%, transparent 85%); }
.bg-glow--b{ width:1280px; height:1280px; right:-220px; top:30vh; background: radial-gradient(circle, #470000 0%, transparent 85%); opacity:.4; }

#particles{
  position:fixed; inset:0; z-index:1; pointer-events:none;
}

/* =================== Cursor =================== */
.cursor{ position:fixed; left:0; top:0; pointer-events:none; z-index:9999; mix-blend-mode:difference; }
.cursor-dot{
  position:fixed; width:6px; height:6px; border-radius:50%;
  background:#fff; transform:translate(-50%,-50%);
  transition: width .25s var(--ease-out), height .25s var(--ease-out), background .25s;
}
.cursor-ring{
  position:fixed; width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(255,255,255,.5);
  transform:translate(-50%,-50%);
  transition: width .35s var(--ease-out), height .35s var(--ease-out), border-color .25s;
}
.cursor.is-hover .cursor-ring{ width:56px; height:56px; border-color:#fff; }
.cursor.is-hover .cursor-dot{ width:10px; height:10px; }
.cursor.is-down .cursor-ring{ width:28px; height:28px; }
@media (max-width: 900px), (hover: none){ .cursor{ display:none; } body{ cursor:auto; } }
@media (hover:hover){ body{ cursor:none; } a,button,input,textarea,select{ cursor:none; } }

/* =================== Loader =================== */
.loader{
  position:fixed; inset:0; z-index:1000; background:#06050c;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.loader-grid{
  position:absolute; inset:-20%;
  background-image:
    linear-gradient(rgba(138,92,255,.08) 1px,transparent 1px),
    linear-gradient(90deg, rgba(138,92,255,.08) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  animation: loaderPan 14s linear infinite;
}
@keyframes loaderPan{ from{ transform:translate(0,0); } to{ transform:translate(-48px,-48px); } }
.loader-inner{
  position:relative;
  display:flex; flex-direction:column; align-items:center; gap:22px;
  text-align:center;
  width:min(440px, 80vw);
}
.loader-bar{ width:100%; height:2px; background:rgba(255,255,255,.08); overflow:hidden; border-radius:2px; }
.loader-bar span{
  display:block; width:0%; height:100%;
  background: var(--grad);
  box-shadow: 0 0 18px rgba(138,92,255,.6);
}
.loader-meta{
  display:flex; justify-content:space-between; width:100%;
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.18em;
  color:var(--ink-mute); text-transform:uppercase;
}
.loader.is-out{ pointer-events:none; }

/* =================== Nav =================== */
.nav{
  position:fixed; top:18px; left:50%; transform:translateX(-50%);
  width:min(var(--container), calc(100% - 36px));
  max-width: 100%;
  display:grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items:center;
  gap:10px 14px;
  padding:12px 14px 12px 18px;
  border:1px solid var(--line);
  border-radius:999px;
  background: rgba(11,10,20,.55);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  z-index:80;
  transition: background .35s, border-color .35s;
  overflow: visible;
}
.nav-logo{
  display:flex; align-items:center; gap:10px;
  font-weight:700; letter-spacing:.18em; font-size:13px;
  flex-shrink:0;
  justify-self: start;
  min-width: 0;
}
/* Kelime-logo (wordmark): kareye sıkıştırma, yüksekliğe göre ölçekle */
.nav-logo-img,
.footer-logo-img{
  height:88px; width:auto;
  object-fit: contain;
  flex-shrink:0;
  filter: drop-shadow(0 0 10px rgba(212,175,90,.35));
}
.footer-logo-img{ height:96px; }

/* Görselde marka adı zaten yazılı — metni görsel olarak gizle, SEO/erişilebilirlik için DOM'da bırak */
.nav-logo-text,
.footer-logo-text{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}
.loader-logo-img{
  width:min(420px, 92vw); height:auto;
  object-fit: contain;
  margin: 0 auto;
}

.nav-links{
  display:flex; gap:4px;
  justify-self: center;
  justify-content: center;
  flex-wrap: nowrap;
  min-width: 0;
}
.nav-links a{
  position:relative;
  padding:9px 12px; border-radius:999px;
  font-size:13px; color:var(--ink-soft);
  white-space:nowrap;
  transition: color .2s, background .2s;
}
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.05); }

.nav-actions{
  display:flex; align-items:center; gap:8px;
  justify-self: end;
  flex-shrink:0;
  min-width: max-content;
}
.nav-right{
  display:flex; align-items:center; gap:8px;
  flex-shrink:0;
}

.lang-toggle{
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.18em;
  color:var(--ink-soft);
  padding:8px 12px; border-radius:999px; border:1px solid var(--line);
  transition: color .2s, border-color .2s, background .2s;
}
.lang-toggle:hover{ color:#fff; border-color:var(--line-2); }
.lang-toggle .lang-sep{ opacity:.4; margin:0 4px; }
[data-lang="en"] .lang-en{ color:#fff; }
[data-lang="tr"] .lang-tr{ color:#fff; }
[data-lang="en"] .lang-tr,[data-lang="tr"] .lang-en{ opacity:.45; }

.nav-burger{
  display:none; width:42px; height:42px; border-radius:50%;
  border:1px solid var(--line);
  flex-direction:column; gap:5px; align-items:center; justify-content:center;
  flex-shrink:0;
}
.nav-burger span{ width:16px; height:1.5px; background:#fff; border-radius:2px; transition: transform .3s, opacity .3s; }
.nav-burger.is-open span:first-child{ transform: translateY(3.5px) rotate(45deg); }
.nav-burger.is-open span:last-child{ transform: translateY(-3px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0; z-index:75;
  background: rgba(7,6,13,.92);
  backdrop-filter: blur(16px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:18px; font-size:28px;
  opacity:0; pointer-events:none; transition: opacity .35s;
}
.mobile-menu.is-open{ opacity:1; pointer-events:auto; }
.mobile-menu a{ color:#fff; font-weight:500; }
.lang-toggle--mobile{ margin-top:18px; font-size:12px; }

/* tight desktop: shrink link padding so everything fits */
@media (max-width: 1180px){
  .nav{ gap: 8px 10px; padding: 10px 10px 10px 14px; }
  .nav-links{ gap: 2px; }
  .nav-links a{ padding: 9px 8px; font-size: 12px; }
  .nav-logo span{ display:none; }
}

/* narrow desktop: hide CTA first, keep lang + links visible */
@media (max-width: 1080px){
  .nav-right .btn{ display:none; }
}

/* tablet: hide center links earlier so sağ blok (dil + menü) kesilmesin */
@media (max-width: 1024px){
  .nav{
    grid-template-columns: auto 1fr auto;
    width: min(var(--container), calc(100% - 24px));
  }
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .nav-logo span{ display:inline; }
}

/* mobile */
@media (max-width: 560px){
  .nav{
    top:12px;
    padding:8px 10px 8px 12px;
    gap:8px;
  }
  .nav-right .btn{ display:none; }
  .lang-toggle{ padding:8px 10px; font-size:10px; }
  .btn-ghost{ padding:8px 12px; font-size:11px; }
}

/* =================== Buttons =================== */
.btn{
  position:relative;
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 22px; border-radius:999px;
  font-size:13px; letter-spacing:.06em; font-weight:500;
  transition: transform .25s var(--ease-out), background .25s, color .25s, border-color .25s, box-shadow .35s;
  will-change: transform;
}
.btn svg{ transition: transform .35s var(--ease-out); }
.btn:hover svg{ transform: translateX(4px); }

.btn-primary{
  background: linear-gradient(120deg, #fff 0%, #d8d6ff 100%);
  color:#0a0815;
  box-shadow: 0 10px 40px -10px rgba(255,255,255,.35), inset 0 0 0 1px rgba(255,255,255,.5);
}
.btn-primary:hover{ box-shadow: 0 14px 50px -10px rgba(138,92,255,.6), inset 0 0 0 1px rgba(255,255,255,.5); }

.btn-outline{
  border:1px solid var(--line-2); color:#fff;
  background: rgba(255,255,255,0.02);
}
.btn-outline:hover{ background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,.35); }

.btn-ghost{
  border:1px solid var(--line); color:#fff;
  font-size:12px; padding:10px 16px;
  background: rgba(255,255,255,0.02);
}
.btn-ghost:hover{ border-color: var(--line-2); background: rgba(255,255,255,0.05); }

.btn-block{ width:100%; justify-content:center; padding:16px 22px; font-size:14px; }

/* =================== Hero =================== */
.hero{
  position:relative;
  min-height: 100svh;
  padding: 160px 28px 80px;
  display:flex; flex-direction:column; justify-content:space-between;
  overflow:hidden;
  z-index:2;
}
.hero-orb{
  position:absolute; border-radius:50%; filter: blur(80px); pointer-events:none;
}
.hero-orb--1{
  width:520px; height:520px; left:-100px; top:60px;
  background: radial-gradient(circle, rgba(138,92,255,.55) 0%, transparent 60%);
}
.hero-orb--2{
  width:620px; height:620px; right:-160px; top:160px;
  background: radial-gradient(circle, rgba(0,224,255,.4) 0%, transparent 60%);
}

.hero-meta{
  position:relative;
  display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:10px 16px;
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.2em;
  color:var(--ink-mute); text-transform:uppercase;
  z-index:3;
}
.hero-meta-row{ display:flex; align-items:center; gap:10px; }
@media (max-width: 640px){
  .hero-meta-row--right{ width:100%; }
  .hero{ padding: 140px 20px 70px; }
  .hero-inner{ padding: 40px 0 60px; }
  .hero-scroll{ display:none; }
  .marquee{ margin: 40px -20px 0; }
  .section-head{ padding: 0 20px; }
  .about-grid, .stats, .service-grid, .work-rail, .timeline,
  .testi-grid, .contact-inner, .footer-grid{
    padding-left:20px; padding-right:20px;
  }
  .work-rail{ padding-left:20px; padding-right:20px; }
}
.dot{ width:6px; height:6px; border-radius:50%; background:#7cffb0; box-shadow: 0 0 10px #7cffb0; }
.dot.pulse{ animation: pulseDot 1.8s infinite ease-in-out; }
@keyframes pulseDot{ 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.4; transform:scale(.9); } }

.hero-inner{
  position:relative;
  max-width: var(--container);
  margin: auto auto 0;
  width:100%;
  padding: 60px 0 80px;
  z-index:3;
}

.hero-eyebrow{
  font-family:'Inter',sans-serif; font-size:11px;
  letter-spacing:.32em; color:var(--ink-mute); text-transform:uppercase;
  margin-bottom:32px;
}

.hero-title{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size: clamp(46px, 9vw, 148px);
  line-height: 1.08;
  letter-spacing:-0.03em;
  margin:0 0 36px;
}
.hero-title .line{
  display:block;
  overflow:hidden;
  padding-bottom: 0.14em;
}
.hero-title .line-inner{
  display:block;
  transform: translateY(110%);
  will-change: transform;
}
.hero-title .word{
  display:inline-block;
  white-space:nowrap;
}
.hero-title .italic{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  letter-spacing:-0.01em;
}
/* Gradient her harfe — parent'ta background-clip çocuk .char'larda görünmez */
.hero-title .line-inner.italic .char{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  letter-spacing:-0.01em;
  background: var(--grad);
  background-clip:text;
  -webkit-background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
}

.hero-sub{
  max-width: 620px;
  font-size: clamp(15px, 1.5vw, 19px);
  line-height:1.55;
  color: var(--ink-soft);
  margin: 0 0 44px;
}

.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }

.hero-scroll{
  position:absolute; bottom:-30px; right:0;
  display:flex; align-items:center; gap:14px;
  font-family:'Inter',sans-serif; font-size:10px; letter-spacing:.32em;
  color: var(--ink-mute);
}
.hero-scroll-line{ width:80px; height:1px; background: rgba(255,255,255,.12); overflow:hidden; }
.hero-scroll-line span{ display:block; width:30%; height:100%; background:#fff; animation: scrollLine 2.2s infinite var(--ease-in-out); }
@keyframes scrollLine{ 0%{ transform: translateX(-100%); } 100%{ transform: translateX(330%); } }

.marquee{
  position:relative; margin: 60px -28px 0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  overflow:hidden;
  padding:18px 0;
  z-index:3;
  background: rgba(11,10,20,.4);
  backdrop-filter: blur(10px);
}
.marquee-track{
  display:flex; gap:36px;
  white-space:nowrap;
  animation: marquee 38s linear infinite;
  font-family:'Instrument Serif',serif; font-style:italic;
  font-size: clamp(20px, 3vw, 36px);
  color: rgba(255,255,255,.7);
}
.marquee-track span:nth-child(even){ color: var(--ink-mute); }
@keyframes marquee{ to{ transform: translateX(-50%); } }

/* =================== Sections =================== */
section{ position:relative; z-index:2; }
.section-head{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
  margin-bottom: 60px;
}
.section-tag{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.28em;
  color:var(--ink-mute); text-transform:uppercase;
  padding:7px 14px; border-radius:999px; border:1px solid var(--line);
  background: rgba(255,255,255,.02);
  margin-bottom:28px;
}
.section-tag .dot{ background: var(--violet); box-shadow: 0 0 10px var(--violet); }
.section-title{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size: clamp(40px, 6.5vw, 96px);
  letter-spacing:-0.03em;
  line-height: .98;
  margin:0;
  max-width: 1100px;
}
.section-title .reveal-word{
  display:inline-block;
  margin-right:.18em;
  will-change: transform,opacity;
}
body.has-anime .section-title .reveal-word{
  opacity:0; transform: translateY(60%);
}
.section-title .italic{
  font-family:'Instrument Serif',serif; font-style:italic; font-weight:400;
  background: var(--grad);
  background-clip:text; -webkit-background-clip:text;
  color: transparent;
}

/* =================== About =================== */
.about{
  padding: 140px 0 100px;
}
.about-grid{
  max-width: var(--container); margin: 0 auto; padding: 0 28px;
  display:grid; grid-template-columns: 1fr 1fr; gap:60px;
  margin-bottom: 80px;
}
.about-copy{
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.6;
  color: var(--ink-soft);
}
.stats{
  max-width: var(--container); margin: 0 auto; padding: 40px 28px;
  display:grid; grid-template-columns: repeat(4, 1fr); gap:0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.stat{
  padding: 24px 28px;
  border-right:1px solid var(--line);
}
.stat:last-child{ border-right:0; }
.stat-num{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500; font-size: clamp(40px, 5vw, 72px);
  letter-spacing:-0.02em; line-height:1;
  background: var(--grad);
  background-clip:text; -webkit-background-clip:text;
  color:transparent;
  margin-bottom:12px;
}
.stat-label{
  font-family:'Inter',sans-serif; font-size:12px; letter-spacing:.18em;
  color:var(--ink-mute); text-transform:uppercase;
}
@media (max-width: 900px){
  .about-grid{ grid-template-columns: 1fr; gap:24px; }
  .stats{ grid-template-columns: repeat(2,1fr); }
  .stat{ border-bottom:1px solid var(--line); }
  .stat:nth-child(even){ border-right:0; }
  .stat:nth-last-child(-n+2){ border-bottom:0; }
}

/* =================== Services =================== */
.services{ padding: 100px 0; }
.service-grid{
  max-width: var(--container); margin: 0 auto; padding: 0 28px;
  display:grid; grid-template-columns: repeat(3, 1fr); gap:18px;
}
.service-card{
  position:relative; overflow:hidden;
  padding: 34px 28px 30px;
  border-radius: var(--r-lg);
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.005));
  min-height: 280px;
  display:flex; flex-direction:column;
  transition: transform .55s var(--ease-out), border-color .35s, background .35s;
  will-change: transform;
}
.service-card::before{
  content:""; position:absolute; inset:-1px; border-radius: inherit;
  background: conic-gradient(from var(--a, 0deg), transparent 0 60%, rgba(138,92,255,.4) 75%, transparent 100%);
  opacity:0; transition: opacity .4s;
  pointer-events:none; z-index:0;
}
.service-card::after{
  content:""; position:absolute; inset:1px; border-radius: calc(var(--r-lg) - 1px);
  background: linear-gradient(180deg, rgba(11,10,20,.95), rgba(11,10,20,.95));
  z-index:0;
}
.service-card:hover{ transform: translateY(-4px); border-color: var(--line-2); }
.service-card:hover::before{ opacity:1; animation: rotateConic 4s linear infinite; }
@keyframes rotateConic{ to{ --a: 360deg; } }
@property --a{ syntax: '<angle>'; inherits: false; initial-value: 0deg; }

.service-card > *{ position:relative; z-index:1; }

.service-num{
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.28em;
  color: var(--violet); margin-bottom: 18px;
}
.service-title{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500; font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing:-0.01em; margin: 0 0 12px;
}
.service-desc{
  font-size:14px; line-height:1.55; color:var(--ink-soft); margin: 0 0 22px;
}
.service-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:auto; }
.service-tags span{
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.08em;
  padding: 5px 10px; border-radius: 999px;
  border:1px solid var(--line); color: var(--ink-soft);
}
.service-arrow{
  position:absolute; top: 28px; right: 28px;
  width: 36px; height: 36px; border-radius:50%;
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:#fff;
  transition: transform .4s var(--ease-out), background .3s, border-color .3s;
  z-index:1;
}
.service-card:hover .service-arrow{
  transform: rotate(45deg);
  background: var(--grad);
  border-color: transparent;
  color:#0a0815;
}
@media (max-width: 980px){ .service-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px){ .service-grid{ grid-template-columns: 1fr; } }

/* =================== Work / Rail =================== */
.work{ padding: 120px 0 100px; }
.work-rail-wrap{ position:relative; }
.work-rail{
  display:flex; gap:24px;
  padding: 0 28px 30px 28px;
  overflow-x:auto; overflow-y:hidden;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.work-rail::-webkit-scrollbar{ display:none; }

.work-card{
  flex: 0 0 min(78vw, 520px);
  scroll-snap-align: start;
  display:flex; flex-direction:column; gap:18px;
}
.work-thumb{
  position:relative;
  aspect-ratio: 4/3;
  border-radius: var(--r-lg);
  overflow:hidden;
  border:1px solid var(--line);
  background: linear-gradient(135deg, var(--c1, #2a1a4a), var(--c2, #0a0816));
  transition: transform .6s var(--ease-out);
}
.work-card:hover .work-thumb{ transform: translateY(-6px); }

.work-thumb-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.07) 1px,transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
.work-thumb-glow{
  position:absolute; width:60%; height:60%;
  top:20%; left:20%; border-radius:50%;
  background: radial-gradient(circle, var(--gc, #8a5cff) 0%, transparent 60%);
  filter: blur(40px); opacity:.6;
  transition: transform .8s var(--ease-out), opacity .4s;
}
.work-card:hover .work-thumb-glow{ transform: scale(1.2); opacity:.9; }

.work-thumb-mock{
  position:absolute;
  left: 8%; right: 8%; top: 18%; bottom: 8%;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(12px);
  padding: 14px;
  display:flex; flex-direction:column; gap:10px;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.6);
  transition: transform .8s var(--ease-out);
}
.work-thumb-mock--dark{ background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.2)); }
.work-card:hover .work-thumb-mock{ transform: translateY(-8px); }

.mock-bar{ display:flex; gap:6px; }
.mock-bar span{ width:8px; height:8px; border-radius:50%; background: rgba(255,255,255,.2); }
.mock-body{ display:flex; flex-direction:column; gap:10px; }
.mock-h{ height: 18px; width: 60%; background: rgba(255,255,255,.18); border-radius:6px; }
.mock-h--big{ height:28px; width:80%; }
.mock-p{ height: 6px; width: 90%; background: rgba(255,255,255,.08); border-radius:4px; }
.mock-p--short{ width: 60%; }
.mock-btn{ height:22px; width:90px; border-radius:6px; background: var(--grad); margin-top:6px; }
.mock-circle{ width:36px; height:36px; border-radius:50%; background: rgba(255,255,255,.16); }
.mock-row{ display:flex; gap:8px; }
.mock-row span{ flex:1; height:16px; border-radius:4px; background: rgba(255,255,255,.1); }
.mock-grid{ display:grid; grid-template-columns: repeat(2,1fr); gap:6px; margin-top:6px; }
.mock-grid span{ height:30px; border-radius:6px; background: rgba(255,255,255,.08); }
.mock-hero{ height:60%; min-height:80px; border-radius:8px; background: linear-gradient(120deg, rgba(255,255,255,.2), rgba(255,255,255,.05)); }
.mock-chart{ display:flex; align-items:flex-end; gap:6px; height:60%; }
.mock-chart span{ flex:1; background: linear-gradient(180deg, var(--cyan), var(--violet)); border-radius:3px; }
.mock-chart span:nth-child(1){ height:30%; }
.mock-chart span:nth-child(2){ height:55%; }
.mock-chart span:nth-child(3){ height:42%; }
.mock-chart span:nth-child(4){ height:78%; }
.mock-chart span:nth-child(5){ height:60%; }
.mock-chart span:nth-child(6){ height:90%; }
.mock-chart span:nth-child(7){ height:70%; }

.work-meta{ padding: 0 6px; }
.work-no{
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.28em;
  color: var(--ink-mute); margin-bottom: 8px;
}
.work-title{
  font-family:'Space Grotesk',sans-serif; font-weight:500; font-size: 24px;
  letter-spacing:-0.01em; margin: 0 0 4px;
}
.work-cat{ font-size: 13px; color: var(--ink-soft); margin:0; }

.rail-progress{
  max-width: var(--container); margin: 14px auto 0;
  padding: 0 28px;
  height: 2px; background: rgba(255,255,255,.06); border-radius:2px; overflow:hidden;
  position:relative;
}
.rail-progress span{
  display:block; height:100%; width:0%;
  background: var(--grad);
  box-shadow: 0 0 12px rgba(138,92,255,.6);
}
.rail-hint{
  max-width: var(--container); margin: 8px auto 0; padding: 0 28px;
  text-align:right;
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.24em;
  color: var(--ink-mute);
}

/* =================== Process / Timeline =================== */
.process{ padding: 100px 0 120px; }
.timeline{
  position:relative;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}
.timeline-line{
  position:absolute; left: 48px; top: 0; bottom: 0; width: 1px;
  background: rgba(255,255,255,.08);
}
.timeline-line span{
  display:block; width:100%; height:0%;
  background: var(--grad);
  box-shadow: 0 0 14px rgba(138,92,255,.7);
}
.timeline-step{
  display:flex; gap:36px; align-items:flex-start;
  padding: 32px 0;
  border-bottom: 1px solid var(--line);
}
body.has-anime .timeline-step{
  opacity:0; transform: translateY(40px);
}
.timeline-step:last-child{ border-bottom:0; }
.ts-num{
  position:relative; z-index:2;
  flex-shrink:0;
  width: 60px; height: 60px; border-radius:50%;
  border:1px solid var(--line);
  background: rgba(11,10,20,.9);
  display:flex; align-items:center; justify-content:center;
  font-family:'Inter',sans-serif; font-size:12px; letter-spacing:.18em;
  color: var(--ink-soft);
}
.ts-body h3{
  font-family:'Space Grotesk',sans-serif; font-weight:500;
  font-size: clamp(26px, 3vw, 42px);
  letter-spacing:-0.02em; margin: 0 0 10px;
}
.ts-body p{ font-size: 15px; line-height:1.55; color: var(--ink-soft); margin:0; max-width: 620px; }

@media (max-width:640px){
  .timeline-line{ left: 32px; }
  .ts-num{ width: 44px; height:44px; font-size:11px; }
  .timeline-step{ gap: 20px; }
}

/* =================== Testimonials =================== */
.testimonials{ padding: 100px 0; }
.testi-grid{
  max-width: var(--container); margin: 0 auto; padding: 0 28px;
  display:grid; grid-template-columns: repeat(3,1fr); gap:18px;
}
.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--line);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--r-lg);
}
.testi-card{
  padding: 30px 26px 26px;
  display:flex; flex-direction:column; gap:18px;
  position:relative; overflow:hidden;
  transition: transform .5s var(--ease-out), border-color .35s;
}
.testi-card:hover{ transform: translateY(-4px); border-color: var(--line-2); }
.quote-mark{
  font-family:'Instrument Serif',serif;
  font-size: 80px; line-height:.6;
  color: var(--violet);
  opacity:.5;
}
.testi-card p{
  font-size: 16px; line-height:1.55; color:#e9e9f3; margin:0;
}
.testi-meta{ display:flex; align-items:center; gap:14px; margin-top:auto; }
.avatar{
  width:42px; height:42px; border-radius:50%;
  background: linear-gradient(135deg, var(--a1), var(--a2));
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:600; letter-spacing:.08em;
}
.testi-name{ font-size:14px; font-weight:500; }
.testi-role{ font-size:12px; color: var(--ink-mute); }
@media (max-width:900px){ .testi-grid{ grid-template-columns: 1fr; } }

/* =================== Contact =================== */
.contact{
  padding: 120px 0;
  position:relative;
}
.contact::before{
  content:""; position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:60%; height:1px;
  background: linear-gradient(90deg, transparent, var(--line-2), transparent);
}
.contact-inner{
  max-width: var(--container); margin: 0 auto; padding: 0 28px;
  display:grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: start;
}
.contact-title{
  font-family:'Space Grotesk',sans-serif; font-weight:500;
  font-size: clamp(40px, 5.5vw, 80px); letter-spacing:-0.03em;
  line-height: .98; margin: 24px 0 24px;
}
.contact-title .reveal-word{
  display:inline-block; margin-right:.18em;
}
body.has-anime .contact-title .reveal-word{
  opacity:0; transform: translateY(60%);
}
.contact-title .italic{
  font-family:'Instrument Serif',serif; font-style:italic; font-weight:400;
  background: var(--grad); background-clip:text; -webkit-background-clip:text; color:transparent;
}
.contact-copy{
  font-size: 16px; line-height:1.55; color: var(--ink-soft); max-width: 480px;
  margin: 0 0 40px;
}
.contact-info{ display:flex; flex-direction:column; gap:18px; }
.contact-link{
  display:inline-flex; align-items:center;
  font-family:'Space Grotesk',sans-serif; font-size: clamp(22px, 2.4vw, 28px);
  font-weight:500;
  background: var(--grad); background-clip:text; -webkit-background-clip:text; color:transparent;
  width: max-content;
}
.contact-row{ display:flex; gap:10px; align-items:center; font-size:13px; color:var(--ink-mute); letter-spacing:.04em; text-transform:uppercase; font-family:'Inter',sans-serif; }
.contact-strong{ color:#fff; text-transform:none; font-family:'Space Grotesk',sans-serif; font-size:14px; letter-spacing:0; }

.contact-form{ padding: 36px 28px 30px; }
.field{ position:relative; padding-top: 24px; margin-bottom: 18px; }
.field label{
  position:absolute; top:24px; left:0;
  font-size:14px; color: var(--ink-soft);
  pointer-events:none;
  transition: transform .35s var(--ease-out), font-size .25s, color .25s;
}
.field input,
.field textarea,
.field select{
  width:100%;
  background: transparent;
  border:0; border-bottom:1px solid var(--line);
  padding: 12px 0;
  color:#fff;
  font-family:inherit; font-size:15px;
  resize:none;
  outline:none;
}
.field select{ appearance: none; }
.field select option{ background:#0b0a14; color:#fff; }
.field textarea{ min-height: 100px; }
.field-line{
  position:absolute; left:0; right:0; bottom:0;
  height:1px; transform: scaleX(0); transform-origin: left;
  background: var(--grad);
  transition: transform .5s var(--ease-out);
}
.field input:focus + .field-line,
.field textarea:focus + .field-line,
.field select:focus + .field-line{ transform: scaleX(1); }

.field:focus-within label,
.field.has-value label{
  transform: translateY(-26px);
  font-size: 11px; letter-spacing:.18em; color: var(--ink-mute); text-transform:uppercase;
}

.form-status{ margin-top:14px; font-size:13px; color: var(--green); min-height:18px; }

@media (max-width: 980px){
  .contact-inner{ grid-template-columns: 1fr; gap:40px; }
}

/* =================== Footer =================== */
.footer{
  position:relative; overflow:hidden;
  padding: 80px 28px 30px;
  border-top:1px solid var(--line);
  background: linear-gradient(180deg, transparent, rgba(138,92,255,.04));
}
.footer-grid{
  max-width: var(--container); margin: 0 auto;
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 50px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--line);
}
.footer-brand p{ color:var(--ink-soft); font-size:14px; line-height:1.55; margin-top:20px; max-width: 340px; }
.footer-logo{ display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:.18em; font-size:14px; }
.footer-col{ display:flex; flex-direction:column; gap:10px; }
.footer-col-title{
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.28em;
  color: var(--ink-mute); text-transform:uppercase; margin-bottom: 6px;
}
.footer-col a{ color:#dcdce6; font-size:14px; transition: color .2s; }
.footer-col a:hover{ color:#fff; }

.socials{ display:flex; gap:10px; flex-wrap:wrap; }
.social{
  width:42px; height:42px; border-radius:50%;
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  color:#fff;
  transition: border-color .25s, color .25s, box-shadow .35s, transform .35s;
}
.social:hover{
  border-color: transparent;
  box-shadow: 0 0 24px rgba(138,92,255,.6), inset 0 0 0 1px rgba(138,92,255,.7);
  color: #fff;
}

.footer-bottom{
  max-width: var(--container); margin: 24px auto 0;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-family:'Inter',sans-serif; font-size:12px; color: var(--ink-mute); letter-spacing:.06em;
}

.footer-mega{
  pointer-events:none;
  position:relative;
  margin-top: 40px;
  text-align:center;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size: clamp(80px, 22vw, 320px);
  line-height: .85;
  letter-spacing:-0.05em;
  background: linear-gradient(180deg, rgba(138,92,255,.4) 0%, rgba(0,224,255,.05) 100%);
  background-clip:text; -webkit-background-clip:text;
  color: transparent;
  user-select:none;
}

@media (max-width: 980px){
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:30px; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns: 1fr; }
}

/* =================== Utility =================== */
.split-reveal{ }
body.has-anime .split-reveal{ opacity:0; transform: translateY(20px); }
.is-revealed{ opacity:1; transform: translateY(0); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }

/* =====================================================
   3D + TILT + PER-CHAR (additions for upgrade)
   ===================================================== */

/* Hero video layers (VIDEO 1 / VIDEO 2) — behind WebGL canvas */
.hero-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  z-index:0;
  pointer-events:none;
  opacity:0;
  transition: opacity .6s var(--ease-out);
}
.hero-video.is-active{ opacity:.55; }
.hero-video--overlay.is-active{ opacity:.35; mix-blend-mode: screen; }
.hero.has-hero-video #hero3d{ opacity:.65; }

/* Hero WebGL canvas — sits behind hero copy, above bg overlays */
#hero3d{
  position:absolute; inset:0; width:100%; height:100%;
  z-index:1; pointer-events:none;
  display:block;
}
.hero > .hero-meta,
.hero > .hero-inner,
.hero > .marquee{ z-index:3; }

/* Work card — Fotoğraf / Video (proje kapakları) */
.work-media{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  z-index:2;
  pointer-events:none;
}

/* Per-letter split target. Each .line keeps overflow:hidden mask. */
.hero-title .line-inner{ transform: none; }
.hero-title .char{
  display:inline-block;
  vertical-align: baseline;
  will-change: transform, opacity;
}
body.has-anime .hero-title .char{
  transform: translateY(105%);
  opacity: 0;
}
.hero-title .char--space{
  width:.28em;
  white-space: pre;
}
.hero-title .line--accent{
  padding-bottom: 0.2em;
}

/* Tilt cards — wrap perspective on the article, rotate .card-inner */
.tilt{
  perspective: 1100px;
  transform-style: preserve-3d;
}
.service-card.tilt,
.testi-card.tilt{
  display:block; /* card-inner takes over flex */
}
.service-card.tilt .card-inner,
.testi-card.tilt .card-inner{
  position:relative; z-index:1;
  display:flex; flex-direction:column;
  min-height: 100%;
  transform-style: preserve-3d;
  will-change: transform;
  transition: transform .6s var(--ease-out);
}
.testi-card.tilt .card-inner{ gap:18px; min-height: 100%; }
/* card-inner contents — testi-card had this gap baked into card itself */
.service-card.tilt{ min-height: 280px; padding: 0; }
.service-card.tilt .card-inner{ padding: 34px 28px 30px; min-height: 280px; }
.testi-card.tilt{ padding: 0; }
.testi-card.tilt .card-inner{ padding: 30px 26px 26px; min-height: 100%; }

.work-card.tilt .work-thumb{
  transform-style: preserve-3d;
  will-change: transform;
}

/* Animated radial highlight following the cursor on tilt cards */
.card-shine{
  position:absolute; inset:0;
  pointer-events:none;
  border-radius: inherit;
  background: radial-gradient(
    320px circle at var(--mx, 50%) var(--my, 50%),
    rgba(255,255,255,.16),
    rgba(255,255,255,.05) 30%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity .35s var(--ease-out);
  z-index: 2;
  mix-blend-mode: screen;
}
.tilt:hover .card-shine{ opacity: 1; }
.work-card .card-shine{ border-radius: var(--r-lg); }

/* Work-card mini WebGL canvas */
.card3d{
  position:absolute; inset:0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 1;
  display:block;
  opacity: 0;
  transition: opacity .6s var(--ease-out);
}
.card3d.is-ready{ opacity: 1; }
/* Mobile: hide card mini-scenes (CPU/GPU heavy) */
@media (max-width: 720px){
  .card3d{ display:none; }
}

/* Tilt-card hover lift — supersedes simple translate hover for service/testi */
.service-card.tilt:hover .card-inner,
.testi-card.tilt:hover .card-inner{ transform: translateZ(20px); }

/* Footer mega text — scroll-driven horizontal drift */
.footer-mega{ will-change: transform; }

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
  .hero-title .line-inner{ transform: none; }
  .hero-title .char{ transform:none; opacity:1; }
  .hero-title .line-inner.italic .char{
    background: var(--grad);
    background-clip:text;
    -webkit-background-clip:text;
    color:transparent;
    -webkit-text-fill-color:transparent;
  }
  .section-title .reveal-word, .contact-title .reveal-word{ opacity:1; transform:none; }
  #hero3d, .card3d{ display:none; }
}

/* =====================================================
   WORK CARD — clickable affordance
   ===================================================== */
/* custom cursor handles hover state — only fallback when no custom cursor */
@media (hover:none){ .work-card{ cursor: pointer; } }
.work-open-hint{
  position:absolute; left:18px; bottom:16px; z-index:3;
  font-family:'Inter',sans-serif; font-size:10px; letter-spacing:.24em;
  color:#fff;
  padding: 7px 12px; border-radius: 999px;
  background: rgba(11,10,20,.55);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity:0; transform: translateY(6px);
  transition: opacity .35s var(--ease-out), transform .35s var(--ease-out), background .25s;
  pointer-events:none;
}
.work-card:hover .work-open-hint,
.work-card:focus-visible .work-open-hint{ opacity:1; transform: translateY(0); }
.work-card:focus-visible{ outline:none; }
.work-card:focus-visible .work-thumb{
  box-shadow: 0 0 0 2px var(--violet), 0 0 0 4px rgba(138,92,255,.25);
}

/* =====================================================
   PROJECT MODAL (browser-frame mini site)
   ===================================================== */
.project-modal{
  position: fixed; inset: 0; z-index: 200;
  display: flex;
  align-items: center; justify-content: center;
  padding: 32px;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity .35s var(--ease-out), visibility 0s linear .35s;
}
.project-modal.is-open{
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transition: opacity .35s var(--ease-out), visibility 0s linear 0s;
}

.pm-backdrop{
  position:absolute; inset:0;
  background: radial-gradient(ellipse at center, rgba(11,10,20,.85), rgba(4,3,9,.96));
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  opacity: 0;
  transition: opacity .45s var(--ease-out);
}
.project-modal.is-open .pm-backdrop{ opacity: 1; }

.pm-wrap{
  position:relative;
  width: min(1180px, 100%);
  height: min(86vh, 820px);
  display: flex; flex-direction: column;
  opacity: 0; transform: translateY(30px) scale(.97);
  transition: opacity .5s var(--ease-out), transform .5s var(--ease-out);
}
.project-modal.is-open .pm-wrap{ opacity: 1; transform: none; }

.pm-close{
  position:absolute; top: -46px; right: 0;
  width: 38px; height: 38px; border-radius:50%;
  border:1px solid var(--line-2);
  background: rgba(11,10,20,.7);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  transition: transform .3s, border-color .25s, background .25s;
  z-index: 3;
}
.pm-close:hover{ transform: rotate(90deg); border-color:#fff; background: rgba(138,92,255,.18); }

.pm-browser{
  position:relative;
  flex: 1; min-height: 0;
  display:flex; flex-direction:column;
  background: linear-gradient(180deg, #0e0c18, #07060d);
  border:1px solid var(--line-2);
  border-radius: 18px;
  overflow: hidden;
  box-shadow:
    0 40px 100px -20px rgba(0,0,0,.7),
    0 0 0 1px rgba(255,255,255,.04),
    0 0 80px -20px rgba(138,92,255,.4);
}

.pm-bar{
  flex-shrink: 0;
  display:flex; align-items:center; gap: 14px;
  padding: 12px 18px;
  background: linear-gradient(180deg, #15131f, #0e0c18);
  border-bottom: 1px solid var(--line);
}
.pm-dots{ display:flex; gap:6px; }
.pm-dots span{
  width: 11px; height: 11px; border-radius: 50%;
  background: #444050;
}
.pm-dots span:nth-child(1){ background: #ff5f57; }
.pm-dots span:nth-child(2){ background: #febc2e; }
.pm-dots span:nth-child(3){ background: #28c840; }
.pm-url{
  flex: 1;
  display:flex; align-items:center; justify-content:center; gap: 8px;
  font-family: 'Inter', sans-serif; font-size: 12px;
  color: var(--ink-soft);
  background: rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius: 8px;
  padding: 6px 14px;
  max-width: 480px; margin: 0 auto;
}
.pm-url svg{ opacity:.65; }
.pm-bar-end{
  min-width: 60px; text-align: right;
}
.pm-tab-meta{
  font-family:'Inter',sans-serif; font-size: 11px; letter-spacing: .14em;
  color: var(--ink-mute); text-transform: uppercase;
}

.pm-scroll{
  flex: 1; overflow-y: auto; overflow-x: hidden;
  scroll-behavior: smooth;
  position: relative;
  outline: none;
}
.pm-scroll::-webkit-scrollbar{ width: 10px; }
.pm-scroll::-webkit-scrollbar-track{ background: rgba(255,255,255,.02); }
.pm-scroll::-webkit-scrollbar-thumb{ background: rgba(138,92,255,.25); border-radius: 6px; border: 2px solid #07060d; }
.pm-scroll::-webkit-scrollbar-thumb:hover{ background: rgba(138,92,255,.5); }

.pm-scroll-hint{
  position:absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .26em;
  color:#fff;
  padding: 7px 14px; border-radius: 999px;
  background: rgba(11,10,20,.7);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  pointer-events: none;
  animation: pmBob 2.2s ease-in-out infinite;
  opacity:.95;
  z-index: 5;
}
.pm-scroll-hint.is-hidden{ opacity: 0; transition: opacity .35s; }
@keyframes pmBob{
  0%,100%{ transform: translate(-50%, 0); }
  50%{ transform: translate(-50%, 4px); }
}

@media (max-width: 720px){
  .project-modal{ padding: 14px; }
  .pm-wrap{ height: calc(100vh - 90px); }
  .pm-close{ top: -42px; right: 0; }
  .pm-bar{ padding: 10px 12px; gap: 10px; }
  .pm-url{ font-size: 11px; padding: 5px 10px; }
  .pm-tab-meta{ display:none; }
}

/* =====================================================
   MINI SITE (inside the browser frame)
   ===================================================== */
.ms{
  --ms-a: #8a5cff;
  --ms-b: #00e0ff;
  --ms-bg: #0a0814;
  --ms-bg-2: #110d22;
  --ms-ink: #efeef7;
  --ms-mute: #9b9bab;
  color: var(--ms-ink);
  background: var(--ms-bg);
  font-family:'Space Grotesk','Inter',sans-serif;
  min-height: 100%;
}
.ms-nav{
  position: sticky; top: 0; z-index: 5;
  display:flex; align-items:center; justify-content: space-between;
  padding: 16px 36px;
  background: rgba(10, 8, 20, .75);
  border-bottom: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.ms-logo{
  display:flex; align-items:center; gap: 10px;
  font-weight: 700; letter-spacing: .18em; font-size: 12px;
}
.ms-logo-mark{
  width: 22px; height: 22px; border-radius: 6px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
}
.ms-nav-links{
  display:flex; gap: 22px;
  font-size: 13px; color: var(--ms-mute);
}
.ms-nav-links a{ transition: color .2s; }
.ms-nav-links a:hover{ color: #fff; }
.ms-nav-cta{
  font-size: 12px; padding: 8px 14px; border-radius: 999px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  color: #0a0814; font-weight: 600;
}

.ms-hero{
  position:relative; overflow:hidden;
  padding: 80px 36px 70px;
  background: radial-gradient(ellipse at top left, color-mix(in srgb, var(--ms-a) 22%, transparent), transparent 60%),
              radial-gradient(ellipse at bottom right, color-mix(in srgb, var(--ms-b) 18%, transparent), transparent 60%),
              var(--ms-bg);
}
.ms-hero::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px,transparent 1px);
  background-size: 36px 36px;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 80%);
  opacity:.5; pointer-events:none;
}
.ms-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.24em;
  color: var(--ms-mute); text-transform:uppercase;
  padding: 6px 12px; border-radius: 999px;
  border:1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.02);
  margin-bottom: 24px;
  position: relative; z-index: 1;
}
.ms-eyebrow::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background: var(--ms-a); box-shadow: 0 0 10px var(--ms-a);
}
.ms-hero h1{
  position: relative; z-index: 1;
  margin: 0 0 22px;
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500;
  font-size: clamp(34px, 5vw, 64px);
  letter-spacing: -0.03em; line-height: 1;
  max-width: 760px;
}
.ms-hero h1 em{
  font-family:'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip: text; -webkit-background-clip: text;
  color: transparent;
}
.ms-hero p{
  position: relative; z-index: 1;
  margin: 0 0 30px;
  font-size: 16px; line-height: 1.55;
  color: var(--ms-mute);
  max-width: 540px;
}
.ms-hero-cta{
  position: relative; z-index: 1;
  display:flex; gap: 12px; flex-wrap: wrap;
}
.ms-btn{
  display:inline-flex; align-items:center; gap: 8px;
  padding: 12px 20px; border-radius: 999px;
  font-size: 13px; font-weight: 500;
  transition: transform .25s, box-shadow .35s, background .25s;
}
.ms-btn--primary{
  background: linear-gradient(135deg, #fff, #d8d6ff);
  color: #0a0814;
  box-shadow: 0 10px 30px -10px rgba(255,255,255,.3);
}
.ms-btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 14px 40px -10px rgba(138,92,255,.5); }
.ms-btn--ghost{
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  background: rgba(255,255,255,.03);
}
.ms-btn--ghost:hover{ background: rgba(255,255,255,.08); }

.ms-hero-visual{
  position:relative; z-index: 1;
  margin-top: 44px;
  height: 220px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(135deg, color-mix(in srgb, var(--ms-a) 30%, #0a0814), color-mix(in srgb, var(--ms-b) 22%, #0a0814));
}
.ms-hero-visual::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 30% 50%, rgba(255,255,255,.18), transparent 50%),
    radial-gradient(circle at 70% 50%, color-mix(in srgb, var(--ms-b) 60%, transparent), transparent 55%);
  mix-blend-mode: screen;
}
.ms-hero-visual-bars{
  position:absolute; inset:auto 30px 24px 30px;
  display:flex; align-items:flex-end; gap: 8px;
  height: 60%;
}
.ms-hero-visual-bars span{
  flex: 1; border-radius: 6px 6px 2px 2px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--ms-b) 80%, #fff), color-mix(in srgb, var(--ms-a) 75%, #fff));
  box-shadow: 0 6px 16px -6px color-mix(in srgb, var(--ms-a) 60%, transparent);
}

.ms-marquee{
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.015);
  overflow: hidden;
  white-space: nowrap;
}
.ms-marquee-track{
  display:inline-flex; gap: 28px;
  animation: msMarquee 22s linear infinite;
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: 18px; color: var(--ms-mute);
}
@keyframes msMarquee{ to{ transform: translateX(-50%); } }

.ms-section{ padding: 70px 36px; }
.ms-section--alt{ background: var(--ms-bg-2); }

.ms-section-head{ margin-bottom: 40px; max-width: 760px; }
.ms-section-tag{
  font-family:'Inter',sans-serif; font-size:11px; letter-spacing:.26em;
  color: var(--ms-mute); text-transform: uppercase;
  margin-bottom: 14px;
}
.ms-section h2{
  margin: 0;
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500;
  font-size: clamp(28px, 3.4vw, 46px);
  letter-spacing: -0.025em; line-height: 1.05;
}
.ms-section h2 em{
  font-family:'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip: text; -webkit-background-clip: text;
  color: transparent;
}

.ms-features{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-feature{
  padding: 24px 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  transition: transform .35s var(--ease-out), border-color .25s, background .25s;
}
.ms-feature:hover{ transform: translateY(-3px); border-color: rgba(255,255,255,.18); }
.ms-feature-icon{
  width: 36px; height: 36px; border-radius: 10px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  display:flex; align-items:center; justify-content:center;
  margin-bottom: 16px;
  font-size: 16px; color: #0a0814; font-weight: 700;
}
.ms-feature h3{
  margin: 0 0 8px;
  font-size: 17px; font-weight: 500;
}
.ms-feature p{
  margin: 0;
  font-size: 13.5px; line-height: 1.55; color: var(--ms-mute);
}

.ms-stats{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ms-stat{
  padding: 30px 22px;
  border-right: 1px solid rgba(255,255,255,.08);
}
.ms-stat:last-child{ border-right: 0; }
.ms-stat-n{
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500;
  font-size: clamp(28px, 3.4vw, 44px);
  letter-spacing: -0.02em;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip:text; -webkit-background-clip:text; color:transparent;
  margin-bottom: 8px;
}
.ms-stat-l{
  font-family:'Inter',sans-serif; font-size: 11px; letter-spacing: .18em;
  color: var(--ms-mute); text-transform: uppercase;
}

.ms-showcase{
  display:grid; grid-template-columns: 1fr 1fr; gap: 30px;
  align-items:center;
}
.ms-showcase-copy h3{
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500;
  font-size: clamp(22px, 2.6vw, 32px);
  letter-spacing: -0.02em; margin: 0 0 14px;
}
.ms-showcase-copy p{
  font-size: 14.5px; line-height: 1.6;
  color: var(--ms-mute); margin: 0 0 18px;
}
.ms-showcase-list{
  list-style: none; padding: 0; margin: 0;
  display:flex; flex-direction: column; gap: 10px;
}
.ms-showcase-list li{
  position: relative;
  padding-left: 22px;
  font-size: 14px; color: var(--ms-ink);
}
.ms-showcase-list li::before{
  content:""; position:absolute; left: 0; top: 7px;
  width: 12px; height: 12px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  box-shadow: 0 0 12px color-mix(in srgb, var(--ms-a) 50%, transparent);
}
.ms-showcase-art{
  aspect-ratio: 5/4;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.1);
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--ms-a) 60%, transparent), transparent 55%),
    radial-gradient(circle at 70% 70%, color-mix(in srgb, var(--ms-b) 50%, transparent), transparent 55%),
    #0e0c1c;
  position: relative; overflow: hidden;
}
.ms-showcase-art::before{
  content:""; position:absolute; inset: 14%;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.01));
  backdrop-filter: blur(6px);
}
.ms-showcase-art::after{
  content:""; position:absolute; inset: 24% 22% auto 22%;
  height: 40%; border-radius: 8px;
  background: repeating-linear-gradient(180deg, rgba(255,255,255,.18) 0 8px, transparent 8px 18px);
  opacity:.55;
}

.ms-quote{
  max-width: 720px;
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: clamp(20px, 2.4vw, 30px);
  line-height: 1.35;
  color: #fff;
  margin: 0 0 22px;
}
.ms-quote-author{
  display:flex; align-items:center; gap: 14px;
}
.ms-quote-avatar{
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  display:flex; align-items:center; justify-content:center;
  font-size: 14px; font-weight: 600; color: #0a0814;
}
.ms-quote-name{ font-size: 14px; }
.ms-quote-role{ font-size: 12px; color: var(--ms-mute); }

.ms-cta{
  padding: 80px 36px;
  text-align: center;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--ms-a) 18%, transparent), transparent 60%), var(--ms-bg);
  border-top: 1px solid rgba(255,255,255,.06);
}
.ms-cta h2{
  margin: 0 0 16px;
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500;
  font-size: clamp(28px, 3.8vw, 52px);
  letter-spacing: -0.025em;
}
.ms-cta p{
  margin: 0 auto 28px;
  font-size: 15px; color: var(--ms-mute);
  max-width: 480px;
}

.ms-footer{
  padding: 30px 36px;
  border-top: 1px solid rgba(255,255,255,.06);
  display:flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
  font-family: 'Inter', sans-serif; font-size: 12px;
  color: var(--ms-mute);
}
.ms-footer-links{ display:flex; gap: 18px; }
.ms-footer-links a{ transition: color .2s; }
.ms-footer-links a:hover{ color: #fff; }

@media (max-width: 720px){
  .ms-nav{ padding: 14px 20px; }
  .ms-nav-links{ display: none; }
  .ms-hero{ padding: 50px 20px 50px; }
  .ms-section{ padding: 50px 20px; }
  .ms-features{ grid-template-columns: 1fr; }
  .ms-stats{ grid-template-columns: repeat(2, 1fr); }
  .ms-stat:nth-child(even){ border-right: 0; }
  .ms-stat:nth-child(-n+2){ border-bottom: 1px solid rgba(255,255,255,.08); }
  .ms-showcase{ grid-template-columns: 1fr; gap: 22px; }
  .ms-cta{ padding: 60px 20px; }
  .ms-footer{ padding: 22px 20px; }
}

body.pm-open{ overflow: hidden; }

/* =====================================================
   MINI SITE — rich components per business type
   ===================================================== */

/* generic split hero */
.ms-hero--split{
  display:grid; grid-template-columns: 1fr 1.05fr; gap: 50px;
  align-items: center;
}
.ms-hero-text{ position:relative; z-index:1; }
.ms-hero-mock{ position:relative; z-index:1; }
@media (max-width: 820px){
  .ms-hero--split{ grid-template-columns: 1fr; gap: 36px; }
}

/* SaaS dashboard mock (Lumen, Vela) */
.ms-dashboard{
  border-radius: 14px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.1);
  background: linear-gradient(180deg, #15131f, #0c0a14);
  box-shadow: 0 30px 80px -30px rgba(138,92,255,.5);
}
.ms-dash-top{
  display:flex; gap: 4px; padding: 10px 12px;
  background: rgba(255,255,255,.02);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.ms-dash-tab{
  font-family:'Inter',sans-serif; font-size: 11px;
  padding: 6px 12px; border-radius: 6px;
  color: var(--ms-mute); letter-spacing: .04em;
}
.ms-dash-tab.is-active{
  background: rgba(255,255,255,.06); color: #fff;
}
.ms-dash-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 14px;
}
.ms-dash-card{
  padding: 14px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.06);
}
.ms-dash-card--wide{ grid-column: 1 / -1; }
.ms-dash-label{
  font-family:'Inter',sans-serif; font-size: 10px;
  letter-spacing: .18em; color: var(--ms-mute); text-transform: uppercase;
  margin-bottom: 8px;
}
.ms-dash-value{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.02em;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip:text; -webkit-background-clip:text; color:transparent;
  margin-bottom: 8px;
}
.ms-dash-delta{
  font-family:'Inter',sans-serif; font-size: 11px;
  color: var(--ms-b);
}
.ms-dash-delta.is-down{ color: #ff7c7c; }
.ms-dash-spark{
  display:flex; align-items: flex-end; gap: 3px;
  height: 36px; margin-top: 10px;
}
.ms-dash-spark span{
  flex: 1; border-radius: 2px 2px 0 0;
  background: linear-gradient(180deg, var(--ms-a), color-mix(in srgb, var(--ms-a) 40%, transparent));
}
.ms-dash-line{
  position: relative; height: 70px; margin-top: 8px;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--ms-a) 14%, transparent));
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
}
.ms-dash-line::before{
  content:""; position:absolute; left:0; right:0; bottom: 30%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--ms-b), var(--ms-a), transparent);
  filter: drop-shadow(0 0 6px color-mix(in srgb, var(--ms-a) 60%, transparent));
}
.ms-dash-rows{
  display:flex; flex-direction:column; gap: 8px; margin-top: 8px;
}
.ms-dash-row{
  display:flex; align-items: center; gap: 10px;
  font-family:'Inter',sans-serif; font-size: 11px;
  color: var(--ms-ink);
}
.ms-dash-row-bar{
  flex: 1; height: 6px; border-radius: 3px;
  background: rgba(255,255,255,.06); position: relative;
}
.ms-dash-row-bar::after{
  content:""; position: absolute; inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--ms-a), var(--ms-b));
  width: var(--w, 50%);
}
.ms-dash-row span:last-child{ color: var(--ms-mute); font-size: 10px; min-width: 36px; text-align:right; }

/* trusted-by logos grid */
.ms-logos{
  padding: 36px 36px;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.015);
}
.ms-logos-label{
  font-family:'Inter',sans-serif; font-size: 10px;
  letter-spacing: .26em; color: var(--ms-mute); text-transform: uppercase;
  text-align: center; margin-bottom: 18px;
}
.ms-logos-grid{
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px;
}
.ms-logos-grid span{
  font-family:'Space Grotesk',sans-serif;
  font-weight: 600; letter-spacing: .12em;
  font-size: 13px; text-align: center;
  color: var(--ms-mute);
  opacity:.85;
  transition: color .25s;
}
.ms-logos-grid span:hover{ color: #fff; }
@media (max-width: 720px){
  .ms-logos-grid{ grid-template-columns: repeat(3, 1fr); gap: 14px; }
}

/* code block */
.ms-code-block{
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  overflow: hidden;
  background: #0a0814;
}
.ms-code-bar{
  display:flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.ms-code-bar > span:not(.ms-code-file){
  width: 9px; height: 9px; border-radius: 50%;
  background: #444050;
}
.ms-code-bar > span:nth-child(1){ background: #ff5f57; }
.ms-code-bar > span:nth-child(2){ background: #febc2e; }
.ms-code-bar > span:nth-child(3){ background: #28c840; }
.ms-code-file{
  font-family: 'Inter', sans-serif; font-size: 11px;
  color: var(--ms-mute); margin-left: 8px;
}
.ms-code-block pre{
  margin: 0; padding: 22px;
  font-family: 'JetBrains Mono', 'Menlo', monospace;
  font-size: 13px; line-height: 1.6;
  color: #d8d6ff;
  white-space: pre;
  overflow-x: auto;
}
.ms-code-block .c-key{ color: #ff5ce0; }
.ms-code-block .c-fn{ color: var(--ms-b); }
.ms-code-block .c-str{ color: #7cffb0; }
.ms-code-block .c-com{ color: #6b6b7a; }

/* pricing */
.ms-pricing{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-price-card{
  position: relative;
  padding: 28px 24px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  display:flex; flex-direction: column;
}
.ms-price-card.is-popular{
  border-color: color-mix(in srgb, var(--ms-a) 50%, transparent);
  box-shadow: 0 30px 60px -30px color-mix(in srgb, var(--ms-a) 60%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--ms-a) 10%, transparent), rgba(255,255,255,.01));
}
.ms-price-card .ms-price-tag{
  position: absolute; top: -10px; left: 24px;
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .18em;
  padding: 4px 10px; border-radius: 999px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  color: #0a0814; font-weight: 600; text-transform: uppercase;
}
.ms-price-name{
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500; font-size: 16px;
  color: var(--ms-mute); margin-bottom: 12px;
}
.ms-price-amt{
  font-family:'Space Grotesk',sans-serif;
  font-weight: 500; font-size: 38px; letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.ms-price-amt small{
  font-size: 13px; font-weight: 400; color: var(--ms-mute);
  margin-left: 4px;
}
.ms-price-desc{
  font-size: 13px; color: var(--ms-mute); margin-bottom: 18px;
}
.ms-price-card ul{
  list-style: none; padding: 0; margin: 0 0 22px;
  display:flex; flex-direction: column; gap: 8px;
}
.ms-price-card li{
  position: relative;
  padding-left: 22px;
  font-size: 13px; color: var(--ms-ink);
}
.ms-price-card li::before{
  content:"✓"; position: absolute; left: 0; top: 0;
  width: 14px; height: 14px;
  font-size: 10px; line-height: 14px; text-align: center;
  color: var(--ms-a);
}
.ms-price-card .ms-btn{ margin-top: auto; justify-content: center; }
@media (max-width: 820px){ .ms-pricing{ grid-template-columns: 1fr; } }

/* integration grid */
.ms-integrations{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
.ms-int{
  padding: 18px 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  display:flex; align-items: center; gap: 10px;
  font-family: 'Space Grotesk', sans-serif; font-size: 13px; font-weight: 500;
  transition: border-color .25s, background .25s;
}
.ms-int:hover{ border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.06); }
.ms-int-dot{
  width: 28px; height: 28px; border-radius: 7px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  flex-shrink: 0;
}
@media (max-width: 720px){ .ms-integrations{ grid-template-columns: 1fr 1fr; } }

/* phone mockup (Orbit) */
.ms-phone{
  position: relative;
  width: 280px; max-width: 100%;
  aspect-ratio: 9 / 19;
  margin: 0 auto;
  border: 8px solid #1a1622;
  border-radius: 38px;
  background: linear-gradient(180deg, #14111c, #0a0814);
  overflow: hidden;
  box-shadow: 0 40px 100px -30px rgba(0,224,255,.4), 0 0 0 1px rgba(255,255,255,.05);
}
.ms-phone::before{
  content:""; position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  width: 80px; height: 18px;
  background: #0a0814; border-radius: 12px; z-index: 2;
}
.ms-phone-screen{
  position: relative;
  padding: 38px 16px 16px;
  height: 100%;
  display:flex; flex-direction: column; gap: 12px;
}
.ms-phone-greet{
  font-family:'Space Grotesk',sans-serif;
  font-size: 13px; color: var(--ms-mute);
}
.ms-phone-balance{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 28px; letter-spacing: -0.02em;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip:text; -webkit-background-clip:text; color:transparent;
}
.ms-phone-balance-label{
  font-family:'Inter',sans-serif; font-size: 9px;
  letter-spacing: .18em; color: var(--ms-mute); text-transform: uppercase;
  margin-bottom: 2px;
}
.ms-phone-card{
  margin-top: 4px;
  aspect-ratio: 16 / 10;
  border-radius: 12px;
  padding: 14px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  display:flex; flex-direction: column; justify-content: space-between;
  color: #0a0814;
  position: relative; overflow: hidden;
  box-shadow: 0 16px 36px -10px color-mix(in srgb, var(--ms-a) 60%, transparent);
}
.ms-phone-card::after{
  content:""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 30%, rgba(255,255,255,.35), transparent 50%);
  pointer-events: none;
}
.ms-phone-card-brand{
  font-family:'Space Grotesk',sans-serif; font-weight: 700;
  font-size: 11px; letter-spacing: .2em;
}
.ms-phone-card-num{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 13px; letter-spacing: .14em;
}
.ms-phone-actions{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px;
  margin-top: 6px;
}
.ms-phone-action{
  text-align: center;
  padding: 8px 4px;
  border-radius: 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
  font-family:'Inter',sans-serif; font-size: 9px;
  color: var(--ms-ink);
}
.ms-phone-action-icon{
  width: 22px; height: 22px; border-radius: 7px;
  margin: 0 auto 4px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
}
.ms-phone-tx{
  margin-top: 4px;
  display:flex; flex-direction: column; gap: 6px;
}
.ms-phone-tx-row{
  display:flex; justify-content: space-between;
  font-family:'Inter',sans-serif; font-size: 10px;
}
.ms-phone-tx-row span:first-child{ color: var(--ms-ink); }
.ms-phone-tx-row span:last-child{ color: var(--ms-b); }

/* card showcase grid (Orbit cards section) */
.ms-cards-row{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-mini-card{
  aspect-ratio: 16 / 10;
  border-radius: 14px;
  padding: 16px;
  display:flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden;
  color: #0a0814;
  box-shadow: 0 20px 50px -20px rgba(0,0,0,.6);
}
.ms-mini-card--violet{ background: linear-gradient(135deg, #8a5cff, #6b3df5); color: #fff; }
.ms-mini-card--cyan{ background: linear-gradient(135deg, #00e0ff, #7cffb0); }
.ms-mini-card--dark{ background: linear-gradient(135deg, #1a1622, #050309); color: #fff; border: 1px solid rgba(255,255,255,.08); }
.ms-mini-card::after{
  content:""; position:absolute; inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(255,255,255,.25), transparent 50%);
}
.ms-mini-card-name{
  font-family:'Space Grotesk',sans-serif; font-weight: 600;
  font-size: 11px; letter-spacing: .22em;
}
.ms-mini-card-num{
  font-family:'Space Grotesk',sans-serif;
  font-size: 14px; letter-spacing: .14em;
}
.ms-mini-card-row{ display:flex; justify-content: space-between; align-items: flex-end; }
.ms-mini-card-row > div{ font-family:'Inter',sans-serif; font-size: 9px; text-transform: uppercase; letter-spacing: .14em; opacity:.8; }
@media (max-width: 720px){ .ms-cards-row{ grid-template-columns: 1fr; } }

/* security/badges row */
.ms-badges{
  display:flex; flex-wrap: wrap; gap: 10px;
}
.ms-badge{
  display:inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.02);
  font-family:'Inter',sans-serif; font-size: 12px;
  color: var(--ms-ink);
}
.ms-badge::before{
  content:""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--ms-b); box-shadow: 0 0 8px var(--ms-b);
}

/* Nova - portfolio grid */
.ms-portfolio{
  display:grid; grid-template-columns: 2fr 1fr; gap: 16px;
  grid-auto-rows: 200px;
}
.ms-portfolio > *:nth-child(1){ grid-row: span 2; }
.ms-portfolio-item{
  position: relative; overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(135deg, color-mix(in srgb, var(--p, var(--ms-a)) 35%, #0a0814), color-mix(in srgb, var(--p, var(--ms-a)) 12%, #0a0814));
  padding: 22px;
  display:flex; flex-direction: column; justify-content: flex-end;
  transition: transform .4s var(--ease-out);
  color: #fff;
}
.ms-portfolio-item:hover{ transform: translateY(-4px); }
.ms-portfolio-item::after{
  content:""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px,transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at 60% 30%, #000 30%, transparent 80%);
  pointer-events: none;
}
.ms-portfolio-tag{
  position: relative; z-index: 1;
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(255,255,255,.7);
  margin-bottom: 8px;
}
.ms-portfolio-title{
  position: relative; z-index: 1;
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: 28px; line-height: 1.05;
}
@media (max-width: 720px){
  .ms-portfolio{ grid-template-columns: 1fr; }
  .ms-portfolio > *:nth-child(1){ grid-row: auto; }
}

/* Awards row */
.ms-awards{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.ms-award{
  padding: 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.ms-award-year{
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: 26px;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip:text; -webkit-background-clip:text; color:transparent;
  margin-bottom: 6px;
}
.ms-award-name{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 15px;
  margin-bottom: 4px;
}
.ms-award-desc{
  font-size: 12px; color: var(--ms-mute);
}
@media (max-width: 720px){ .ms-awards{ grid-template-columns: 1fr; } }

/* E-commerce product grid (Aoki) */
.ms-products{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
}
.ms-product{
  display:flex; flex-direction: column; gap: 10px;
}
.ms-product-img{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 12px; overflow: hidden;
  background: linear-gradient(135deg, color-mix(in srgb, var(--ms-a) 25%, #1a1420), color-mix(in srgb, var(--ms-b) 18%, #100a14));
  border: 1px solid rgba(255,255,255,.06);
}
.ms-product-img::after{
  content:""; position: absolute; inset: 18% 14%;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.01));
}
.ms-product-img-tag{
  position: absolute; top: 10px; left: 10px;
  font-family:'Inter',sans-serif; font-size: 9px; letter-spacing: .22em;
  padding: 3px 8px; border-radius: 999px;
  background: rgba(11,10,20,.7); color: #fff;
  z-index: 1; text-transform: uppercase;
}
.ms-product-name{
  font-family:'Space Grotesk',sans-serif; font-size: 14px; font-weight: 500;
}
.ms-product-meta{
  display:flex; justify-content: space-between; align-items: center;
  font-family:'Inter',sans-serif; font-size: 12px; color: var(--ms-mute);
}
.ms-product-price{
  color: #fff; font-weight: 500;
}
@media (max-width: 720px){ .ms-products{ grid-template-columns: 1fr 1fr; } }

/* editorial split */
.ms-editorial{
  display:grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center;
}
.ms-editorial-img{
  aspect-ratio: 4 / 5;
  border-radius: 14px;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--ms-a) 60%, transparent), transparent 55%),
    radial-gradient(circle at 70% 70%, color-mix(in srgb, var(--ms-b) 50%, transparent), transparent 55%),
    #110a17;
  border: 1px solid rgba(255,255,255,.08);
  position: relative; overflow: hidden;
}
.ms-editorial-img::after{
  content:""; position:absolute; inset: 16%;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 10px;
}
.ms-editorial h3{
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: clamp(28px, 3.4vw, 42px); line-height: 1.05;
  margin: 0 0 16px;
}
.ms-editorial p{
  font-size: 15px; line-height: 1.7; color: var(--ms-ink);
  margin: 0 0 16px;
}
.ms-editorial .ms-byline{
  font-family:'Inter',sans-serif; font-size: 11px; letter-spacing: .22em;
  color: var(--ms-mute); text-transform: uppercase;
  margin-bottom: 18px;
}
@media (max-width: 720px){ .ms-editorial{ grid-template-columns: 1fr; gap: 24px; } }

/* press strip */
.ms-press{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 24px 0;
}
.ms-press > div{
  text-align: center;
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: 14px; color: var(--ms-mute);
}
.ms-press strong{
  display:block;
  font-family:'Space Grotesk',sans-serif; font-style: normal;
  font-weight: 600; letter-spacing: .14em; font-size: 13px; color: #fff;
  margin-bottom: 4px;
}
@media (max-width: 720px){ .ms-press{ grid-template-columns: 1fr 1fr; } }

/* Health - doctor cards / service cards */
.ms-doctors{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-doctor{
  padding: 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  text-align: center;
}
.ms-doctor-avatar{
  width: 80px; height: 80px; border-radius: 50%;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  margin: 0 auto 14px;
  display:flex; align-items: center; justify-content: center;
  font-family:'Space Grotesk',sans-serif; font-size: 24px; font-weight: 600;
  color: #0a0814;
}
.ms-doctor-name{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 16px; margin-bottom: 4px;
}
.ms-doctor-role{
  font-size: 12px; color: var(--ms-mute); margin-bottom: 10px;
}
.ms-doctor-tags{
  display:flex; flex-wrap: wrap; gap: 4px; justify-content: center;
}
.ms-doctor-tags span{
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .08em;
  padding: 3px 8px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  color: var(--ms-mute);
}
@media (max-width: 720px){ .ms-doctors{ grid-template-columns: 1fr; } }

/* steps (1-2-3 process for Helios) */
.ms-steps{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
.ms-step{
  padding: 22px 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  position: relative;
}
.ms-step-n{
  width: 32px; height: 32px; border-radius: 50%;
  display:flex; align-items: center; justify-content: center;
  font-family:'Space Grotesk',sans-serif; font-weight: 500; font-size: 13px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  color: #0a0814;
  margin-bottom: 14px;
}
.ms-step h4{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 15px; margin: 0 0 6px;
}
.ms-step p{
  font-size: 12.5px; line-height: 1.5; color: var(--ms-mute); margin: 0;
}
@media (max-width: 720px){ .ms-steps{ grid-template-columns: 1fr; } }

/* service / test plans (Helios) */
.ms-plans{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.ms-plan{
  padding: 24px 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  display:flex; flex-direction: column;
}
.ms-plan-cat{
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .22em;
  color: var(--ms-a); text-transform: uppercase;
  margin-bottom: 8px;
}
.ms-plan-name{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.01em; margin-bottom: 8px;
}
.ms-plan-desc{
  font-size: 13px; color: var(--ms-mute); margin-bottom: 16px;
}
.ms-plan-price{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 26px; letter-spacing: -0.02em;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip:text; -webkit-background-clip:text; color:transparent;
  margin-bottom: 16px;
}
.ms-plan-bm{
  display:flex; flex-direction: column; gap: 6px;
  margin-bottom: 18px;
}
.ms-plan-bm span{
  font-size: 12.5px; color: var(--ms-ink);
  padding-left: 16px; position: relative;
}
.ms-plan-bm span::before{
  content: "·"; position: absolute; left: 4px; top: -2px;
  color: var(--ms-a); font-size: 18px;
}
.ms-plan .ms-btn{ margin-top: auto; justify-content: center; }
@media (max-width: 720px){ .ms-plans{ grid-template-columns: 1fr; } }

/* FAQ accordion-ish */
.ms-faq{
  display:flex; flex-direction: column;
  border-top: 1px solid rgba(255,255,255,.08);
}
.ms-faq-item{
  padding: 22px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ms-faq-item summary{
  display:flex; justify-content: space-between; align-items: center;
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 16px; cursor: pointer; list-style: none;
}
.ms-faq-item summary::-webkit-details-marker{ display:none; }
.ms-faq-item summary::after{
  content: "+";
  font-family:'Space Grotesk',sans-serif; font-weight: 300;
  font-size: 22px; color: var(--ms-a);
  transition: transform .25s;
}
.ms-faq-item[open] summary::after{ content: "−"; }
.ms-faq-item p{
  margin: 12px 0 0;
  font-size: 14px; line-height: 1.6;
  color: var(--ms-mute); max-width: 720px;
}

/* B2B use cases (Vela) */
.ms-usecases{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-uc{
  padding: 26px 22px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
}
.ms-uc-icon{
  width: 38px; height: 38px; border-radius: 10px;
  background: linear-gradient(135deg, var(--ms-a), var(--ms-b));
  display:flex; align-items: center; justify-content: center;
  font-family:'Space Grotesk',sans-serif; font-weight: 600; color: #0a0814;
  margin-bottom: 16px;
}
.ms-uc h4{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 17px; margin: 0 0 8px;
}
.ms-uc p{
  font-size: 13px; line-height: 1.55; color: var(--ms-mute); margin: 0 0 14px;
}
.ms-uc-stat{
  display:flex; align-items: baseline; gap: 8px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.ms-uc-stat-n{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 22px;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip:text; -webkit-background-clip:text; color:transparent;
}
.ms-uc-stat-l{
  font-family:'Inter',sans-serif; font-size: 11px; color: var(--ms-mute);
}
@media (max-width: 720px){ .ms-usecases{ grid-template-columns: 1fr; } }

/* compare table (Vela vs ERP) */
.ms-compare{
  width: 100%;
  border-collapse: collapse;
  font-family:'Space Grotesk',sans-serif;
}
.ms-compare th, .ms-compare td{
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-size: 14px;
}
.ms-compare th{
  font-family:'Inter',sans-serif; font-weight: 500;
  font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ms-mute);
}
.ms-compare td:first-child{ color: var(--ms-ink); }
.ms-compare .ms-yes{ color: var(--ms-b); }
.ms-compare .ms-no{ color: #ff7c7c; opacity: .6; }
.ms-compare-cta{
  background: linear-gradient(135deg, color-mix(in srgb, var(--ms-a) 12%, transparent), transparent);
}

/* ============================================================
   PHOTO SUPPORT — real images inside mini-sites
   ============================================================ */

/* Product photo (Aoki) */
.ms-product-img.has-photo{ background: #0b0a14; }
.ms-product-img.has-photo::after{ display: none; }
.ms-product-img.has-photo > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .8s var(--ease-out, ease);
}
.ms-product:hover .ms-product-img.has-photo > img{ transform: scale(1.04); }

/* Editorial photo (Aoki) */
.ms-editorial-img.has-photo{ background: #0b0a14; }
.ms-editorial-img.has-photo::after{ display: none; }
.ms-editorial-img.has-photo > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}

/* Portfolio photo (Nova) */
.ms-portfolio-item.has-photo{
  padding: 18px;
  background: #0b0a14;
}
.ms-portfolio-item.has-photo::after{ display: none; }
.ms-portfolio-item .ms-portfolio-photo{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  z-index: 0;
  transition: transform .8s var(--ease-out, ease);
}
.ms-portfolio-item.has-photo::before{
  content:""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(8,6,16,0) 35%, rgba(8,6,16,.85) 100%);
  pointer-events: none;
}
.ms-portfolio-item.has-photo:hover .ms-portfolio-photo{ transform: scale(1.05); }
.ms-portfolio-item.has-photo .ms-portfolio-tag,
.ms-portfolio-item.has-photo .ms-portfolio-title{ z-index: 2; }

/* Aoki hero photo banner */
.ms-hero--photo .ms-hero-photo{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 6;
  border-radius: 18px;
  overflow: hidden;
  margin-bottom: 36px;
  background: #0b0a14;
  border: 1px solid rgba(255,255,255,.06);
}
.ms-hero--photo .ms-hero-photo > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.ms-hero--photo .ms-hero-photo::after{
  content:""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(8,6,16,.15) 0%, rgba(8,6,16,.55) 100%),
    radial-gradient(ellipse at 70% 40%, color-mix(in srgb, var(--ms-a) 18%, transparent), transparent 60%);
  pointer-events: none;
}
@media (max-width: 720px){
  .ms-hero--photo .ms-hero-photo{ aspect-ratio: 4 / 5; margin-bottom: 24px; }
}

/* =====================================================
   HYBRID LIGHT THEME — soften the cinematic dark
   About / Services / Process / Testimonials switch to
   warm off-white so the site doesn't feel only-futuristic.
   ===================================================== */

:root{
  --paper:        #f4f1ea;
  --paper-2:      #ebe6dc;
  --paper-ink:    #14121c;
  --paper-soft:   #45424f;
  --paper-mute:   #6f6b78;
  --paper-line:   rgba(20,18,28,0.10);
  --paper-line-2: rgba(20,18,28,0.18);
}

.about, .services, .testimonials{
  background: var(--paper);
  color: var(--paper-ink);
  position: relative;
  z-index: 4;
}
.process{
  background: var(--paper-2);
  color: var(--paper-ink);
  position: relative;
  z-index: 4;
}

/* soft seam between dark and light segments */
.about::after,
.process::after{
  content:""; position:absolute; left:0; right:0; top:0;
  height: 80px; pointer-events:none;
  background: linear-gradient(180deg, rgba(7,6,13,0.45), transparent);
  z-index: 1;
}
.about > *,
.process > *,
.services > *,
.testimonials > *{ position: relative; z-index: 2; }

/* section heads + copy on light bg */
.about .section-tag,
.services .section-tag,
.process .section-tag,
.testimonials .section-tag{
  color: var(--paper-mute);
  border-color: var(--paper-line);
  background: rgba(255,255,255,0.6);
}
.about .section-tag .dot,
.services .section-tag .dot,
.process .section-tag .dot,
.testimonials .section-tag .dot{
  background: var(--violet);
  box-shadow: 0 0 10px rgba(138,92,255,.55);
}
.about .section-title,
.services .section-title,
.process .section-title,
.testimonials .section-title{
  color: var(--paper-ink);
}
.about .section-title .italic,
.services .section-title .italic,
.process .section-title .italic,
.testimonials .section-title .italic{
  background: linear-gradient(120deg, #6b3df5 0%, #0098b3 100%);
  background-clip: text; -webkit-background-clip: text; color: transparent;
}

/* ABOUT */
.about-copy{ color: var(--paper-soft); }
.stats{
  border-top: 1px solid var(--paper-line);
  border-bottom: 1px solid var(--paper-line);
}
.stat{ border-right: 1px solid var(--paper-line); }
.stat-num{
  background: linear-gradient(120deg, #6b3df5 0%, #0098b3 100%);
  background-clip:text; -webkit-background-clip:text; color: transparent;
}
.stat-label{ color: var(--paper-mute); }
@media (max-width: 900px){
  .about .stat{ border-bottom: 1px solid var(--paper-line); }
}

/* SERVICES — paper cards on cream */
.service-card{
  background: linear-gradient(180deg, #ffffff 0%, #faf7f1 100%);
  border: 1px solid var(--paper-line);
  box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 20px 40px -28px rgba(20,18,28,0.12);
}
.service-card::after{
  background: linear-gradient(180deg, #ffffff 0%, #faf7f1 100%);
}
.service-card:hover{ border-color: var(--paper-line-2); }
.service-num{ color: var(--violet-2); }
.service-title{ color: var(--paper-ink); }
.service-desc{ color: var(--paper-soft); }
.service-tags span{
  border-color: var(--paper-line);
  color: var(--paper-soft);
  background: rgba(255,255,255,0.6);
}
.service-arrow{
  border: 1px solid var(--paper-line);
  color: var(--paper-ink);
  background: rgba(255,255,255,0.6);
}
.service-card .card-shine{
  background: radial-gradient(
    320px circle at var(--mx, 50%) var(--my, 50%),
    rgba(138,92,255,.18),
    rgba(138,92,255,.05) 30%,
    transparent 60%
  );
  mix-blend-mode: multiply;
}

/* PROCESS — light timeline */
.timeline-line{ background: var(--paper-line); }
.ts-num{
  background: #ffffff;
  border: 1px solid var(--paper-line);
  color: var(--paper-soft);
  box-shadow: 0 6px 14px -8px rgba(20,18,28,0.18);
}
.ts-body h3{ color: var(--paper-ink); }
.ts-body p{ color: var(--paper-soft); }
.timeline-step{ border-bottom: 1px solid var(--paper-line); }

/* TESTIMONIALS — paper glass cards */
.testimonials .testi-card.glass,
.testimonials .glass{
  background: linear-gradient(180deg, #ffffff 0%, #faf7f1 100%);
  border: 1px solid var(--paper-line);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 24px 50px -30px rgba(20,18,28,0.18);
}
.testimonials .testi-card:hover{ border-color: var(--paper-line-2); }
.testimonials .testi-card p{ color: var(--paper-ink); }
.testimonials .quote-mark{ color: var(--violet-2); opacity: .6; }
.testimonials .testi-name{ color: var(--paper-ink); }
.testimonials .testi-role{ color: var(--paper-mute); }
.testimonials .card-shine{
  background: radial-gradient(
    320px circle at var(--mx, 50%) var(--my, 50%),
    rgba(138,92,255,.18),
    rgba(138,92,255,.05) 30%,
    transparent 60%
  );
  mix-blend-mode: multiply;
}

/* hide bg overlays inside light sections so they don't darken paper */
.about, .services, .process, .testimonials{
  isolation: isolate;
}

@media (max-width: 900px){
  .about::after, .process::after{ height: 50px; }
}

/* Doctor photos (Helios) */
.ms-doctor-avatar.has-photo{
  position: relative;
  overflow: hidden;
  background: #0b0a14;
}
.ms-doctor-avatar.has-photo > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}

/* =====================================================
   MINI-SITE PHOTO PATTERNS — extra visual treatments
   Pattern A: ms-photo-band  — cinematic ultra-wide band
   Pattern B: ms-photo-split — side-by-side photo + copy
   Pattern C: ms-photo-cases — photo grid with hover lift
   Pattern D: ms-photo-feature — feature card with photo header
   ===================================================== */

/* Pattern A — cinematic ultra-wide band */
.ms-photo-band{
  position: relative;
  margin: 0 36px 70px;
  border-radius: 18px;
  overflow: hidden;
  aspect-ratio: 16 / 5;
  border: 1px solid rgba(255,255,255,.08);
  background: #0a0814;
  box-shadow: 0 30px 80px -30px rgba(138,92,255,.4);
}
.ms-photo-band > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 1.2s var(--ease-out);
  filter: saturate(.85) contrast(1.05);
}
.ms-photo-band:hover > img{ transform: scale(1.04); }
.ms-photo-band::after{
  content:""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,8,20,.0) 30%, rgba(10,8,20,.85) 100%),
    linear-gradient(120deg, color-mix(in srgb, var(--ms-a) 35%, transparent), transparent 55%);
  pointer-events: none;
}
.ms-photo-band-caption{
  position: absolute; left: 36px; right: 36px; bottom: 28px;
  z-index: 2; display:flex; align-items: flex-end; justify-content: space-between;
  gap: 20px; color: #fff;
}
.ms-photo-band-caption h3{
  font-family:'Instrument Serif',serif; font-style: italic; font-weight: 400;
  font-size: clamp(24px, 3vw, 38px); line-height: 1.05;
  margin: 0; max-width: 60%;
  text-shadow: 0 4px 24px rgba(0,0,0,.4);
}
.ms-photo-band-meta{
  font-family:'Inter',sans-serif; font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; opacity: .8; text-align: right;
}
@media (max-width: 720px){
  .ms-photo-band{ margin: 0 20px 50px; aspect-ratio: 4/3; }
  .ms-photo-band-caption{ left: 20px; right: 20px; bottom: 18px; flex-direction: column; align-items: flex-start; }
  .ms-photo-band-caption h3{ max-width: 100%; }
}

/* Pattern B — split: photo card + copy */
.ms-photo-split{
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 36px; align-items: center;
}
.ms-photo-split--reverse{ grid-template-columns: 1fr 1.1fr; }
.ms-photo-split--reverse .ms-photo-split-img{ order: 2; }
.ms-photo-split--reverse .ms-photo-split-copy{ order: 1; }
.ms-photo-split-img{
  position: relative;
  aspect-ratio: 4/5;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: #0a0814;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.6);
}
.ms-photo-split-img > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 1s var(--ease-out);
}
.ms-photo-split-img:hover > img{ transform: scale(1.05); }
.ms-photo-split-img::after{
  content:""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 80%, color-mix(in srgb, var(--ms-a) 25%, transparent), transparent 55%),
    linear-gradient(180deg, rgba(10,8,20,0) 60%, rgba(10,8,20,.35) 100%);
  pointer-events: none;
}
.ms-photo-split-badge{
  position: absolute; top: 16px; left: 16px; z-index: 2;
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .26em;
  text-transform: uppercase;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(10,8,20,.65);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.ms-photo-split-copy h3{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: clamp(22px, 2.8vw, 36px);
  letter-spacing: -0.02em; line-height: 1.05;
  margin: 0 0 14px;
}
.ms-photo-split-copy h3 em{
  font-family:'Instrument Serif', serif; font-style: italic; font-weight: 400;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip: text; -webkit-background-clip: text; color: transparent;
}
.ms-photo-split-copy p{
  font-size: 14.5px; line-height: 1.65; color: var(--ms-mute);
  margin: 0 0 20px;
}
.ms-photo-split-stats{
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  padding-top: 18px; border-top: 1px solid rgba(255,255,255,.08);
}
.ms-photo-split-stats div{ font-family:'Inter',sans-serif; }
.ms-photo-split-stats strong{
  display: block; font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.01em;
  background: linear-gradient(120deg, var(--ms-a), var(--ms-b));
  background-clip: text; -webkit-background-clip: text; color: transparent;
  margin-bottom: 2px;
}
.ms-photo-split-stats span{
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ms-mute);
}
@media (max-width: 820px){
  .ms-photo-split, .ms-photo-split--reverse{ grid-template-columns: 1fr; gap: 24px; }
  .ms-photo-split-img{ aspect-ratio: 5/4; }
  .ms-photo-split--reverse .ms-photo-split-img{ order: initial; }
  .ms-photo-split--reverse .ms-photo-split-copy{ order: initial; }
}

/* Pattern C — photo cards with hover */
.ms-photo-cases{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-photo-case{
  position: relative; overflow: hidden;
  aspect-ratio: 4/5;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: #0a0814;
  transition: transform .5s var(--ease-out);
}
.ms-photo-case:hover{ transform: translateY(-6px); }
.ms-photo-case > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 1s var(--ease-out), filter .4s;
  filter: saturate(.9);
}
.ms-photo-case:hover > img{ transform: scale(1.06); filter: saturate(1); }
.ms-photo-case::after{
  content:""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,8,20,0) 35%, rgba(10,8,20,.9) 100%);
  pointer-events: none;
}
.ms-photo-case-caption{
  position: absolute; left: 18px; right: 18px; bottom: 18px; z-index: 2;
  color: #fff;
}
.ms-photo-case-tag{
  font-family:'Inter',sans-serif; font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  margin-bottom: 6px;
}
.ms-photo-case-title{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 17px; line-height: 1.2;
  letter-spacing: -0.01em;
}
.ms-photo-case-num{
  position: absolute; top: 14px; right: 16px; z-index: 2;
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: 30px;
  color: rgba(255,255,255,.85);
  text-shadow: 0 4px 18px rgba(0,0,0,.5);
}
@media (max-width: 720px){
  .ms-photo-cases{ grid-template-columns: 1fr; }
}

/* Pattern D — feature triptych with photo headers */
.ms-photo-feature-grid{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ms-photo-feature{
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  display: flex; flex-direction: column;
  transition: transform .35s var(--ease-out), border-color .25s;
}
.ms-photo-feature:hover{ transform: translateY(-4px); border-color: rgba(255,255,255,.2); }
.ms-photo-feature-img{
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #0a0814;
}
.ms-photo-feature-img > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .8s var(--ease-out);
  filter: saturate(.9) contrast(1.02);
}
.ms-photo-feature:hover .ms-photo-feature-img > img{ transform: scale(1.05); }
.ms-photo-feature-img::after{
  content:""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(10,8,20,.6) 100%);
}
.ms-photo-feature-body{
  padding: 20px 22px 24px;
}
.ms-photo-feature-body h4{
  font-family:'Space Grotesk',sans-serif; font-weight: 500;
  font-size: 16px; margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.ms-photo-feature-body p{
  font-size: 13px; line-height: 1.55;
  color: var(--ms-mute);
  margin: 0;
}
@media (max-width: 720px){
  .ms-photo-feature-grid{ grid-template-columns: 1fr; }
}

/* Polaroid-style photo card (for Orbit lifestyle) */
.ms-photo-polaroid{
  position: relative;
  padding: 14px 14px 56px;
  background: #f8f5ee;
  color: #14121c;
  border-radius: 6px;
  width: 100%;
  max-width: 360px;
  margin: 0 auto;
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,.5),
    0 1px 0 rgba(0,0,0,.1) inset;
  transform: rotate(-2deg);
  transition: transform .5s var(--ease-out);
}
.ms-photo-polaroid:hover{ transform: rotate(0deg) translateY(-4px); }
.ms-photo-polaroid-img{
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #0a0814;
  border-radius: 2px;
}
.ms-photo-polaroid-img > img{
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.ms-photo-polaroid-caption{
  position: absolute; bottom: 18px; left: 0; right: 0;
  text-align: center;
  font-family:'Instrument Serif',serif; font-style: italic;
  font-size: 14px;
}
