/* =========================================================================
   TriData Technologies — Design System
   "Sovereign Modernism" — editorial dark, saffron-amber accents,
   precision mono caption layer, restrained but cinematic motion.
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  --ink:        #0a0f1c;
  --ink-2:      #0f1828;
  --ink-3:      #16223a;
  --ink-4:      #1c2b48;
  --line:       rgba(255,255,255,0.07);
  --line-2:     rgba(255,255,255,0.14);
  --line-3:     rgba(255,255,255,0.22);

  --paper:      #f4efe6;
  --paper-2:    #ece4d3;

  --text:       #ecf0f6;
  --text-dim:   #939cb0;
  --text-mute:  #5b6478;

  --accent:     #d99547;          /* saffron-amber */
  --accent-2:   #f0b870;
  --accent-3:   #b3712a;
  --signal:     #7fd1c4;          /* cool counter-accent */
  --signal-2:   #a6e0d6;
  --danger:     #e26b6b;

  --maxw:       1280px;
  --pad:        clamp(20px, 4vw, 56px);

  --serif:      'Fraunces', 'Times New Roman', serif;
  --sans:       'Manrope', system-ui, -apple-system, sans-serif;
  --mono:       'JetBrains Mono', ui-monospace, Menlo, monospace;

  --r-sm:       6px;
  --r-md:       12px;
  --r-lg:       18px;
  --r-xl:       24px;

  --ease:       cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; background: var(--ink); }
body{
  background: transparent;
  color: var(--text);
  font-family: var(--sans);
  font-weight: 400;
  line-height: 1.55;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }

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

/* Quantum field background canvas */
#quantumField{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  width:100%; height:100%; opacity:.5;
}

/* ---------- Keyframes ---------- */
@keyframes qOrbit{
  from{ transform: rotate(0deg) translateX(var(--r)) rotate(0deg); }
  to  { transform: rotate(360deg) translateX(var(--r)) rotate(-360deg); }
}
@keyframes qSpin{
  from{ transform: rotate(0deg); }
  to  { transform: rotate(360deg); }
}
@keyframes qFlicker{
  0%,100%{ opacity:1; } 50%{ opacity:.35; }
}
@keyframes qDrift{
  0%,100%{ transform: translate(0,0); }
  33%{ transform: translate(8px,-12px); }
  66%{ transform: translate(-6px,8px); }
}
@keyframes qSweep{
  0%{ transform: translateX(-100%); opacity:0; }
  20%,80%{ opacity:1; }
  100%{ transform: translateX(100%); opacity:0; }
}
@keyframes qDashFlow{ to{ stroke-dashoffset:-1000; } }
@keyframes qPulseGlow{
  0%,100%{ filter: drop-shadow(0 0 4px var(--accent)) drop-shadow(0 0 12px rgba(217,149,71,0.4)); }
  50%   { filter: drop-shadow(0 0 8px var(--accent)) drop-shadow(0 0 22px rgba(217,149,71,0.7)); }
}
@keyframes qPacket{
  0%{ offset-distance:0%; opacity:0; }
  10%,90%{ opacity:1; }
  100%{ offset-distance:100%; opacity:0; }
}
@keyframes qScanline{
  0%{ transform: translateY(-100%); } 100%{ transform: translateY(100%); }
}
@keyframes qDataStream{
  0%  { transform: translateY(100%); opacity:0; }
  10%,90%{ opacity:.7; }
  100%{ transform: translateY(-100%); opacity:0; }
}
@keyframes marqueeScroll{
  from{ transform: translateX(0); } to{ transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  #quantumField{ display:none; }
}

/* ---------- Layout ---------- */
.container{
  width:100%; max-width: var(--maxw);
  margin:0 auto; padding-left: var(--pad); padding-right: var(--pad);
  position:relative; z-index:2;
}

/* ---------- Type ---------- */
.eyebrow{
  font-family: var(--mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--text-dim);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:18px; height:1px; background: var(--accent); }

h1,h2,h3,h4,h5{ font-family: var(--serif); font-weight:400; letter-spacing:-0.01em; margin:0; }
h1{ font-size: clamp(40px, 6.6vw, 88px); line-height:1.02; }
h2{ font-size: clamp(30px, 4.4vw, 56px); line-height:1.06; }
h3{ font-size: clamp(20px, 2.2vw, 26px); line-height:1.2; }
h4{ font-size: clamp(16px, 1.6vw, 18px); line-height:1.3; }

.italic{ font-style:italic; font-weight:300; color: var(--accent-2); }
.accent{ color: var(--accent-2); }
.lede{ font-size: clamp(16px, 1.4vw, 19px); color: var(--text-dim); max-width: 62ch; }
.section-sub{ color: var(--text-dim); margin-top: 14px; max-width: 68ch; font-size: clamp(15px, 1.2vw, 16.5px); }

/* ---------- Navigation ---------- */
.nav{
  position: sticky; top:0; z-index: 50;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  background: rgba(10,15,28,0.78);
  border-bottom: 1px solid var(--line);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height: 72px; }

.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{ width:34px; height:34px; position:relative; }
.brand-text{ font-family: var(--serif); font-size: 19px; letter-spacing:.01em; }
.brand-text small{
  font-family: var(--mono); font-size: 9.5px; letter-spacing:.28em;
  display:block; color: var(--text-mute); text-transform:uppercase; margin-top:-3px;
}

.nav-links{ display:flex; gap:28px; align-items:center; }
.nav-links a{
  font-size:13px; color: var(--text-dim); transition: color .2s;
  position:relative; padding:6px 0;
}
.nav-links a:hover, .nav-links a.active{ color: var(--text); }
.nav-links a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px; background: var(--accent);
}

.nav-cta{
  border:1px solid var(--line-2);
  padding: 10px 18px; border-radius: 999px;
  font-size:13px; color: var(--text);
  display:inline-flex; align-items:center; gap:8px;
  transition: all .2s;
}
.nav-cta:hover{ background: var(--accent); border-color: var(--accent); color: var(--ink); }
.nav-cta .dot{ width:6px; height:6px; border-radius:50%; background: var(--accent); box-shadow: 0 0 10px var(--accent); }

.nav-toggle{
  display:none; background:transparent; color: var(--text);
  border:1px solid var(--line-2); padding:8px 12px; border-radius:8px; font-size:13px;
}

@media (max-width: 920px){
  .nav-links{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .nav-cta{ display:none; }
  .nav-links.open{
    display:flex; flex-direction:column; gap:0;
    position:absolute; top:72px; left:0; right:0;
    background: var(--ink-2); border-bottom: 1px solid var(--line);
    padding: 8px var(--pad) 20px;
  }
  .nav-links.open a{ padding: 14px 0; border-bottom: 1px solid var(--line); width:100%; }
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-size:14px; font-weight:500;
  padding: 14px 22px; border-radius: 999px;
  transition: all .25s var(--ease);
  border:1px solid transparent;
}
.btn .arrow{ transition: transform .25s var(--ease); }
.btn:hover .arrow{ transform: translateX(4px); }
.btn-primary{ background: var(--accent); color: var(--ink); }
.btn-primary:hover{ background: var(--accent-2); }
.btn-ghost{ border-color: var(--line-2); color: var(--text); }
.btn-ghost:hover{ border-color: var(--accent); color: var(--accent-2); }

/* ---------- Section heads ---------- */
.section-head{
  display:grid; grid-template-columns: 220px 1fr; gap: clamp(24px, 4vw, 64px);
  align-items: start;
  padding: clamp(64px, 8vw, 110px) 0 clamp(36px, 5vw, 56px);
  position:relative;
}
.section-head .eyebrow{ padding-top:14px; }
@media (max-width: 820px){ .section-head{ grid-template-columns: 1fr; gap: 14px; } }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding: clamp(60px, 9vw, 120px) 0 clamp(80px, 10vw, 140px);
  overflow:hidden;
}
.hero-grid-bg{
  position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:
    linear-gradient(transparent 95%, rgba(255,255,255,0.06) 95%) 0 0/100% 80px,
    linear-gradient(90deg, transparent 95%, rgba(255,255,255,0.06) 95%) 0 0/80px 100%,
    radial-gradient(900px 500px at 80% -10%, rgba(217,149,71,0.18), transparent 60%),
    radial-gradient(700px 380px at 10% 30%, rgba(127,209,196,0.10), transparent 60%);
  mask-image: linear-gradient(180deg, black 30%, transparent 100%);
}
.hero-scan{
  position:absolute; inset:0; pointer-events:none; opacity:.18;
  background: linear-gradient(180deg, transparent, rgba(127,209,196,0.6), transparent);
  height: 200px; animation: qScanline 9s linear infinite;
}
.hero-meta{
  display:flex; flex-wrap:wrap; gap: 32px; margin-bottom: clamp(28px, 4vw, 44px);
  font-family: var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--text-mute);
}
.hero-meta span{ display:inline-flex; flex-direction:column; gap:6px; }
.hero-meta b{ color: var(--text); font-weight:500; letter-spacing:.05em; text-transform:none; font-family: var(--sans); font-size:13px; }

.hero-row{
  display:grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(28px, 5vw, 72px); align-items:center;
}
@media (max-width: 1000px){ .hero-row{ grid-template-columns: 1fr; } }

.cta-row{ display:flex; gap:14px; flex-wrap:wrap; margin-top: 32px; }

/* Hero ops card */
.hero-card{
  position:relative; overflow:hidden;
  border:1px solid var(--line-2);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, rgba(20,33,58,0.6), rgba(15,24,40,0.4));
  padding: 24px;
  backdrop-filter: blur(6px);
}
.data-stream{
  position:absolute; inset:0; pointer-events:none; overflow:hidden;
  font-family: var(--mono); font-size:10px; color: rgba(127,209,196,0.5);
}
.data-stream span{ position:absolute; top:0; animation: qDataStream 8s linear infinite; white-space:nowrap; }

.hc-head{
  display:flex; justify-content:space-between; align-items:center;
  font-family: var(--mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--text-dim);
  padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-bottom: 18px;
}
.hc-head .live{ color: var(--signal); display:inline-flex; align-items:center; gap:6px; }
.hc-head .live::before{ content:""; width:6px; height:6px; border-radius:50%; background: var(--signal); box-shadow: 0 0 8px var(--signal); animation: qFlicker 1.6s infinite; }

.stat-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.stat{ padding: 12px 14px; border:1px solid var(--line); border-radius: var(--r-md); background: rgba(255,255,255,0.02); }
.stat .k{ font-family: var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color: var(--text-mute); }
.stat .v{ font-family: var(--serif); font-size: 28px; line-height:1; margin-top:6px; }
.stat .v .unit{ font-size:14px; color: var(--text-dim); margin-left:2px; }

.india-map{ width:100%; margin-top: 18px; }
.map-link{
  stroke: rgba(217,149,71,0.5); stroke-width: .6; fill: none;
  stroke-dasharray: 3 5; animation: qDashFlow 24s linear infinite;
}
.map-packet{ animation: qPacket 3s linear infinite; }

/* ---------- Marquee ---------- */
.marquee{
  position:relative; overflow:hidden;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: rgba(15,24,40,0.5); padding: 18px 0;
  z-index:2;
}
.marquee-track{ display:inline-flex; gap: 56px; animation: marqueeScroll 60s linear infinite; white-space:nowrap; }
.marquee span{
  font-family: var(--mono); font-size: 11.5px; letter-spacing:.2em; text-transform:uppercase;
  color: var(--text-dim);
}
.marquee span::after{ content:"·"; color: var(--accent); margin-left: 56px; }

/* ---------- About ---------- */
.about{ padding-bottom: clamp(60px, 9vw, 120px); }
.about-grid{
  display:grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(28px, 5vw, 64px);
}
@media (max-width: 960px){ .about-grid{ grid-template-columns: 1fr; } }
.about-prose p{ font-size: clamp(15.5px, 1.2vw, 17px); line-height: 1.7; color: var(--text); margin: 0 0 18px; max-width: 62ch; }
.about-prose p b{ color: var(--text); }
.pillquotes{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 24px; }
.pill{
  display:inline-flex; align-items:center; gap: 8px;
  padding: 8px 14px; border-radius: 999px;
  border: 1px solid var(--line-2);
  font-family: var(--mono); font-size: 11px; letter-spacing:.16em; text-transform:uppercase;
  color: var(--text-dim);
}
.pill b{ color: var(--accent-2); font-weight:500; }

.credentials{
  border:1px solid var(--line); border-radius: var(--r-lg);
  background: rgba(15,24,40,0.55);
  padding: 24px;
}
.credentials h4{ font-size: 18px; margin-bottom: 16px; }
.cred-row{ display:flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--line); }
.cred-row:first-of-type{ border-top: none; }
.cred-row .check{
  flex: 0 0 22px; width:22px; height:22px; border-radius:50%;
  background: rgba(127,209,196,0.12); color: var(--signal);
  display:inline-flex; align-items:center; justify-content:center; font-size: 12px;
  border: 1px solid rgba(127,209,196,0.35);
}
.cred-row .t b{ display:block; font-size: 14px; color: var(--text); }
.cred-row .t span{ font-size: 12.5px; color: var(--text-dim); }

.investor{
  margin-top: 20px;
  padding: 22px; border-radius: var(--r-lg);
  border:1px solid var(--line);
  background: linear-gradient(135deg, rgba(217,149,71,0.10), rgba(217,149,71,0));
}
.investor .name{ font-family: var(--serif); font-size: 24px; margin-top: 10px; }
.investor .where{ font-size: 13px; color: var(--text-dim); margin-top: 4px; }

/* ---------- Business Units ---------- */
.bu{ padding-bottom: clamp(60px, 9vw, 120px); }
.bu-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
@media (max-width: 1000px){ .bu-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px){ .bu-grid{ grid-template-columns: 1fr; } }

.bu-card{
  background: var(--ink);
  padding: clamp(24px, 3vw, 36px);
  display:flex; flex-direction:column; gap: 14px;
  position:relative; overflow:hidden;
  transition: background .3s;
}
.bu-card:hover{ background: var(--ink-2); }
.bu-card::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(115deg, transparent 30%, rgba(127,209,196,0.08) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .8s var(--ease);
}
.bu-card:hover::after{ transform: translateX(100%); }
.bu-card .icon{ width: 48px; height: 48px; }
.bu-card .icon svg{ width:100%; height:100%; transition: transform .6s var(--ease); }
.bu-card:hover .icon svg{ transform: rotate(360deg); }
.bu-card .id{
  font-family: var(--mono); font-size: 10.5px; letter-spacing:.2em; text-transform:uppercase;
  color: var(--text-mute);
}
.bu-card h3{ color: var(--text); }
.bu-card .desc{ color: var(--text-dim); font-size: 14.5px; line-height: 1.65; }
.bu-card ul{
  list-style:none; padding:0; margin: 6px 0 0;
  display:flex; flex-direction:column; gap: 8px;
}
.bu-card ul li{
  font-size: 13px; color: var(--text-dim);
  padding-left: 16px; position:relative;
}
.bu-card ul li::before{
  content:""; position:absolute; left: 0; top: 9px;
  width:6px; height:1px; background: var(--accent);
}

/* ---------- Metrics ---------- */
.metrics{ padding-bottom: clamp(60px, 9vw, 120px); }
.metrics-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--line);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
@media (max-width: 900px){ .metrics-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px){ .metrics-grid{ grid-template-columns: 1fr; } }
.m-cell{
  background: var(--ink); padding: clamp(24px, 3vw, 40px);
  display:flex; flex-direction:column; gap: 10px;
}
.m-cell .k{
  font-family: var(--mono); font-size: 10.5px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--text-mute);
}
.m-cell .v{ font-family: var(--serif); font-size: clamp(38px, 4.5vw, 60px); line-height:1; color: var(--text); }
.m-cell .v .u{ font-size: .5em; color: var(--text-dim); margin-left: 4px; }
.m-cell .note{ font-size: 13px; color: var(--text-dim); }

/* ---------- Portfolio ---------- */
.portfolio{ padding-bottom: clamp(60px, 9vw, 120px); }
.port-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--line);
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
@media (max-width: 1000px){ .port-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px){ .port-grid{ grid-template-columns: 1fr; } }
.port-card{
  background: var(--ink); padding: clamp(24px, 3vw, 32px);
  display:flex; flex-direction:column; gap: 12px;
  position:relative; overflow:hidden; transition: background .3s;
}
.port-card:hover{ background: var(--ink-2); }
.port-card::after{
  content:""; position:absolute; left:0; right:0; top:0; height:1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:0; transition: opacity .3s;
}
.port-card:hover::after{ opacity:1; }
.port-meta{ display:flex; justify-content:space-between; align-items:center; font-family: var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color: var(--text-mute); }
.port-meta .tag{ color: var(--accent-2); }
.port-card p{ color: var(--text-dim); font-size: 14px; line-height: 1.65; }
.port-card .status{
  margin-top: auto; font-family: var(--mono); font-size: 11px; letter-spacing:.16em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:8px; color: var(--signal);
}
.port-card .status::before{ content:""; width:6px; height:6px; border-radius:50%; background: var(--signal); box-shadow: 0 0 8px var(--signal); }

/* ---------- Infrastructure ---------- */
.infra{ padding-bottom: clamp(60px, 9vw, 120px); }
.infra-grid{
  display:grid; grid-template-columns: 1fr 1fr;
  gap: clamp(30px, 5vw, 64px); align-items:start;
}
@media (max-width: 1000px){ .infra-grid{ grid-template-columns: 1fr; } }

.infra-specs{
  display:grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: var(--line); border:1px solid var(--line);
  border-radius: var(--r-md); overflow:hidden;
  margin-top: 28px;
}
.spec{ background: var(--ink); padding: 16px 18px; }
.spec .k{ font-family: var(--mono); font-size: 10.5px; letter-spacing:.18em; text-transform:uppercase; color: var(--text-mute); }
.spec .v{ font-size: 15px; color: var(--text); margin-top: 4px; }

.infra-diagram{
  background: rgba(15,24,40,0.55);
  border:1px solid var(--line); border-radius: var(--r-lg);
  padding: 14px;
}
.dc-rack{ animation: qFlicker 4s infinite; animation-delay: var(--d, 0s); }
.dc-led{ animation: qFlicker 1.6s infinite; }
.dc-power-line{ stroke: var(--accent); stroke-width: 1.4; stroke-dasharray: 4 6; animation: qDashFlow 6s linear infinite; }

/* ---------- Quantum ---------- */
.quantum{ padding-bottom: clamp(60px, 9vw, 120px); }
.quantum-grid{
  display:grid; grid-template-columns: 1fr 1fr;
  gap: clamp(30px, 5vw, 64px); align-items:center;
}
@media (max-width: 1000px){ .quantum-grid{ grid-template-columns: 1fr; } }
.quantum-vis{
  position:relative; aspect-ratio: 1/1; width:100%;
  border:1px solid var(--line); border-radius: var(--r-lg);
  background: radial-gradient(circle at center, rgba(127,209,196,0.06), transparent 60%);
  overflow:hidden;
}
.quantum-vis svg{ width:100%; height:100%; }

.qfacts{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 28px; }
@media (max-width: 540px){ .qfacts{ grid-template-columns: 1fr; } }
.qfact{
  border:1px solid var(--line); border-radius: var(--r-md); padding: 16px;
  background: rgba(127,209,196,0.04);
}
.qfact .k{ font-family: var(--mono); font-size:10.5px; letter-spacing:.2em; color: var(--signal); text-transform:uppercase; }
.qfact .v{ font-family: var(--serif); font-size: 20px; margin-top: 6px; }
.qfact .d{ font-size: 12.5px; color: var(--text-dim); margin-top: 6px; line-height:1.5; }

/* ---------- Contact ---------- */
.contact{ padding-bottom: clamp(60px, 9vw, 120px); }
.contact-grid{
  display:grid; grid-template-columns: 1fr 1.2fr;
  gap: clamp(28px, 5vw, 56px);
}
@media (max-width: 960px){ .contact-grid{ grid-template-columns: 1fr; } }
.info-row{
  display:grid; grid-template-columns: 130px 1fr; gap: 18px;
  padding: 16px 0; border-top: 1px solid var(--line);
  align-items: start;
}
.info-row:first-of-type{ border-top: 1px solid var(--line); }
.info-row .k{ font-family: var(--mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase; color: var(--text-mute); padding-top: 4px; }
.info-row .v{ font-size: 14.5px; color: var(--text); line-height: 1.55; }
.info-row .v a{ color: var(--accent-2); border-bottom: 1px dashed rgba(240,184,112,0.4); }
.info-row .v a:hover{ color: var(--text); border-color: var(--text); }

.contact form{
  background: rgba(15,24,40,0.55);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(24px, 3vw, 32px);
  display:flex; flex-direction:column; gap: 18px;
}
.contact form .row{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 640px){ .contact form .row{ grid-template-columns: 1fr; } }
.field{ display:flex; flex-direction:column; gap: 8px; }
.field label{
  font-family: var(--mono); font-size: 10.5px; letter-spacing:.2em; text-transform:uppercase;
  color: var(--text-mute);
}
.field input, .field select, .field textarea{
  background: rgba(255,255,255,0.02);
  border:1px solid var(--line-2);
  color: var(--text);
  padding: 12px 14px;
  border-radius: var(--r-md);
  font-family: var(--sans); font-size: 14px;
  outline: none;
  transition: border-color .2s, background .2s;
}
.field textarea{ min-height: 130px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  border-color: var(--accent); background: rgba(255,255,255,0.04);
}
.form-submit{
  align-self: flex-start;
  background: var(--accent); color: var(--ink);
  border: none; padding: 14px 24px; border-radius: 999px;
  font-size: 14px; font-weight: 500;
  display:inline-flex; align-items:center; gap: 10px;
  transition: background .25s;
}
.form-submit:hover{ background: var(--accent-2); }
.form-foot{ font-family: var(--mono); font-size: 10.5px; letter-spacing:.18em; text-transform:uppercase; color: var(--text-mute); }

/* ---------- Page Hero (sub-pages) ---------- */
.page-hero{
  position:relative;
  padding: clamp(70px, 8vw, 110px) 0 clamp(50px, 6vw, 80px);
  overflow:hidden;
  border-bottom: 1px solid var(--line);
}
.page-hero .hero-grid-bg{ opacity:.35; }
.page-hero h1{ font-size: clamp(36px, 5vw, 64px); }
.page-hero .lede{ margin-top: 22px; max-width: 64ch; }
.crumbs{
  font-family: var(--mono); font-size: 11px; letter-spacing:.2em; text-transform:uppercase;
  color: var(--text-mute);
  display:flex; gap: 10px; align-items:center; margin-bottom: 22px;
}
.crumbs a{ color: var(--text-dim); }
.crumbs a:hover{ color: var(--accent-2); }
.crumbs span.sep{ color: var(--accent); }

/* ---------- Service detail (services page) ---------- */
.svc-block{
  display:grid; grid-template-columns: 1fr 1.5fr;
  gap: clamp(28px, 5vw, 64px);
  padding: clamp(48px, 6vw, 80px) 0;
  border-bottom: 1px solid var(--line);
}
.svc-block:last-of-type{ border-bottom: none; }
@media (max-width: 900px){ .svc-block{ grid-template-columns: 1fr; } }
.svc-id{
  font-family: var(--mono); font-size: 11px; letter-spacing:.22em; text-transform:uppercase;
  color: var(--accent-2); margin-bottom: 14px;
}
.svc-block h2{ font-size: clamp(28px, 3.6vw, 44px); }
.svc-block .lede{ margin-top: 16px; }
.svc-cap{
  display:grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 26px;
}
@media (max-width: 600px){ .svc-cap{ grid-template-columns: 1fr; } }
.cap{
  border:1px solid var(--line); border-radius: var(--r-md);
  padding: 16px; background: rgba(255,255,255,0.02);
}
.cap .h{ font-size: 14px; color: var(--text); font-weight: 500; }
.cap .d{ font-size: 13px; color: var(--text-dim); margin-top: 6px; line-height: 1.55; }

/* ---------- CTA strip ---------- */
.cta-strip{
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(217,149,71,0.05), rgba(217,149,71,0));
  padding: clamp(50px, 6vw, 80px) 0;
}
.cta-strip .inner{
  display:flex; justify-content:space-between; align-items:center; gap: 24px;
  flex-wrap: wrap;
}
.cta-strip h2{ font-size: clamp(28px, 3.4vw, 42px); max-width: 22ch; }

/* ---------- Footer ---------- */
footer{
  background: var(--ink-2);
  border-top: 1px solid var(--line);
  padding: clamp(48px, 6vw, 80px) 0 24px;
  position:relative; z-index:2;
}
.foot-grid{
  display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: clamp(24px, 4vw, 48px);
}
@media (max-width: 900px){ .foot-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .foot-grid{ grid-template-columns: 1fr; } }
.foot-brand p{ color: var(--text-dim); font-size: 13.5px; line-height: 1.65; margin: 14px 0 18px; max-width: 38ch; }
.foot-col h5{ font-family: var(--mono); font-size: 11px; letter-spacing:.22em; text-transform:uppercase; color: var(--text-mute); margin-bottom: 16px; }
.foot-col a{ display:block; color: var(--text-dim); font-size: 13.5px; padding: 6px 0; transition: color .2s; }
.foot-col a:hover{ color: var(--accent-2); }
.foot-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap: 12px;
  margin-top: clamp(36px, 5vw, 56px);
  padding-top: 22px; border-top: 1px solid var(--line);
  font-family: var(--mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--text-mute);
}
