/* ============================================================
   ithouse — Hosting page variations · shared styles
   Tokens lifted from the ithouse design system (dark default)
   ============================================================ */

@font-face{font-family:"Readex Pro";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("../fonts/readex-pro.woff2") format("woff2");font-feature-settings:"ss03" on;}
@font-face{font-family:"Stack Sans Headline";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("../fonts/stack-sans-headline.woff2") format("woff2");}
@font-face{font-family:"Google Sans Code";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("../fonts/google-sans-code.woff2") format("woff2");}
@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/space-grotesk-400.woff2") format("woff2");}
@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:500;font-display:swap;src:url("../fonts/space-grotesk-500.woff2") format("woff2");}
@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/space-grotesk-600.woff2") format("woff2");}


:root{
  --bg:#18181b; --bg-deep:#09090b;
  --fg:#ffffff;
  --fg-2:oklch(55.2% .016 285.938);   /* zinc-500 muted */
  --fg-3:oklch(70.5% .015 286.067);   /* zinc-400 secondary */
  --fg-4:oklch(87.1% .006 286.286);   /* zinc-300 near-primary */
  --primary:oklch(87% .08 210);
  --primary-hover:oklch(82% .1 210);
  --cyan:#93e3f1;
  --green:#6cefce;
  --card:#1e1e1e; --card-2:#212025;
  --hairline:rgba(255,255,255,.1);
  --wire:#3F3F46;
  --heading:"Stack Sans Headline",sans-serif;
  --sans:"Readex Pro",sans-serif;
  --mono:"Google Sans Code",Menlo,monospace;
  --mono-alt:"Departure Mono",Menlo,monospace;
  --numeric:"Space Grotesk",sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
}

.hv-page{width:100%;min-height:100%;background:var(--bg);color:var(--fg);
  font-family:var(--sans);letter-spacing:-.025em;position:relative;overflow:hidden;
  display:flex;flex-direction:column;}
.hv-page *{box-sizing:border-box;margin:0;}
.hv-page a{text-decoration:none;color:inherit;}
.hv-wrap{width:100%;max-width:1360px;margin:0 auto;padding:0 48px;position:relative;}

/* ------------------------------------------------ nav (original: logo pill left, nav pill right) */
.hv-nav{position:absolute;top:32px;left:0;right:0;z-index:50;
  display:flex;justify-content:center;}
.hv-nav-row{width:100%;max-width:1360px;padding:0 44px 0 40px;display:flex;justify-content:space-between;gap:16px;}
.hv-pill{display:flex;align-items:center;border-radius:8px;
  background:rgba(255,255,255,.02);backdrop-filter:blur(25px);}
.hv-pill-logo{display:flex;align-items:center;justify-content:center;padding:4px 8px;}
.hv-pill-logo img{height:24px;display:block;}
.hv-pill-nav{padding:4px;display:flex;align-items:center;gap:4px;}
.hv-nav-link{display:flex;align-items:center;justify-content:center;gap:4px;
  font-size:14px;font-weight:400;letter-spacing:-.025em;color:#fff;padding:10px;border-radius:4px;
  transition:background-color .2s var(--ease),color .2s var(--ease);cursor:pointer;line-height:1;}
.hv-nav-link:hover{background:var(--bg-deep);}
.hv-nav-link.open{background:var(--bg-deep);}
.hv-nav-link.open .hv-caret{transform:rotate(180deg);}
.hv-nav-link .hv-caret{transition:transform .2s var(--ease);}

/* ------------------------------------------------ desktop mega menu */
.hv-pill-nav{position:relative;}
.hv-mega-wrap{position:absolute;top:100%;right:0;padding-top:8px;z-index:1000;}
.hv-mega{display:flex;border-radius:8px;overflow:hidden;
  background:#09090B;
  border:1px solid rgba(255,255,255,.07);
  animation:hv-mega-in .18s var(--ease);}
@keyframes hv-mega-in{from{transform:translateY(-4px);}to{transform:none;}}
@media (prefers-reduced-motion: reduce){.hv-mega{animation:none;}}
.hv-mega-col{display:flex;flex-direction:column;gap:28px;padding:28px 32px;
  border-right:2px solid rgba(255,255,255,.06);min-width:280px;box-sizing:border-box;}
.hv-mega-col:last-child{border-right:none;}
.hv-mega-top{display:flex;flex-direction:column;gap:8px;min-height:100px;}
.hv-mega-head{display:flex;align-items:center;gap:8px;color:#fff;
  font-size:15px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  text-decoration:none;transition:color .2s var(--ease);width:fit-content;}
a.hv-mega-head:hover{color:var(--fg-3);}
.hv-mega-head svg{width:22px;height:22px;fill:currentColor;flex-shrink:0;}
.hv-mega-desc{font-size:15px;line-height:1.5;color:var(--fg-3);letter-spacing:-.015em;max-width:220px;}
.hv-mega-col.has-ghost .hv-mega-desc{max-width:258px;}
.hv-mega-body{display:flex;flex:1;justify-content:space-between;gap:16px;align-items:flex-end;}
.hv-mega-links{display:flex;flex-direction:column;gap:15px;padding-bottom:4px;align-self:flex-start;}
.hv-mega-links a{font-size:15px;color:#fff;letter-spacing:-.015em;white-space:nowrap;
  text-decoration:none;transition:color .2s var(--ease);}
.hv-mega-links a:hover{color:var(--fg-3);}
.hv-mega-img{flex-shrink:0;align-self:flex-end;}
.hv-mega-img img{display:block;object-fit:contain;}
.hv-mega-col.minis{justify-content:space-between;gap:24px;min-width:292px;}
.hv-mega-mini{display:flex;flex-direction:column;gap:8px;}
/* Hosting column — scattered cluster ghost (option A) */
.hv-mega-col.has-ghost{position:relative;min-width:316px;}
.hv-mega-ghost{position:absolute;right:24px;bottom:18px;width:170px;height:170px;pointer-events:none;
  -webkit-mask-image:linear-gradient(180deg,#000 55%,transparent 98%);
  mask-image:linear-gradient(180deg,#000 55%,transparent 98%);}
.hv-mega-ghost img,.hv-mega-ghost svg{position:absolute;display:block;}
.hv-mega-ghost .gwp{width:96px;top:4px;right:2px;opacity:.13;}
.hv-mega-ghost .gmg{width:70px;top:64px;left:0;opacity:.10;}
.hv-mega-ghost .gnd{width:62px;bottom:4px;right:38px;opacity:.08;}
.hv-mega-ghost .gps{width:44px;top:2px;left:10px;opacity:.06;}
.hv-mega-col.has-ghost .hv-mega-top,.hv-mega-col.has-ghost .hv-mega-body{position:relative;z-index:1;}
/* Security — mini live edge-security window */
.hv-mega-col.has-ghost:has(.hv-mega-secwin){min-width:382px;}
.hv-mega-secwin{position:absolute;right:20px;bottom:28px;width:196px;z-index:0;line-height:1.5;
  background:#0d0d10;border:1px solid rgba(255,255,255,.1);border-radius:8px;
  box-shadow:0 14px 36px rgba(0,0,0,.5);overflow:hidden;font-family:var(--mono);}
.msw-head{display:flex;align-items:center;gap:6px;padding:8px 11px;
  border-bottom:1px solid rgba(255,255,255,.07);
  font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);}
.msw-dot{width:6px;height:6px;border-radius:99px;background:var(--green);
  animation:w1-pulse 2.2s var(--ease) infinite;}
.msw-row{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:7px 11px;border-bottom:1px solid rgba(255,255,255,.04);
  font-size:10px;letter-spacing:0;color:var(--fg-3);
  animation:msw-row 7s var(--ease) infinite;}
.msw-row:last-child{border-bottom:none;}
.msw-row:nth-child(2){animation-delay:.2s;}
.msw-row:nth-child(3){animation-delay:1.6s;}
.msw-row:nth-child(4){animation-delay:3s;}
.msw-row:nth-child(5){animation-delay:4.4s;}
.msw-row .pill{font-size:8.5px;font-weight:500;padding:1.5px 7px;border-radius:99px;flex-shrink:0;}
.msw-row .pill.block{background:rgba(246,120,143,.1);border:1px solid rgba(246,120,143,.3);color:#f6788f;}
.msw-row .pill.chal{background:rgba(246,170,80,.1);border:1px solid rgba(246,170,80,.3);color:#f6aa50;}
.msw-row .pill.allow{background:rgba(108,239,206,.08);border:1px solid rgba(108,239,206,.25);color:var(--green);}
@keyframes msw-row{0%{opacity:0;transform:translateY(4px);}5%{opacity:1;transform:none;}94%{opacity:1;}100%{opacity:0;}}
@media (prefers-reduced-motion: reduce){.msw-row{animation:none;}.msw-dot{animation:none;}}
/* Compliance — badge cluster */
.hv-mega-ghost.ghost-comp .ggdpr2{width:84px;top:4px;right:4px;opacity:.22;}
.hv-mega-ghost.ghost-comp .gsoc{width:60px;top:72px;left:6px;opacity:.12;}
.hv-mega-ghost.ghost-comp .ggdpr{width:60px;bottom:6px;right:42px;opacity:.12;}
.hv-nav-link .hv-caret{width:16px;height:16px;fill:currentColor;flex-shrink:0;margin:-4px 0;}
.hv-nav-contact, .hv-page a.hv-nav-contact{display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:400;letter-spacing:-.025em;line-height:1;
  background:#fff;color:#18181b;padding:10px;border-radius:4px;cursor:pointer;
  transition:background-color .2s var(--ease),color .2s var(--ease);}
.hv-nav-contact:hover{background:oklch(96.7% .001 286.375);color:#000;}
.hv-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  border-radius:4px;font-family:var(--sans);font-weight:500;letter-spacing:-.025em;
  transition:background-color .2s var(--ease),color .2s var(--ease);border:none;}
.hv-btn svg{width:13px;height:13px;flex-shrink:0;transition:transform .2s var(--ease);}
.hv-btn:hover svg{transform:translate(2px,-2px);}
.hv-btn-primary, .hv-page a.hv-btn-primary{background:var(--primary);color:#18181b;}
.hv-btn-primary:hover, .hv-page a.hv-btn-primary:hover{background:var(--primary-hover);color:#000;}
.hv-btn-secondary, .hv-page a.hv-btn-secondary{background:#fff;color:#18181b;}
.hv-btn-secondary:hover, .hv-page a.hv-btn-secondary:hover{background:oklch(96.7% .001 286.375);}
.hv-btn-ghost, .hv-page a.hv-btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:6px;}
.hv-btn-ghost:hover, .hv-page a.hv-btn-ghost:hover{background:rgba(255,255,255,.12);}
.hv-btn-sm{padding:7px 14px;font-size:15px;}
.hv-btn-md{padding:12px 18px;font-size:17px;}
.hv-btn-lg{padding:14px 22px;font-size:19px;}

/* ------------------------------------------------ type helpers */
.hv-eyebrow{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.025em;color:var(--fg-3);}
.hv-eyebrow .dot{color:var(--fg-2);padding:0 6px;}
.hv-h1{font-family:var(--heading);font-weight:600;font-size:72px;line-height:1.02;letter-spacing:-.04em;}
.hv-h2{font-family:var(--heading);font-weight:600;font-size:48px;line-height:1.1;letter-spacing:-.025em;}
.hv-h3{font-family:var(--heading);font-weight:600;font-size:24px;line-height:1.2;letter-spacing:-.025em;}
.hv-lead{font-size:22px;line-height:1.45;color:rgba(255,255,255,.75);font-weight:400;}
.hv-body{font-size:16px;line-height:1.55;color:var(--fg-3);}
.hv-body strong, .hv-lead strong{font-weight:700;color:#fff;}
.hv-small{font-size:14px;line-height:1.5;color:var(--fg-2);}
.hv-mono{font-family:var(--mono);font-size:13px;letter-spacing:0;color:var(--fg-3);}
.hv-mono-label{font-family:var(--numeric);font-weight:500;font-size:11.5px;letter-spacing:.14em;color:rgba(255,255,255,.42);text-transform:uppercase;}

/* ------------------------------------------------ icons */
.hv-icon{width:20px;height:20px;fill:currentColor;flex-shrink:0;}
.hv-tick{width:16px;height:16px;flex-shrink:0;fill:none;stroke:var(--cyan);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}

/* ------------------------------------------------ platform logo tile */
.hv-logo-tile{display:flex;align-items:center;justify-content:center;background:#1e1e1e;
  border:1px solid rgba(255,255,255,.07);border-radius:8px;flex-shrink:0;}
.hv-logo-tile img{display:block;}

/* ------------------------------------------------ image placeholder */
.hv-ph{position:relative;background:#161618;border:1px dashed rgba(255,255,255,.14);border-radius:8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;overflow:hidden;}
.hv-ph svg{width:22px;height:22px;fill:none;stroke:rgba(255,255,255,.3);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
.hv-ph span{font-family:var(--mono-alt);font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.35);text-transform:uppercase;}

/* ------------------------------------------------ app-logo marquee (V1 hero) */
.hv-mq-wrap{position:relative;width:480px;height:380px;flex-shrink:0;overflow:hidden;}
.hv-mq-rows{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:20px;}
.hv-mq{overflow:hidden;display:flex;width:100%;}
.hv-mq-track{display:flex;flex-shrink:0;animation:hv-mq-slide var(--mq-dur,36s) linear infinite;will-change:transform;backface-visibility:hidden;}
.hv-mq.rev .hv-mq-track{animation-direction:reverse;}
.hv-mq-group{display:flex;gap:16px;padding-right:16px;flex-shrink:0;}
.hv-mq-card{width:68px;height:68px;background:#1e1e1e;border:1px solid rgba(255,255,255,.07);border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hv-mq-card img{max-width:36px;max-height:36px;}
.hv-mq-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;
  width:100px;height:100px;background:#09090b;border:4px solid #3F3F46;border-radius:18px;
  display:flex;align-items:center;justify-content:center;box-shadow:0 12px 32px rgba(0,0,0,.45);}
.hv-mq-fade{position:absolute;inset:-2px;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, #18181b 0%, rgba(24,24,27,0) 16%, rgba(24,24,27,0) 84%, #18181b 100%),
    radial-gradient(ellipse 62% 62% at 50% 50%, rgba(24,24,27,0) 30%, rgba(24,24,27,.65) 62%, #18181b 94%);}
@keyframes hv-mq-slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.hv-mq-track{animation:none;}}

/* ------------------------------------------------ footer */
.hv-footer{border-top:1px solid var(--hairline);margin-top:auto;}
.hv-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding:64px 0 48px;}
.hv-footer h4{font-size:15px;font-weight:600;color:#fff;margin-bottom:14px;letter-spacing:-.025em;}
.hv-footer ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;}
.hv-footer ul a{font-size:15px;color:var(--fg-3);transition:color .2s var(--ease);}
.hv-footer ul a:hover{color:#fff;}
.hv-footer-bottom{display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--hairline);padding:20px 0 28px;}
.hv-status{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--fg-3);}
.hv-status i{width:8px;height:8px;border-radius:99px;background:var(--green);
  box-shadow:0 0 8px rgba(108,239,206,.7);}

/* ------------------------------------------------ mobile nav (hidden by default; activated by responsive.css) */
.hv-nav-mbar{display:none;}
.hv-nav-sheet{display:none;}
.hv-nav-burger{display:none;}

/* ------------------------------------------------ misc shared */
.hv-hr{border:none;border-top:1px solid var(--hairline);}
.hv-badge-row{display:flex;align-items:center;gap:36px;}
.hv-badge-row img{height:44px;width:auto;opacity:.85;}
.hv-arrow-link{display:inline-flex;align-items:center;gap:8px;font-weight:500;color:var(--cyan);
  font-size:16px;transition:color .2s var(--ease);cursor:pointer;}
.hv-arrow-link svg{width:13px;height:13px;fill:currentColor;transition:transform .2s var(--ease);}
.hv-arrow-link:hover svg{transform:translate(2px,-2px);}
