:root{
  --bg:#07090c;
  --text:#e9eef6;
  --muted:#b6c2d6;
  --line:rgba(255,255,255,.10);
  --line2:rgba(255,255,255,.08);
  --accent:rgba(110,168,255,.95);
  --accent2:rgba(124,241,200,.85);
  --accent-y:#f7c84b;
  --accent-y-soft:rgba(247,200,75,.22);
  --shadow: 0 18px 42px rgba(0,0,0,.45);
  --container:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 10% 10%, rgba(110,168,255,.12), transparent 55%),
    radial-gradient(1000px 600px at 85% 15%, rgba(124,241,200,.10), transparent 50%),
    radial-gradient(900px 520px at 70% 0%, rgba(247,200,75,.08), transparent 55%),
    linear-gradient(180deg, var(--bg), #0b0d10);
  line-height:1.55;
}

a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.small{font-size:12px}

.container{width:min(var(--container), calc(100% - 40px)); margin:0 auto;}

.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip-link:focus{
  left:16px; top:16px; width:auto;height:auto;
  padding:10px 12px; background:#111827; border:1px solid var(--line);
  border-radius:12px; z-index:9999;
}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:1000;
  background: rgba(7,9,12,.72);
  border-bottom:1px solid var(--line2);
  backdrop-filter: blur(10px);
}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:16px;}
.brand{display:flex; align-items:center; gap:12px;}
.brand-mark{
  width:42px;height:42px;border-radius:14px;
}
.brand-text{display:flex;flex-direction:column;gap:2px}
.brand-name{font-weight:800;letter-spacing:-.01em}
.brand-tagline{font-size:12px;color:var(--muted)}
.topnav{display:flex;gap:18px;align-items:center}
.navlink{color:var(--muted)}
.navlink:hover{color:var(--text);text-decoration:none}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px; border-radius:14px;
  border:1px solid var(--line);
  background: linear-gradient(135deg, rgba(110,168,255,.22), rgba(124,241,200,.14), var(--accent-y-soft));
  color:var(--text);
  font-weight:700; cursor:pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}
.btn:hover{border-color:rgba(255,255,255,.20); text-decoration:none}
.btn-small{padding:10px 12px;border-radius:12px}
.btn-ghost{background: rgba(255,255,255,.04); box-shadow:none}
.btn:hover{
  border-color: rgba(247,200,75,.45);
}

/* Hero */
.hero{padding:54px 0 18px 0;}
.hero-inner{display:grid; grid-template-columns: 1.05fr .95fr; gap:22px; align-items:start;}
h1{margin:0 0 12px 0; font-size: clamp(34px, 4.2vw, 54px); line-height:1.05; letter-spacing:-.03em;}
.lead{margin:0 0 18px 0; color:var(--muted); font-size: clamp(16px, 1.8vw, 18px); max-width:70ch;}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin:10px 0 16px 0;}
.kpi-row{display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; margin:10px 0 10px 0;}
.kpi{border:1px solid var(--line); background: rgba(255,255,255,.03); border-radius: 16px; padding:12px;}
.kpi-label{font-size:12px;color:var(--muted);margin-bottom:6px;}
.kpi-value{font-weight:800;letter-spacing:-.01em}
.hint{font-size:12px;color:var(--muted);opacity:.9;margin-top:10px}

/* Frame */
.frame{
  border-radius: 24px;
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.frame-top{display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid var(--line2); background: rgba(0,0,0,.18);}
.dots{display:flex;gap:6px}
.dots span{width:10px;height:10px;border-radius:999px;background:rgba(255,255,255,.12);}
.frame-title{font-size:12px;color:var(--muted);font-weight:700}
.frame-actions{color:rgba(255,255,255,.45)}
.frame-body{padding:14px}
.frame-foot{padding:12px 14px;border-top:1px solid var(--line2);color:var(--muted);font-size:12px;background:rgba(0,0,0,.12)}

.bento{display:grid; grid-template-columns: 1fr 1fr; gap:10px;}
.widget{ text-align:left; border:1px solid var(--line); background: rgba(0,0,0,.18); border-radius: 18px; padding:12px;}
.widget-h{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:8px}
.widget-v{font-weight:900;letter-spacing:-.02em;font-size:22px}
.widget-s{color:var(--muted);font-size:12px;margin-top:6px}
.widget-chart{grid-column:1 / -1}
.mini-chart{
  height:130px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background: transparent;
  position: relative;
  overflow:hidden;
}
.widget-proof{grid-column:1 / -1; cursor:pointer;}
.widget-proof:hover{border-color:rgba(255,255,255,.20)}
.proof-grid{display:grid; grid-template-columns: 1fr 1fr; gap:8px;}
.proof-grid img{width:100%; height:86px; object-fit:cover; border-radius: 14px; border:1px solid rgba(255,255,255,.08);}

/* Scrolly */
.scrolly{padding:26px 0 56px 0;}
.scrolly-inner{display:grid; grid-template-columns: 380px 1fr; gap:18px; align-items:start;}
.pinned{position:sticky; top:86px;}
.pinned-card{border-radius: 24px; border:1px solid var(--line); background: rgba(255,255,255,.03); padding:16px; box-shadow: var(--shadow);}
.pinned-kicker{font-size:12px; color:var(--muted); font-weight:800; letter-spacing:.06em; text-transform:uppercase; margin-bottom:10px;}
.pinned h2{margin:0 0 10px 0; font-size:22px; letter-spacing:-.02em; line-height:1.2;}
.pin-bullets{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 14px 0}
.bullet{font-size:12px;padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.16);color:var(--muted);}
.pin-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.pin-mini{margin-top:12px;border-radius: 20px;border:1px solid var(--line2);background: rgba(0,0,0,.12);padding:12px;}
.mini-label{font-size:12px;color:var(--muted);font-weight:800;margin-bottom:10px}
.mini-list{display:grid;gap:8px}
.mini-item{border:1px solid rgba(255,255,255,.08);background: rgba(255,255,255,.02);border-radius: 14px;padding:10px;color:var(--muted);font-size:12px;}

.steps{display:grid; gap:14px;}
.step{scroll-margin-top:90px;}
.step-card{border-radius: 24px; border:1px solid var(--line); background: rgba(255,255,255,.03); padding:16px;}
.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.16);color:var(--muted);font-size:12px;font-weight:800;margin-bottom:10px;}
.step-card h3{margin:0 0 6px 0;letter-spacing:-.02em}
.step-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap:12px; margin-top:12px;}
.panel{border-radius: 20px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);padding:12px;}
.panel h4{margin:0 0 6px 0;letter-spacing:-.01em}
.panel p{margin:0 0 10px 0}
.panel ul{margin:0; padding-left:18px; color:var(--muted)}
.panel li{margin:6px 0}
.timeline{margin:10px 0 0 0; padding-left:18px; color:var(--muted)}
.timeline li{margin:10px 0}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{font-size:12px; padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.16);color:var(--muted);}

.callout{margin-top:12px;border-radius: 20px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);padding:12px;}
.callout-title{font-size:12px;color:var(--muted);font-weight:800;margin-bottom:10px}
.callout-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:10px}
.callout-item{border-radius: 16px;border:1px solid rgba(255,255,255,.08);background: rgba(255,255,255,.02);padding:10px;color:var(--muted);font-size:12px;}

.out-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}
.out{border-radius: 20px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);padding:12px;}
.out-h{font-weight:900;letter-spacing:-.01em;margin-bottom:6px}

/* Contact */
.contact-grid{display:grid; grid-template-columns: .95fr 1.05fr; gap:12px; margin-top:12px;}
.contact-direct{display:grid;gap:10px}
.contact-card{border-radius: 20px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);padding:12px;}
.contact-label{font-size:12px;color:var(--muted);font-weight:800;margin-bottom:6px}
.contact-value a{font-weight:900;letter-spacing:-.01em}
.contact-note{font-size:12px;color:var(--muted);margin-top:6px}

.form{border-radius: 20px;border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);padding:12px;}
.form h4{margin:0 0 10px 0}
label{display:block;font-size:12px;color:var(--muted);margin:10px 0}
input, textarea{width:100%; margin-top:8px; padding:12px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.18); color:var(--text); outline:none;}
input:focus, textarea:focus{border-color: rgba(110,168,255,.55)}
.hp{position:absolute !important; left:-9999px !important; width:1px !important; height:1px !important; overflow:hidden !important;}

/* Footer */
.footer{border-top:1px solid var(--line2); background: rgba(7,9,12,.85);}
.footer-inner{padding:18px 0; display:flex; align-items:center; justify-content:space-between; gap:12px; color:var(--muted); flex-wrap:wrap;}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
.footer-links a{color:var(--muted)}
.footer-links a:hover{color:var(--text);text-decoration:none}

/* Modal */
.modal{position:fixed;inset:0;z-index:2000}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.66)}
.modal-card{
  position:relative; width:min(1100px, calc(100% - 32px));
  margin: 56px auto; border-radius: 24px; border:1px solid var(--line);
  background: rgba(12,17,25,.95); box-shadow: var(--shadow); overflow:hidden;
}
.modal-top{display:flex;align-items:center;justify-content:space-between; padding:12px 14px;border-bottom:1px solid var(--line2);}
.modal-title{font-weight:900;letter-spacing:-.01em}
.iconbtn{width:38px;height:38px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background: rgba(255,255,255,.04);color:var(--text);cursor:pointer;}
.iconbtn:hover{border-color:rgba(255,255,255,.20)}
.modal-body{display:grid; grid-template-columns: 220px 1fr; gap:12px; padding:12px;}
.gallery{display:grid;gap:10px;align-content:start}
.thumb{border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);border-radius: 16px;padding:6px;cursor:pointer;}
.thumb:hover{border-color:rgba(255,255,255,.20)}
.thumb img{width:100%; height:92px; object-fit:cover; border-radius: 12px; display:block;}
.viewer{border:1px solid rgba(255,255,255,.10);background: rgba(0,0,0,.14);border-radius: 16px;overflow:hidden;}
.viewer-top{display:flex;align-items:center;justify-content:space-between; padding:10px 10px;border-bottom:1px solid rgba(255,255,255,.08);}
.viewer-actions{display:flex;gap:8px;flex-wrap:wrap}
.viewport{height: 560px; background: #05070a; position:relative; overflow:hidden; cursor:grab;}
.viewport.grabbing{cursor:grabbing}
.viewport img{
  position:absolute; top:50%; left:50%;
  transform: translate(-50%, -50%) scale(1);
  transform-origin: center;
  user-select:none; -webkit-user-drag:none;
  max-width:none; max-height:none;
}
.modal-foot{padding:10px 14px;border-top:1px solid var(--line2)}

/* Responsive */
@media (max-width: 1020px){
  .hero-inner{grid-template-columns:1fr;}
  .scrolly-inner{grid-template-columns:1fr;}
  .pinned{position:relative; top:0;}
  .step-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .modal-body{grid-template-columns: 160px 1fr;}
  .viewport{height:420px;}
  .topnav{display:none;}
}

/* Nav active state */
.navlink.active{
  color: var(--text);
  text-decoration:none;
  position: relative;
}
.navlink.active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-10px;
  height:2px;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(110,168,255,.75), rgba(247,200,75,.75));
  opacity:.9;
}
.navlink-cta.active::after{
  display: none;
}

/* Mobile bottom nav */
.mobile-nav{
  position: fixed;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  display: none;
  gap: 6px;
  padding: 8px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(7,9,12,0.85);
  backdrop-filter: blur(10px);
  z-index: 1200;
  box-shadow: 0 16px 50px rgba(0,0,0,0.45);
}
.mobile-nav .navlink{
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 8px 10px;
  border-radius: 12px;
  font-size: 12px;
  color: rgba(255,255,255,0.78);
  text-decoration: none;
}
.mobile-nav .navlink.active{
  color: var(--text);
  background: rgba(255,255,255,0.06);
  box-shadow: inset 0 -2px 0 rgba(247,200,75,.9);
}
.mobile-nav .navlink-cta{
  background: linear-gradient(135deg, rgba(110,168,255,.20), rgba(124,241,200,.12), rgba(247,200,75,.20));
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--text);
  font-weight: 700;
}
.mobile-nav .navlink-cta.active{
  background: linear-gradient(135deg, rgba(110,168,255,.28), rgba(124,241,200,.18), rgba(247,200,75,.28));
}
@media (max-width: 720px){
  .mobile-nav{
    display: flex;
  }
  body{
    padding-bottom: 86px;
  }
}

/* Form additions */
select{
  width:100%;
  margin-top:8px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
  appearance: none;
}
select:focus{border-color: rgba(110,168,255,.55)}
.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.section-cta{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
@media (max-width: 1020px){
  .form-grid{grid-template-columns:1fr;}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition:none !important; animation:none !important;}
}

.proof-grid picture{display:block}
.proof-grid picture img{width:100%; height:86px; object-fit:cover; border-radius: 14px; border:1px solid rgba(255,255,255,.08);}

/* Section icons (mono, inherits theme) */
/* Section heading icon (inline, no chip) */
.section-ico{
  display:inline-flex;
  width: 22px;
  height: 22px;
  margin-right: 8px;
  color: rgba(247,200,75,0.85);
  vertical-align: -3px;
}
.section-ico svg{
  width: 22px;
  height: 22px;
  display:block;
}
.badge-ico{
  display:inline-flex;
  width:18px;
  height:18px;
  opacity:.95;
}
.badge-ico svg{
  width:18px;
  height:18px;
  display:block;
}

/* Small mono tokens for operational metrics */
.mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  letter-spacing: .01em;
}

/* Logo in header */
.brand-mark{
  display:grid;
  place-items:center;
  overflow:hidden;
}
.brand-mark picture, .brand-mark img{
  width:100%;
  height:100%;
  display:block;
}
.brand-mark img{
  object-fit:contain;
  padding:4px; /* breathing room */
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.35));
}


/* ===========================
   HUD layers (light + medium)
   =========================== */

:root{
  --hud-line: rgba(255,255,255,0.10);
  --hud-line-2: rgba(255,255,255,0.06);
  --hud-grid: rgba(255,255,255,0.04);
  --hud-scan: rgba(255,255,255,0.035);
  --hud-glow: rgba(110,168,255,0.18);
}

/* Light HUD: subtle instrumentation finish for the whole page */
.hud-light .card,
.hud-light .step-card,
.hud-light .frame,
.hud-light .modal-card,
.hud-light .widget{
  position: relative;
  overflow: hidden;
}

.hud-light .card::before,
.hud-light .step-card::before,
.hud-light .frame::before,
.hud-light .modal-card::before,
.hud-light .widget::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  background:
    radial-gradient(100% 140% at 50% 0%, rgba(110,168,255,0.10), transparent 55%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.02) 0 1px, transparent 1px 30px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.015) 0 1px, transparent 1px 30px);
  opacity: .35;
  mix-blend-mode: normal;
}

/* Medium HUD: hero + demo areas feel like an ops console */
.hud-medium{
  position: relative;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.10) inset,
    0 0 0 2px rgba(0,0,0,0.28) inset,
    0 18px 60px rgba(0,0,0,0.55);
}

.hud-medium::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  pointer-events:none;
  background:
    radial-gradient(120% 180% at 30% -20%, var(--hud-glow), transparent 55%),
    repeating-linear-gradient(0deg, var(--hud-scan) 0 1px, transparent 1px 6px),
    repeating-linear-gradient(90deg, var(--hud-grid) 0 1px, transparent 1px 28px);
  opacity: .55;
}

.hud-medium::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  background:
    /* corner brackets */
    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px top 14px/18px 2px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px top 14px/2px 18px no-repeat,

    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px top 14px/18px 2px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px top 14px/2px 18px no-repeat,

    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px bottom 14px/18px 2px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px bottom 14px/2px 18px no-repeat,

    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px bottom 14px/18px 2px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px bottom 14px/2px 18px no-repeat;
  opacity:.35;
  filter: drop-shadow(0 0 12px rgba(110,168,255,0.25));
}

/* Telemetry strip (medium HUD) */
.hero .frame.hud-medium .frame-top{
  position: relative;
}

/* Ensure content stays above HUD layers */
.hud-light .card > *,
.hud-light .step-card > *,
.hud-light .frame > *,
.hud-light .modal-card > *,
.hud-light .widget > *{
  position: relative;
  z-index: 1;
}

/* Slightly sharper widgets inside medium HUD */
.hero .frame.hud-medium .widget{
  box-shadow: 0 0 0 1px rgba(255,255,255,0.10) inset;
}


/* ===========================
   HUD tuning (more visible)
   =========================== */
@keyframes hudScan {
  0% { background-position: 0 0, 0 0, 0 0; }
  100% { background-position: 0 120px, 0 0, 0 0; }
}

/* Make medium HUD clearly distinct */
.hud-medium::before{
  opacity: .75;
  animation: hudScan 8s linear infinite;
}

.hud-medium::after{
  opacity: .60;
}

/* Bigger, clearer brackets */
.hud-medium::after{
  background:
    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px top 14px/26px 3px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px top 14px/3px 26px no-repeat,

    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px top 14px/26px 3px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px top 14px/3px 26px no-repeat,

    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px bottom 14px/26px 3px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) left 14px bottom 14px/3px 26px no-repeat,

    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px bottom 14px/26px 3px no-repeat,
    linear-gradient(var(--hud-accent), var(--hud-accent)) right 14px bottom 14px/3px 26px no-repeat,

    /* subtle top/bottom rails */
    linear-gradient(90deg, rgba(110,168,255,0.0), rgba(110,168,255,0.45), rgba(110,168,255,0.0)) left 0 top 0/100% 1px no-repeat,
    linear-gradient(90deg, rgba(110,168,255,0.0), rgba(110,168,255,0.30), rgba(110,168,255,0.0)) left 0 bottom 0/100% 1px no-repeat;
}

/* Stronger title bar for HUD surfaces */
.hero .frame.hud-medium .frame-top{
  background: linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.18));
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* Widgets inside medium HUD: more instrument-panel feel */
.hero .frame.hud-medium .widget{
  border-color: rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.22);
}
.hero .frame.hud-medium .widget::before{
  opacity: .18;
}


/* ===========================
   Mobile modal viewer (full-screen + filmstrip)
   =========================== */

.icon-btn{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.28);
  color: rgba(255,255,255,0.75);
  font-weight: 700;
  display:grid;
  place-items:center;
}
.icon-btn:hover{ background: rgba(0,0,0,0.38); }

.modal-card{ position: relative; }

.modal-tip{
  position:absolute;
  top:56px;
  right:16px;
  left:16px;
  z-index: 6;
  pointer-events:none;
}
.modal-tip-inner{
  pointer-events:auto;
  max-width: 520px;
  margin-left:auto;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 60px rgba(0,0,0,0.6);
}
.modal-tip .tip-title{
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.72);
}
.modal-tip .tip-body{
  margin-top: 2px;
  font-size: 13px;
  color: rgba(255,255,255,0.80);
}

@media (max-width: 720px){
  /* Full-screen feel */
  .modal{
    padding: 0;
  }
  .modal-card{
    width: 100%;
    height: 100vh;
    border-radius: 0;
  }
  .modal-head{
    padding: 12px 12px 8px 12px;
  }
  .modal-title{
    font-size: 16px;
  }

  /* Body: viewer on top, filmstrip bottom */
  .modal-body{
    grid-template-columns: 1fr !important;
    grid-template-rows: 1fr auto;
    gap: 10px;
    padding: 10px 12px 12px 12px;
  }

  /* Gallery becomes bottom filmstrip */
  .gallery{
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 130px;
    gap: 10px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    align-content: start;
  }
  .thumb{
    scroll-snap-align: start;
  }
  .thumb img{
    height: 78px;
  }

  /* Hide the desktop instruction line; use help button */
  .modal-instructions{
    display:none;
  }

  /* Float controls over the viewer */
  .controls{
    position: absolute;
    top: 70px;
    right: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 5;
  }
  .controls .btn{
    padding: 10px 12px;
    border-radius: 14px;
  }

  #viewport{
    border-radius: 18px;
    min-height: 55vh;
  }
}


/* ===========================
   Mobile modal viewer v2 (match current markup)
   =========================== */

@media (max-width: 720px){
  /* modal container: stretch full-screen */
  .modal{
    padding: 0 !important;
    align-items: stretch !important;
    justify-content: stretch !important;
  }
  .modal-card{
    width: 100% !important;
    height: 100vh !important;
    max-width: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  .modal-top{
    padding: 12px 12px 8px 12px !important;
  }
  .modal-title{
    font-size: 16px !important;
  }

  /* Body becomes column: viewer first, filmstrip bottom */
  .modal-body{
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding: 10px 12px 12px 12px !important;
    height: calc(100vh - 56px) !important;
  }

  .viewer{
    order: 1;
    flex: 1 1 auto;
    min-height: 50vh;
  }
  .gallery{
    order: 2;
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: 130px !important;
    gap: 10px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding-bottom: 6px !important;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .thumb{ scroll-snap-align: start; }
  .thumb img{ height: 78px !important; }

  /* Hide desktop instruction line on mobile */
  .modal-instructions{ display:none !important; }

  /* Floating zoom actions */
  .viewer-top{
    height: 0;
    padding: 0;
    margin: 0;
  }
  .viewer-actions{
    position: absolute !important;
    top: 70px !important;
    right: 12px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    z-index: 6 !important;
  }

  .viewport{
    border-radius: 18px !important;
    height: 100% !important;
  }

  /* Tip overlay position */
  .modal-tip{
    top: 60px;
    left: 12px;
    right: 12px;
  }
}

/* Tip + help button styles (works on all sizes) */
.modal-tip{
  position:absolute;
  top:56px;
  left:16px;
  right:16px;
  z-index: 8;
  pointer-events:none;
}
.modal-tip-inner{
  pointer-events:auto;
  max-width: 520px;
  margin-left:auto;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 60px rgba(0,0,0,0.6);
}
.modal-tip .tip-title{
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.72);
}
.modal-tip .tip-body{
  margin-top: 2px;
  font-size: 13px;
  color: rgba(255,255,255,0.80);
}


/* ===========================
   Mobile modal controls visibility (v3)
   =========================== */
.viewer{ position: relative; overflow: visible; }
.viewport{ position: relative; z-index: 1; }

.viewer-actions{
  z-index: 20 !important;
  pointer-events: auto;
}

.viewer-actions .btn{
  background: rgba(0,0,0,0.68) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  box-shadow:
    0 10px 24px rgba(0,0,0,0.55),
    0 0 0 1px rgba(110,168,255,0.14) inset;
  color: rgba(255,255,255,0.92) !important;
}

.viewer-actions .btn:hover{
  background: rgba(0,0,0,0.78) !important;
  border-color: rgba(255,255,255,0.26) !important;
}

@media (max-width: 720px){
  .viewer-actions{
    top: 12px !important; /* clear header */
    right: 12px !important;
    flex-direction: row !important;
  }
}


/* ===========================
   Select dropdown readability
   =========================== */
.form select{
  color: rgba(255,255,255,0.92);
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 14px;
  padding: 12px 14px;
  line-height: 1.25;
  font-size: 14px;
}

.form select:focus{
  outline: none;
  border-color: rgba(110,168,255,0.55);
  box-shadow: 0 0 0 3px rgba(110,168,255,0.18);
}

/* Try to improve the dropdown list in browsers that support styling <option> */
.form select option,
.form select optgroup{
  background: #0b0f14;
  color: rgba(255,255,255,0.92);
}

/* Add breathing room per item (supported in Chromium; safe elsewhere) */
.form select option{
  padding: 10px 12px;
}

/* Selected/hover (best-effort; varies by browser) */
.form select option:checked{
  background: rgba(110,168,255,0.35);
  color: #fff;
}
.form select option:hover{
  background: rgba(255,255,255,0.12);
}

/* Placeholder option (first item) slightly dim */
.form select option[disabled]{
  color: rgba(255,255,255,0.55);
}


/* ===========================
   Contact section improvements
   =========================== */

/* Make the form the hero, contact details secondary */
.contact-grid{
  grid-template-columns: 1.35fr 0.65fr;
  gap: 18px;
  align-items: start;
}

/* Form card: more breathing room */
.form.card{
  padding: 26px 26px 22px;
}

/* Improve form rhythm */
.form label{
  display:block;
  margin: 10px 0 6px;
  font-size: 12px;
  letter-spacing: .04em;
  color: rgba(255,255,255,0.72);
}
.form .row{
  gap: 14px;
}
.form input,
.form select,
.form textarea{
  min-height: 46px;
  padding: 12px 14px;
}
.form textarea{
  min-height: 140px;
  resize: vertical;
}
.form .btn{
  width: 100%;
  margin-top: 12px;
}

/* Optional details disclosure */
.form details.optional{
  margin-top: 10px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  background: rgba(0,0,0,0.16);
  padding: 10px 12px 12px;
}
.form details.optional > summary{
  cursor: pointer;
  user-select: none;
  list-style: none;
  font-weight: 800;
  color: rgba(255,255,255,0.78);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.form details.optional > summary .muted{
  font-weight: 600;
  color: rgba(255,255,255,0.55);
}
.form details.optional > summary::-webkit-details-marker{ display:none; }
.form details.optional > summary::after{
  content: "▾";
  opacity: .75;
}
.form details.optional[open] > summary::after{
  content: "▴";
}
.form details.optional .optional-inner{
  margin-top: 10px;
}

/* Compact direct-contact panel */
.contact-panel.card{
  padding: 18px 18px 16px;
}
.contact-panel .panel-title{
  font-weight: 900;
  font-size: 14px;
  letter-spacing: .02em;
}
.contact-panel .panel-sub{
  margin-top: 6px;
  font-size: 13px;
  color: rgba(255,255,255,0.70);
}
.contact-panel .contact-rows{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.contact-panel .contact-row{
  display:flex;
  align-items:flex-start;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.14);
}
.contact-panel .contact-btn{
  text-decoration: none;
  transition: border-color .2s ease, background .2s ease, transform .2s ease;
}
.contact-panel .contact-btn:hover{
  border-color: rgba(255,255,255,0.20);
  background: rgba(0,0,0,0.22);
  transform: translateY(-1px);
}
.contact-panel .contact-btn:focus-visible{
  outline: none;
  border-color: rgba(110,168,255,0.60);
  box-shadow: 0 0 0 3px rgba(110,168,255,0.22);
}
.contact-panel .contact-ico{
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.22);
  color: rgba(255,255,255,0.75);
  flex: 0 0 auto;
}
.contact-panel .contact-ico svg{
  width: 16px;
  height: 16px;
  display:block;
}
.contact-panel .contact-label{
  font-size: 12px;
  color: rgba(255,255,255,0.62);
  margin-bottom: 2px;
}
.contact-panel .contact-value{
  font-size: 14px;
  font-weight: 700;
  color: rgba(255,255,255,0.88);
  word-break: break-word;
}
.contact-panel .contact-hint{
  margin-top: 4px;
  font-size: 12px;
  color: rgba(255,255,255,0.55);
}
.contact-panel .contact-foot{
  margin-top: 12px;
}

@media (max-width: 980px){
  .contact-grid{ grid-template-columns: 1fr; }
  .form.card{ padding: 22px 18px 18px; }
}


/* ===========================
   Contact value wrapping fix
   =========================== */
.contact-panel .contact-value{
  word-break: normal;
  overflow-wrap: break-word; /* break only if needed */
  hyphens: none;
  line-height: 1.25;
  font-size: 13.5px;
}
.contact-panel .contact-row{
  padding: 12px 12px;
}
.contact-panel .contact-ico{
  width: 34px;
  height: 34px;
}


/* Mini-chart axis labels/legend (canvas) */
.mini-chart{
  overflow: visible;
}


/* ===========================
   KPI two-column widget layout
   =========================== */
.widget.widget-kpi{
  display: grid;
  grid-template-columns: 76px 1fr;
  grid-template-areas:
    "v h"
    "v s";
  column-gap: 12px;
  row-gap: 4px;
  align-items: center;
  padding: 10px 12px;
}

.widget.widget-kpi .widget-h{
  grid-area: h;
  margin: 0;
  font-size: 12px;
}

.widget.widget-kpi .widget-v{
  grid-area: v;
  margin: 0;
  font-size: 28px;
  line-height: 1;
}

.widget.widget-kpi .widget-s{
  grid-area: s;
  margin: 0;
  font-size: 11px;
  color: rgba(255,255,255,0.62);
}

/* Slightly tighter bento gap to reduce total height */
.bento{ gap: 8px; }


/* Contact form status + loading */
.form-status{
  margin-top: 10px;
  font-size: 12px;
  line-height: 1.35;
  color: rgba(255,255,255,0.72);
  min-height: 18px;
}
.form-status[data-type="success"]{
  color: rgba(140,255,180,0.85);
}
.form-status[data-type="error"]{
  color: rgba(255,150,150,0.90);
}
.form .btn[data-loading="1"]{
  opacity: 0.75;
  cursor: progress;
}


/* ===========================
   Form modal
   =========================== */
.modal-overlay{
  position: fixed;
  inset: 0;
  display: none;
  place-items: center;
  padding: 18px;
  background: rgba(0,0,0,0.62);
  z-index: 9999;
}
.modal-overlay.is-open{ display: grid; }

.modal-overlay .form-modal-card{
  width: min(520px, 100%);
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(10,14,22,0.92);
  box-shadow: 0 20px 70px rgba(0,0,0,0.55);
  overflow: hidden;
}
.modal-overlay .modal-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.modal-overlay .modal-title{
  font-weight: 900;
  letter-spacing: .01em;
  color: rgba(255,255,255,0.92);
}
.modal-overlay .modal-x{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.25);
  color: rgba(255,255,255,0.85);
  font-size: 20px;
  line-height: 0;
  cursor: pointer;
}
.modal-overlay .modal-x:hover{
  background: rgba(255,255,255,0.06);
}
.modal-overlay .modal-body{
  padding: 14px 16px 6px;
  color: rgba(255,255,255,0.74);
  font-size: 13px;
  line-height: 1.45;
}
.modal-overlay .modal-actions{
  padding: 12px 16px 16px;
  display:flex;
  justify-content: flex-end;
  gap: 10px;
}
.modal-overlay .modal-actions .btn{
  min-width: 120px;
}


/* ===========================
   Modal mobile fix
   =========================== */
body.modal-open{
  overflow: hidden;
  touch-action: none;
}

.modal-overlay{
  /* iOS/Android: better viewport handling */
  min-height: 100svh;
}

.modal-overlay .form-modal-card{
  display: flex;
  flex-direction: column;
  max-height: calc(100svh - 36px);
}

.modal-overlay .modal-body{
  overflow: auto;
}

@media (max-width: 560px){
  .modal-overlay{
    padding: 12px;
    align-items: stretch;
    justify-items: stretch;
  }
  .modal-overlay .form-modal-card{
    width: 100%;
    max-height: calc(100svh - 24px);
    border-radius: 18px;
  }
  .modal-overlay .modal-head{
    position: sticky;
    top: 0;
    background: rgba(10,14,22,0.96);
    z-index: 2;
  }
  .modal-overlay .modal-actions{
    position: sticky;
    bottom: 0;
    background: rgba(10,14,22,0.96);
    border-top: 1px solid rgba(255,255,255,0.08);
    z-index: 2;
  }
  .modal-overlay .modal-actions .btn{
    width: 100%;
    min-width: 0;
  }
}
