/* ============ Unchained Raven — site styles ============ */
:root{
  --obsidian:#0F1115;
  --raven:#1D3557;
  --raven-deep:#16243C;
  --teal:#00A3A3;
  --teal-bright:#3FD3CE;
  --indigo:#4F46E5;
  --indigo-soft:#8A86F0;
  --mist:#E8ECF1;
  --mist-dim:#9AA6B6;
  --mist-faint:#6B7689;
  --line:rgba(232,236,241,.12);
  --line-strong:rgba(232,236,241,.22);
  --serif:'Cormorant Garamond',Georgia,serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'Hanken Grotesk',system-ui,sans-serif;
  --maxw:1280px;
  --pad:clamp(22px,5vw,72px);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--obsidian);color:var(--mist);
  font-family:var(--sans);font-weight:300;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--teal);color:var(--obsidian);}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}

.eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.34em;
  text-transform:uppercase;font-weight:500;color:var(--teal-bright);
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--teal);}
.serif{font-family:var(--serif);}
em{font-style:italic;}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  padding:15px 26px;cursor:pointer;border:1px solid transparent;white-space:nowrap;
  background:var(--mist);color:var(--obsidian);transition:.4s cubic-bezier(.2,.7,.3,1);
  position:relative;overflow:hidden;
}
.btn .arr{transition:transform .4s cubic-bezier(.2,.7,.3,1);}
.btn:hover{background:var(--teal);color:var(--obsidian);}
.btn:hover .arr{transform:translateX(5px);}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--mist);
  border-bottom:1px solid var(--teal);padding-bottom:5px;transition:.3s;
}
.btn-ghost:hover{color:var(--teal-bright);letter-spacing:.22em;}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--pad);transition:background .45s,backdrop-filter .45s,padding .45s,border-color .45s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(15,17,21,.82);backdrop-filter:blur(14px);
  padding-top:16px;padding-bottom:16px;border-bottom:1px solid var(--line);
}
.wm{display:flex;align-items:center;gap:13px;}
.brand-logo{
  display:block;height:32px;width:auto;
  filter:drop-shadow(0 0 10px rgba(0,163,163,.22));
}
.nav-right{display:flex;align-items:center;gap:38px;}
.nav-links{display:flex;gap:32px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;}
.nav-links a{opacity:.62;transition:.3s;position:relative;}
.nav-links a:hover{opacity:1;color:var(--teal-bright);}
.nav .btn{padding:11px 20px;}
@media(max-width:980px){.nav-links{display:none;}}
@media(max-width:560px){.brand-logo{height:26px;}}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  padding-block:clamp(116px,17vh,196px) clamp(80px,12vh,120px);}
.hero-photo{position:absolute;inset:0 0 0 42%;z-index:1;}
.hero-photo image-slot{width:100%;height:100%;display:block;}
.hero-emblem{
  position:absolute;right:4%;top:50%;transform:translateY(-50%);
  width:min(46vw,640px);z-index:1;opacity:.10;pointer-events:none;
}
.hero-emblem img{width:100%;height:auto;display:block;}
.hero-glow{
  position:absolute;right:6%;top:50%;transform:translate(0,-50%);
  width:540px;height:540px;border-radius:50%;z-index:0;pointer-events:none;
  background:radial-gradient(circle,rgba(0,163,163,.22),rgba(79,70,229,.12) 45%,transparent 70%);
  filter:blur(8px);
}
.hero-scrim{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,var(--obsidian) 34%,rgba(15,17,21,.7) 52%,rgba(15,17,21,0) 74%);
}
.hero-scrim2{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(0deg,var(--obsidian),transparent 30%);}
.hero-inner{position:relative;z-index:3;width:100%;}
.hero h1{
  font-family:var(--serif);font-weight:500;font-size:clamp(46px,7.3vw,104px);
  line-height:.93;letter-spacing:-.01em;margin:26px 0 0;max-width:12ch;
}
.hero h1 em{color:var(--teal-bright);}
.hero .sub{margin:32px 0 0;font-size:clamp(16px,1.4vw,19px);line-height:1.62;
  color:var(--mist-dim);max-width:46ch;}
.hero .hero-body{
  margin:18px 0 0;font-size:clamp(15px,1.22vw,18px);line-height:1.7;
  color:var(--mist-dim);max-width:52ch;
}
.hero .hero-promise{
  margin:20px 0 0;font-family:var(--mono);font-size:12px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--mist);max-width:52ch;
}
.hero .cta-row{display:flex;align-items:center;gap:34px;margin-top:44px;flex-wrap:wrap;}
.hero-signals{
  display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;max-width:56rem;
}
.hero-signals span{
  display:inline-flex;align-items:center;gap:10px;padding:10px 14px;
  border:1px solid var(--line);background:rgba(15,17,21,.42);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mist-dim);backdrop-filter:blur(8px);
}
.hero-signals span::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--indigo-soft));
  box-shadow:0 0 14px rgba(63,211,206,.45);
}
.scroll-cue{
  position:absolute;bottom:34px;right:var(--pad);z-index:3;display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--mist-faint);
}
.scroll-cue .bar{width:48px;height:1px;background:var(--mist-faint);position:relative;overflow:hidden;}
.scroll-cue .bar::after{content:"";position:absolute;inset:0;background:var(--teal);
  animation:slide 2.4s cubic-bezier(.5,0,.3,1) infinite;}
@keyframes slide{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
@media(max-height:680px){.scroll-cue{display:none;}}

/* ============ reveal ============ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.3,1),transform 1s cubic-bezier(.2,.7,.3,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

/* ============ section frame ============ */
section{position:relative;}
.sec-pad{padding-block:clamp(96px,15vh,190px);}
.sec-label{display:flex;align-items:baseline;gap:18px;margin-bottom:54px;}
.sec-num{font-family:var(--mono);font-size:12px;color:var(--mist-faint);letter-spacing:.2em;}

/* ============ BELIEF ============ */
.belief{border-top:1px solid var(--line);}
.belief .statement{
  font-family:var(--serif);font-weight:400;font-size:clamp(34px,5.6vw,76px);
  line-height:1.04;letter-spacing:-.01em;max-width:18ch;margin:26px 0 0;
}
.belief .statement em{color:var(--teal-bright);}
.belief .body-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,90px);margin-top:64px;align-items:start;}
.belief .body-grid p{font-size:clamp(16px,1.35vw,18px);color:var(--mist-dim);max-width:48ch;margin:0;}
.belief .body-grid .lead{font-family:var(--serif);font-size:clamp(22px,2.4vw,30px);
  line-height:1.4;color:var(--mist);font-weight:400;}
.point-list{
  list-style:none;padding:0;margin:28px 0 0;display:grid;gap:16px;
}
.point-list li{
  position:relative;padding-left:22px;color:var(--mist-dim);font-size:15px;
}
.point-list li::before{
  content:"";position:absolute;left:0;top:.72em;width:9px;height:1px;background:var(--teal);
}
@media(max-width:760px){.belief .body-grid{grid-template-columns:1fr;}}

/* ============ SERVICES ============ */
.services{border-top:1px solid var(--line);position:relative;}
.services::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(63,211,206,.8),rgba(79,70,229,.8),transparent);
  opacity:.35;
}
.services-head{
  display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);
  gap:clamp(28px,6vw,90px);align-items:end;margin-top:28px;
}
.services-head h2{
  margin:0;font-weight:400;font-size:clamp(34px,5vw,68px);line-height:1.02;max-width:11ch;
}
.services-head p{
  margin:0;color:var(--mist-dim);font-size:clamp(16px,1.35vw,18px);max-width:42ch;
}
.service-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin-top:64px;
}
.service-card{
  position:relative;padding:34px 30px 32px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(29,53,87,.44),rgba(15,17,21,.9));
  overflow:hidden;min-height:100%;
}
.service-card::after{
  content:"";position:absolute;left:0;top:0;width:100%;height:1px;
  background:linear-gradient(90deg,var(--teal),rgba(79,70,229,.65),transparent);
  opacity:.7;
}
.service-num{
  display:inline-block;font-family:var(--mono);font-size:12px;color:var(--teal-bright);
  letter-spacing:.22em;text-transform:uppercase;
}
.service-card h3{
  margin:26px 0 14px;font-size:clamp(28px,3vw,40px);line-height:1.02;font-weight:500;
}
.service-card p{
  margin:0;color:var(--mist-dim);font-size:15px;max-width:40ch;
}
.service-list{
  list-style:none;padding:0;margin:28px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:12px 18px;
}
.service-list li{
  position:relative;padding-left:18px;font-size:14px;color:var(--mist);
}
.service-list li::before{
  content:"";position:absolute;left:0;top:.68em;width:8px;height:8px;border:1px solid var(--teal);
  transform:rotate(45deg);
}
@media(max-width:980px){
  .services-head{grid-template-columns:1fr;}
  .service-grid{grid-template-columns:1fr;}
}
@media(max-width:620px){
  .service-list{grid-template-columns:1fr;}
}

/* ============ APART ============ */
.apart{background:var(--raven-deep);border-top:1px solid var(--line);position:relative;}
.apart::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--teal),var(--indigo),transparent);opacity:.6;}
.principle{
  display:grid;grid-template-columns:90px 1fr auto;gap:clamp(20px,4vw,56px);
  align-items:baseline;padding:38px 0;border-top:1px solid var(--line);
}
.principle:last-child{border-bottom:1px solid var(--line);}
.principle .pn{font-family:var(--mono);font-size:13px;color:var(--teal);letter-spacing:.1em;padding-top:8px;}
.principle .pt{font-family:var(--serif);font-size:clamp(26px,3.4vw,46px);font-weight:500;line-height:1;}
.principle .pd{font-size:15px;color:var(--mist-dim);max-width:34ch;justify-self:start;}
.principle:hover .pt{color:var(--teal-bright);}
.principle .pt{transition:color .4s;}
@media(max-width:760px){.principle{grid-template-columns:54px 1fr;}.principle .pd{grid-column:2;}}

/* ============ SERVE ============ */
.serve{border-top:1px solid var(--line);}
.serve .lead{font-family:var(--serif);font-weight:400;font-size:clamp(30px,4.6vw,60px);
  line-height:1.08;max-width:20ch;margin:26px 0 0;}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:64px;}
.card{
  background:var(--raven);border:1px solid var(--line);padding:38px 32px 44px;
  position:relative;overflow:hidden;transition:.5s cubic-bezier(.2,.7,.3,1);
}
.card::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--teal),var(--indigo));transition:width .6s cubic-bezier(.2,.7,.3,1);}
.card:hover{transform:translateY(-6px);border-color:var(--line-strong);}
.card:hover::after{width:100%;}
.card .cnum{font-family:var(--mono);font-size:12px;color:var(--teal);letter-spacing:.2em;}
.card h3{font-family:var(--serif);font-weight:500;font-size:30px;margin:60px 0 14px;line-height:1.05;max-width:12ch;}
.card p{font-size:14.5px;color:var(--mist-dim);margin:0;}
@media(max-width:1120px){.cards{grid-template-columns:repeat(2,1fr);}}
@media(max-width:860px){.cards{grid-template-columns:1fr;}}

/* ============ CTA ============ */
.cta{position:relative;border-top:1px solid var(--line);overflow:hidden;}
.cta-glow{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);
  width:760px;height:760px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(0,163,163,.16),rgba(79,70,229,.10) 42%,transparent 68%);}
.cta-shell{
  position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,520px);
  gap:clamp(24px,5vw,56px);align-items:start;
}
.cta-copy{padding-top:4px;}
.cta-emblem{width:104px;margin:16px 0 14px;opacity:.9;
  filter:drop-shadow(0 0 22px rgba(0,163,163,.45));position:relative;z-index:2;}
.cta-emblem img{width:100%;height:auto;display:block;}
.cta h2{font-family:var(--serif);font-weight:500;font-size:clamp(44px,7vw,104px);
  line-height:.98;margin:0;position:relative;z-index:2;}
.cta h2 em{color:var(--teal-bright);}
.cta p{position:relative;z-index:2;color:var(--mist-dim);font-size:16px;max-width:40ch;margin:16px 0 0;}
.cta-points{
  list-style:none;padding:0;margin:22px 0 0;display:grid;gap:10px;
}
.cta-points li{
  position:relative;padding-left:20px;font-size:14px;color:var(--mist);
}
.cta-points li::before{
  content:"";position:absolute;left:0;top:.63em;width:8px;height:8px;
  border:1px solid var(--teal);transform:rotate(45deg);
}
.cta-panel{
  position:relative;padding:22px;border:1px solid var(--line-strong);
  background:linear-gradient(180deg,rgba(24,32,48,.9),rgba(15,17,21,.96));
  backdrop-filter:blur(12px);
}
.cta-panel::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,var(--teal),rgba(79,70,229,.7),transparent);
}
.contact-form{
  display:grid;gap:14px;
}
.contact-form[hidden],
.contact-success[hidden]{
  display:none;
}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.contact-form label{
  display:grid;gap:7px;
}
.contact-form label span{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mist-faint);
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;border:1px solid var(--line);background:rgba(8,10,14,.86);color:var(--mist);
  padding:12px 14px;font:inherit;outline:none;transition:border-color .25s,box-shadow .25s,background .25s;
  border-radius:0;
}
.contact-form select{
  appearance:none;
}
.contact-form textarea{
  resize:vertical;min-height:108px;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color:rgba(63,211,206,.65);box-shadow:0 0 0 1px rgba(63,211,206,.2);background:rgba(8,10,14,.96);
}
.contact-submit{
  justify-self:start;margin-top:4px;position:relative;z-index:2;padding:15px 24px;font-size:12px;
}
.contact-submit:disabled{
  opacity:.7;cursor:wait;
}
.contact-status{
  margin:2px 0 0;font-size:14px;min-height:1.5em;color:var(--mist-faint);
}
.contact-status[data-state="pending"]{
  color:var(--mist-dim);
}
.contact-status[data-state="error"]{
  color:#f2a6a6;
}
.contact-success{
  display:grid;gap:10px;align-content:center;min-height:100%;padding:12px 2px 6px;
}
.contact-success h3{
  margin:0;font-size:clamp(28px,4vw,42px);font-weight:500;
}
.contact-success p{
  margin:0;max-width:32ch;
}
.success-mark{
  display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid rgba(63,211,206,.5);
  color:var(--teal-bright);font-family:var(--mono);font-size:16px;
}
@media(max-width:980px){
  .cta-shell{grid-template-columns:1fr;}
  .cta-panel{padding:20px;}
}
@media(max-width:640px){
  .form-row{grid-template-columns:1fr;}
}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--line);padding:54px var(--pad) 40px;}
.foot-grid{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;
  align-items:flex-end;gap:30px;flex-wrap:wrap;}
.foot-grid .legal{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--mist-faint);line-height:1.9;text-transform:uppercase;}
.foot-grid .tag{font-family:var(--serif);font-size:26px;}
.foot-grid .tag em{color:var(--teal-bright);}
