/* ============================================================
   miscloud.tech — "Engineering Studio / Editorial"
   Deep Space palette, calmed for B2B. Mono as structure.
   Hairlines · blueprint grid · grain · oversized display.
   ============================================================ */

:root{
  /* palette */
  --void:#04060c;
  --abyss:#080e1a;
  --deep:#0c1426;
  --line:#172439;
  --line-2:#22324d;
  --blue:#3fd0e6;        /* calm electric blue */
  --orange:#ff9f43;      /* Artemisa — used sparingly */
  --star:#e7eefb;
  --dust:#6b7a99;
  --body:#aab6cf;

  --accent:#3fd0e6;
  --accent-ink:#04222b;

  /* type */
  --font-display:'Space Grotesk', system-ui, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, monospace;

  /* layout */
  --maxw:1320px;
  --pad-x:clamp(22px, 5.5vw, 88px);
  --nav-h:78px;
  --r:5px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--void);color:var(--body);
  font-family:var(--font-body);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}

/* atmosphere: deep wash + grain */
body::before{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(1200px 760px at 82% -10%, rgba(63,208,230,.05), transparent 58%),
    radial-gradient(1000px 680px at 8% 112%, rgba(255,159,67,.03), transparent 58%),
    var(--void);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.42;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:rgba(63,208,230,.22);color:var(--star);}

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--accent);margin:0 0 22px;display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent);opacity:.7;}
.eyebrow.plain::before{display:none;}

h1,h2,h3{font-family:var(--font-display);color:var(--star);font-weight:600;margin:0;}
h1{font-size:clamp(2.6rem,5.6vw,5rem);line-height:1.0;letter-spacing:-.035em;font-weight:700;}
h2{font-size:clamp(1.9rem,3.8vw,3.2rem);line-height:1.05;letter-spacing:-.03em;font-weight:600;}
h3{font-size:1.32rem;line-height:1.22;letter-spacing:-.012em;font-weight:600;}
.lead{font-size:clamp(1.12rem,1.55vw,1.38rem);color:var(--body);line-height:1.55;font-weight:400;}
p{margin:0 0 1em;text-wrap:pretty;}
.muted{color:var(--dust);}
.mono{font-family:var(--font-mono);}
.accent{color:var(--accent);}
.cat-word{color:var(--orange);}

/* mono section label, e.g. "01 — SERVICIOS" */
.tag-label{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--dust);display:inline-flex;align-items:center;gap:14px;}
.tag-label b{color:var(--accent);font-weight:500;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x);}
section{position:relative;}
.section{padding:clamp(76px,9vw,150px) 0;}
.section.tight{padding-top:0;}
.section-head{max-width:720px;margin-bottom:clamp(44px,5vw,68px);}
.section-head h2{margin-top:18px;}
.section-head .lead{margin:20px 0 0;}
.rule{height:1px;background:var(--line);border:0;margin:0;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;
  background:rgba(4,6,12,.74);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%;gap:24px;}
.brand{display:flex;align-items:center;gap:14px;}
.brand-name{font-family:var(--font-display);font-weight:600;color:#ffffff;font-size:1.72rem;letter-spacing:-.02em;line-height:1;}
.brand-name .tld{color:var(--blue);font-weight:500;}
/* large brand lockup (footer / standalone) */
.brand-lg{gap:22px;}
.brand-lg .artemisa{height:128px;}
.brand-lg .brand-name{font-size:2.9rem;font-weight:700;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-family:var(--font-mono);font-size:.84rem;letter-spacing:.04em;color:var(--star);font-weight:500;transition:color .2s;}
.nav-links a:hover,.nav-links a.active{color:#ffffff;}
.nav-links a.active{position:relative;}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-27px;height:2px;background:var(--accent);}
.nav-links a.btn{font-family:var(--font-body);}
.nav-actions{display:flex;align-items:center;gap:14px;}

.artemisa{height:60px;flex:none;display:inline-flex;align-items:center;}
.artemisa svg,.artemisa img{height:100%;width:auto;display:block;overflow:visible;background:transparent;}

.lang{display:inline-flex;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;
  border:1px solid var(--line);border-radius:999px;overflow:hidden;background:rgba(12,20,38,.4);}
.lang button{appearance:none;border:0;background:transparent;color:#c2cde2;font-family:inherit;
  font-size:inherit;letter-spacing:inherit;padding:6px 12px;cursor:pointer;transition:.18s;font-weight:600;}
.lang button[aria-pressed="true"]{background:var(--accent);color:var(--accent-ink);font-weight:700;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-body);font-weight:600;
  font-size:.97rem;padding:13px 22px;border-radius:var(--r);cursor:pointer;border:1px solid transparent;
  transition:transform .15s ease, background .2s, border-color .2s, color .2s;white-space:nowrap;}
.btn .arr{font-family:var(--font-mono);transition:transform .2s;}
.btn:hover .arr{transform:translateX(4px);}
.btn-primary{background:var(--accent);color:var(--accent-ink);}
.btn-primary:hover{transform:translateY(-2px);background:#5fdcf0;}
.btn-ghost{background:transparent;color:var(--star);border-color:var(--line-2);}
.btn-ghost:hover{border-color:var(--accent);transform:translateY(-2px);}
.btn-lg{padding:16px 28px;font-size:1.04rem;}

/* ---------- HERO (editorial spec sheet) ---------- */
.hero{position:relative;min-height:calc(100svh - var(--nav-h));display:flex;flex-direction:column;
  justify-content:center;overflow:hidden;padding:clamp(40px,7vw,90px) 0;}
.hero > .wrap{width:100%;position:relative;z-index:2;}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
/* blueprint grid inside hero */
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:78px 78px;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 40%,#000 30%,transparent 78%);
          mask-image:radial-gradient(120% 100% at 50% 40%,#000 30%,transparent 78%);}

.hero-grid{display:grid;grid-template-columns:1fr 1.12fr;gap:clamp(28px,4.5vw,64px);align-items:center;}
.hero-headline{font-family:var(--font-display);font-weight:700;letter-spacing:-.045em;
  font-size:clamp(3rem,8.2vw,8rem);line-height:.94;color:var(--star);margin:26px 0 0;}
.hl-line{display:block;overflow:hidden;}
.hl-ink{display:block;}
.hero-sub{max-width:520px;margin:30px 0 0;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;}

/* ---- hero cat — the notable static ASCII (Artemisa, full body) ---- */
.hero-cat{position:relative;height:clamp(360px,81vh,885px);
  display:flex;align-items:center;justify-content:center;}
.hero-cat::before{content:"";position:absolute;inset:-6% -12%;z-index:0;pointer-events:none;
  background:radial-gradient(58% 52% at 50% 46%, rgba(63,208,230,.13), transparent 72%);}
.hero-cat-art{position:relative;z-index:1;margin:0;
  font-family:var(--font-mono);font-weight:500;
  font-size:var(--hfs,4px);line-height:1.0em;letter-spacing:0;white-space:pre;
  color:var(--star);text-shadow:0 0 16px rgba(63,208,230,.22);}

/* ---- hero spec strip (4-up technical readout) ---- */
.hero-spec{margin-top:clamp(34px,5vh,64px);border-top:1px solid var(--line-2);padding-top:18px;}
.hero-spec-cap{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--dust);display:flex;justify-content:space-between;margin-bottom:18px;}
.hero-spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.hspec{display:flex;flex-direction:column;gap:8px;padding:4px 26px;border-left:1px solid var(--line);}
.hspec:first-child{padding-left:0;border-left:none;}
.hspec .sk{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);}
.hspec .sv{font-size:.95rem;color:var(--body);line-height:1.45;}
.hspec .sv b{color:var(--star);font-weight:600;}

/* spec column — pilares as a technical readout */
.spec{border-top:1px solid var(--line-2);}
.spec-row{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:16px 0;border-bottom:1px solid var(--line);align-items:baseline;}
.spec-row .sk{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);white-space:nowrap;}
.spec-row .sv{font-size:.96rem;color:var(--body);}
.spec-row .sv b{color:var(--star);font-weight:600;}
.spec-cap{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--dust);margin-bottom:14px;display:flex;justify-content:space-between;}

/* hero top meta strip */
.hero-meta{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dust);}
.hero-meta .blip{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;vertical-align:middle;margin-right:9px;
  box-shadow:0 0 0 0 rgba(63,208,230,.5);animation:blip 2.6s ease-out infinite;}
@keyframes blip{0%{box-shadow:0 0 0 0 rgba(63,208,230,.45)}70%{box-shadow:0 0 0 7px rgba(63,208,230,0)}100%{box-shadow:0 0 0 0 rgba(63,208,230,0)}}

@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:30px;align-items:start;}
  .hero-cat{order:-1;height:clamp(340px,54vh,560px);justify-content:flex-start;}
  .hero-spec-grid{grid-template-columns:1fr 1fr;gap:22px 0;}
  .hspec:nth-child(3){padding-left:0;border-left:none;}
}
@media(max-width:560px){
  .hero-spec-grid{grid-template-columns:1fr;}
  .hspec{padding-left:0;border-left:none;padding-right:0;}
}

/* ---------- load reveal ---------- */
@media(prefers-reduced-motion:no-preference){
  .lr{opacity:0;animation:lrUp .8s cubic-bezier(.2,.7,.2,1) forwards;}
  .hl-ink{transform:translateY(105%);animation:inkUp .95s cubic-bezier(.16,.84,.28,1) forwards;}
  @keyframes lrUp{to{opacity:1;transform:none;}}
  @keyframes inkUp{to{transform:none;}}
}
.lr{will-change:opacity,transform;}

/* ---------- manifesto strip ---------- */
.manifesto{border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.manifesto .wrap{padding-top:clamp(64px,8vw,120px);padding-bottom:clamp(64px,8vw,120px);
  display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,5vw,64px);align-items:start;}
.manifesto .statement{font-family:var(--font-display);font-weight:600;letter-spacing:-.03em;
  font-size:clamp(2rem,4.6vw,4rem);line-height:1.06;color:var(--star);max-width:18ch;}
.manifesto .note{font-family:var(--font-mono);font-size:.8rem;line-height:1.9;color:var(--dust);max-width:30ch;padding-top:10px;}
.manifesto .note b{color:var(--accent);font-weight:500;}
@media(max-width:760px){.manifesto .wrap{grid-template-columns:1fr;}}

/* ---------- service INDEX (oversized rows) ---------- */
.index-list{border-top:1px solid var(--line-2);}
.index-row{display:grid;grid-template-columns:54px 1fr auto;gap:clamp(16px,3vw,40px);align-items:center;
  padding:clamp(22px,3vw,34px) 0;border-bottom:1px solid var(--line);position:relative;
  transition:padding-left .4s cubic-bezier(.2,.7,.2,1);color:inherit;}
.index-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);
  transform:scaleY(0);transform-origin:top;transition:transform .4s ease;}
.index-row:hover{padding-left:24px;}
.index-row:hover::before{transform:scaleY(1);}
.index-row .ix{font-family:var(--font-mono);font-size:.82rem;color:var(--dust);letter-spacing:.06em;}
.index-row .body-col{min-width:0;}
.index-row .nm{display:block;font-family:var(--font-display);font-weight:600;letter-spacing:-.025em;line-height:1.02;
  font-size:clamp(1.7rem,4vw,3rem);color:var(--star);transition:color .25s;}
.index-row:hover .nm{color:var(--accent);}
.index-row .ds{display:block;font-size:.96rem;color:var(--dust);margin-top:8px;max-width:54ch;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .4s ease, opacity .35s ease, margin-top .4s ease;}
.index-row:hover .ds{max-height:80px;opacity:1;}
.index-row .end{display:flex;align-items:center;gap:20px;}
.index-row .meta{font-family:var(--font-mono);font-size:.76rem;color:var(--dust);text-align:right;white-space:nowrap;letter-spacing:.04em;}
.index-row .go{font-family:var(--font-mono);color:var(--accent);opacity:0;transform:translateX(-6px);transition:.3s;}
.index-row:hover .go{opacity:1;transform:none;}
@media(max-width:680px){
  .index-row{grid-template-columns:38px 1fr;}
  .index-row .end{display:none;}
}

/* ---------- process (hairline steps) ---------- */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);}
.flow.five{grid-template-columns:repeat(5,1fr);}
.step{padding:22px clamp(14px,1.8vw,22px) 24px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;min-height:150px;position:relative;}
.step .num{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);letter-spacing:.12em;}
.step h3{font-size:1.12rem;}
.step p{margin:0;font-size:.92rem;color:var(--body);}
@media(max-width:1000px){.flow,.flow.five{grid-template-columns:repeat(2,1fr);}.step{border-right:1px solid var(--line);}}
/* ≤560px — steps become a numbered timeline (badge + title + text), no dangling arrows */
@media(max-width:560px){
  .section{padding:clamp(54px,13vw,80px) 0;}
  .flow,.flow.five{grid-template-columns:1fr;border-left:0;border-top:1px solid var(--line);}
  .step{
    display:grid;grid-template-columns:38px 1fr;column-gap:15px;row-gap:7px;
    align-items:start;min-height:0;padding:20px 2px 22px;
    border-right:0;border-bottom:1px solid var(--line);
  }
  .step .num{
    grid-column:1;grid-row:1;align-self:center;justify-self:start;
    display:inline-flex;align-items:center;justify-content:center;
    width:38px;height:38px;border:1px solid var(--line-2);border-radius:50%;
    font-size:.74rem;letter-spacing:.04em;
  }
  .step h3{grid-column:2;grid-row:1;align-self:center;font-size:1.08rem;}
  .step p{grid-column:2;grid-row:2;}
  .step svg.arrow{display:none;}
}

/* ---------- CTA band ---------- */
.cta-band{
  border: 1px solid var(--line-2);
  border-radius: var(--r);
  overflow: hidden;
  position: relative;
  background: rgba(8, 14, 26, 0.40);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding: clamp(44px,6vw,80px);
}
.cta-band::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(680px 320px at 92% 130%,rgba(63,208,230,.07),transparent 60%);}
.cta-band-inner{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:44px;flex-wrap:wrap;}
.cta-band h2{max-width:660px;}
.cta-band .sub{color:var(--body);margin:16px 0 0;max-width:540px;}

/* ---------- cards reused by inner pages ---------- */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.pillar{background:var(--abyss);padding:34px 28px 38px;display:flex;flex-direction:column;gap:14px;
  border-right:1px solid var(--line);transition:background .25s;}
.pillars .pillar:last-child{border-right:0;}
.pillar:hover{background:#0b1526;}
.pillar .pk{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;color:var(--dust);}
.pillar p{margin:0;font-size:.95rem;color:var(--body);}
.pillar .role{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);letter-spacing:.08em;margin-top:auto;}
.pillar.is-back .role{color:var(--dust);}
@media(max-width:900px){.pillars{grid-template-columns:repeat(2,1fr);}.pillar:nth-child(2){border-right:0;}.pillar:nth-child(-n+2){border-bottom:1px solid var(--line);}}
@media(max-width:560px){.pillars{grid-template-columns:1fr;}.pillar{border-right:0;border-bottom:1px solid var(--line);}}

.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.svc{background:linear-gradient(180deg,var(--abyss),#070d18);border:1px solid var(--line);border-radius:var(--r);
  padding:32px 30px;display:flex;flex-direction:column;gap:14px;transition:border-color .25s, transform .25s;}
.svc:hover{border-color:rgba(63,208,230,.32);transform:translateY(-3px);}
.svc .idx{font-family:var(--font-mono);font-size:.74rem;color:var(--dust);letter-spacing:.1em;}
.svc p{margin:0;font-size:.97rem;}
.svc .meta{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);letter-spacing:.05em;margin-top:6px;}
@media(max-width:760px){.svc-grid{grid-template-columns:1fr;}}

.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{font-family:var(--font-mono);font-size:.72rem;color:var(--body);border:1px solid var(--line);border-radius:999px;padding:5px 12px;background:rgba(12,20,38,.34);}

/* inner page service blocks */
.svc-block{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(28px,5vw,72px);
  padding:clamp(48px,6vw,80px) 0;border-top:1px solid var(--line);align-items:start;}
.svc-block:first-of-type{border-top:0;}
.svc-block .lead-num{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.16em;color:var(--accent);margin-bottom:16px;}
.svc-block h2{margin-bottom:18px;}
.svc-block .desc{color:var(--body);max-width:460px;}
.svc-foot{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;align-items:center;}
.incl{display:grid;gap:12px;margin:0;padding:0;list-style:none;}
.incl li{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;background:var(--abyss);border:1px solid var(--line);border-radius:var(--r);font-size:.96rem;color:var(--body);}
.incl li .mk{font-family:var(--font-mono);color:var(--accent);flex:none;margin-top:1px;}
@media(max-width:820px){.svc-block{grid-template-columns:1fr;gap:24px;}}

.motors{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.motor{background:linear-gradient(180deg,var(--abyss),#070d18);border:1px solid var(--line);border-radius:var(--r);padding:34px 32px;}
.motor .tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);}
.motor.warm .tag{color:var(--orange);}
.motor h3{margin:14px 0 12px;font-size:1.4rem;}
.motor p{margin:0;font-size:.96rem;}
.motor .rule-t{margin-top:20px;font-family:var(--font-mono);font-size:.82rem;color:var(--dust);border-top:1px solid var(--line);padding-top:16px;}
@media(max-width:700px){.motors{grid-template-columns:1fr;}}

/* diagram */
.diagram-wrap{display:grid;grid-template-columns:0.95fr 1.05fr;gap:clamp(28px,5vw,64px);align-items:center;}
.diagram{background:linear-gradient(180deg,var(--abyss),#070d18);border:1px solid var(--line);border-radius:var(--r);padding:30px;position:relative;overflow:hidden;}
.diagram .cap{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;color:var(--dust);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.diagram .cap .d{width:7px;height:7px;border-radius:50%;background:var(--blue);}
.diagram svg{width:100%;height:auto;display:block;}
.dg-box{fill:#0a1426;stroke:#22324d;stroke-width:1.5;}
.dg-box.hi{stroke:var(--blue);}
.dg-box.warm{stroke:var(--orange);}
.dg-t{fill:#e7eefb;font-family:'JetBrains Mono',monospace;font-size:11px;}
.dg-s{fill:#6b7a99;font-family:'JetBrains Mono',monospace;font-size:9px;}
.dg-line{stroke:#2a3a5e;stroke-width:1.5;fill:none;}
.dg-arrow{fill:#6b7a99;}
@media(max-width:820px){.diagram-wrap{grid-template-columns:1fr;}}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.note{background:var(--abyss);border:1px solid var(--line);border-radius:var(--r);padding:26px 28px;}
.note .k{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;}
.note h3{font-size:1.15rem;margin-bottom:8px;}
.note p{margin:0;font-size:.95rem;}
@media(max-width:700px){.grid-2{grid-template-columns:1fr;}}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 0.85fr;gap:clamp(32px,5vw,72px);align-items:start;}
.panel{background:linear-gradient(180deg,var(--abyss),#070d18);border:1px solid var(--line);border-radius:var(--r);padding:clamp(30px,4vw,44px);}
.form{display:grid;gap:18px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field label{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dust);}
.field input,.field textarea,.field select{background:var(--void);border:1px solid var(--line);border-radius:var(--r);
  color:var(--star);font-family:var(--font-body);font-size:1rem;padding:13px 15px;width:100%;transition:border-color .2s, box-shadow .2s;}
.field textarea{min-height:148px;resize:vertical;line-height:1.6;}
.field input::placeholder,.field textarea::placeholder{color:var(--dust);}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(63,208,230,.12);}
.field.invalid input,.field.invalid textarea{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,159,67,.12);}
.err-msg{font-family:var(--font-mono);font-size:.72rem;color:var(--orange);min-height:1em;}
.form-note{font-family:var(--font-mono);font-size:.76rem;color:var(--dust);}
.form-ok{display:none;align-items:center;gap:12px;padding:16px 18px;border-radius:var(--r);border:1px solid rgba(63,208,230,.4);background:rgba(63,208,230,.06);color:var(--star);font-size:.95rem;}
.form-ok.show{display:flex;}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}
.aside .blk{padding:22px 0;border-top:1px solid var(--line);}
.aside .blk:first-child{border-top:0;padding-top:0;}
.aside .k{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dust);margin-bottom:12px;}
.aside p{margin:0;font-size:.95rem;}
.aside a.mailrow{display:flex;align-items:center;gap:10px;color:var(--star);font-family:var(--font-mono);font-size:.92rem;padding:8px 0;transition:color .2s;}
.aside a.mailrow:hover{color:var(--accent);}
.aside a.mailrow .b{color:var(--accent);}
.promise{background:rgba(63,208,230,.05);border:1px solid rgba(63,208,230,.25);border-radius:var(--r);padding:22px 24px;margin-bottom:6px;}
.promise .t{font-family:var(--font-display);color:var(--star);font-size:1.15rem;line-height:1.3;letter-spacing:-.01em;}
.promise .s{font-family:var(--font-mono);font-size:.78rem;color:var(--blue);margin-top:10px;}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;}}

/* ---------- page hero (inner) ---------- */
.page-hero{padding:clamp(70px,9vw,128px) 0 clamp(30px,4vw,48px);position:relative;border-bottom:1px solid var(--line);}
.page-hero h1{font-size:clamp(2.6rem,5.4vw,4.6rem);margin:0 0 22px;}
.page-hero .lead{max-width:640px;}

/* ---------- ARTEMISA — gata ASCII (focused) ---------- */
.artemisa-sec{border-top:1px solid var(--line);background:
  radial-gradient(1100px 620px at 50% 8%, rgba(63,208,230,.045), transparent 62%), var(--abyss);}
.artemisa-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:clamp(34px,5vw,72px);align-items:center;}
.artemisa-copy .eyebrow{margin-bottom:18px;}
.artemisa-copy h2{margin:0 0 18px;}
.artemisa-copy .lead{max-width:42ch;}
.artemisa-meta{margin-top:30px;border-top:1px solid var(--line);}
.artemisa-meta .spec-row .sk{min-width:104px;}

/* terminal card holding the cat */
.cat-terminal{border:1px solid var(--line-2);border-radius:8px;overflow:hidden;
  background:linear-gradient(180deg, rgba(8,14,26,.9), rgba(4,6,12,.96));
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.03);}
.cat-term-bar{display:flex;align-items:center;gap:8px;padding:11px 15px;border-bottom:1px solid var(--line);
  background:rgba(4,6,12,.6);}
.cat-term-bar .dot{width:11px;height:11px;border-radius:50%;background:var(--line-2);flex:none;}
.cat-term-bar .dot.live{background:var(--orange);box-shadow:0 0 0 0 rgba(255,159,67,.5);animation:catlive 2.8s ease-out infinite;}
@keyframes catlive{0%{box-shadow:0 0 0 0 rgba(255,159,67,.45)}70%{box-shadow:0 0 0 7px rgba(255,159,67,0)}100%{box-shadow:0 0 0 0 rgba(255,159,67,0)}}
.cat-term-title{margin-left:8px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;color:var(--dust);}
.cat-term-title b{color:var(--blue);font-weight:500;}

.cat-stage{position:relative;padding:clamp(14px,2.4vw,26px) 0;width:100%;
  overflow:hidden;text-align:center;}
.cat-inner{position:relative;display:inline-block;text-align:left;}
.cat-art{margin:0;font-family:var(--font-mono);font-weight:500;font-size:var(--fs,9px);
  line-height:1.04em;letter-spacing:0;white-space:pre;color:var(--star);
  text-shadow:0 0 14px rgba(63,208,230,.10);}
#cat-base{position:relative;display:block;}
/* the head + tongue move together as a group */
.cat-head-grp{position:absolute;top:0;left:0;will-change:transform;transform-origin:42% 96%;
  animation:catdip 3.2s ease-in-out infinite;}
#cat-head{position:absolute;top:0;left:0;}
.cat-tongue{position:absolute;left:0;top:0;pointer-events:none;font-family:var(--font-mono);font-weight:700;
  color:var(--orange);opacity:0;transform-origin:top center;line-height:1em;
  text-shadow:0 0 7px rgba(255,159,67,.85);animation:cattongue 3.2s ease-in-out infinite;}

@keyframes catdip{
  0%,6%   {transform:translateY(0) rotate(0deg);}
  18%,58% {transform:translateY(1.05em) rotate(1.7deg);}
  76%,100%{transform:translateY(0) rotate(0deg);}
}
@keyframes cattongue{
  0%,16% {opacity:0;transform:scaleY(.5);}
  21%    {opacity:1;transform:scaleY(1.45);}
  29%    {opacity:.55;transform:scaleY(.7);}
  37%    {opacity:1;transform:scaleY(1.55);}
  45%    {opacity:.55;transform:scaleY(.7);}
  53%    {opacity:1;transform:scaleY(1.4);}
  59%,100%{opacity:0;transform:scaleY(.5);}
}
@media(prefers-reduced-motion:reduce){
  .cat-head-grp{animation:none;}
  .cat-tongue{animation:none;opacity:0;}
}

@media(max-width:900px){
  .artemisa-grid{grid-template-columns:1fr;gap:30px;}
  .artemisa-copy{order:2;}
}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);background:var(--abyss);padding:clamp(52px,6vw,80px) 0 40px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;}
.footer h4{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dust);margin:0 0 18px;font-weight:500;}
.footer a{color:var(--body);font-size:.95rem;display:block;padding:5px 0;transition:color .2s;}
.footer a:hover{color:var(--accent);}
.sig{font-family:var(--font-mono);font-size:.82rem;color:var(--dust);line-height:1.9;margin-top:18px;}
.sig b{color:var(--star);font-weight:500;}
.sig .blue{color:var(--blue);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  margin-top:48px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.74rem;color:var(--dust);letter-spacing:.04em;}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr;}.footer-grid .f-about{grid-column:1/-1;}}

/* ---------- mobile nav ---------- */
.nav-toggle{display:none;}
@media(max-width:860px){
  .nav-links{position:fixed;inset:var(--nav-h) 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;
    background:rgba(4,6,12,.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:8px var(--pad-x) 20px;
    transform:translateY(-130%);transition:transform .3s ease;}
  .nav-links.open{transform:translateY(0);}
  .nav-links a{padding:16px 0;width:100%;border-bottom:1px solid var(--line);font-size:1rem;}
  .nav-links a.active::after{display:none;}
  .nav-cta-desktop{display:none;}
  .nav-toggle{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
  .nav-toggle span{width:22px;height:2px;background:var(--star);transition:.25s;}
}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .lr{opacity:1 !important;animation:none !important;}
  .hl-ink{transform:none !important;animation:none !important;}
}

