/* Base */
:root{
  --bg:#0b1b2b;        /* deep navy */
  --bg-2:#0e2236;
  --text:#eaf2ff;
  --muted:#b9c7da;
  --brand:#082E74;     /* accent */
  --glass: rgba(255,255,255,.06);
  --border: rgba(255,255,255,.12);
}

*{box-sizing:border-box;}
html,body{height:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  /* SOLID BACKGROUND (no gradients) */
  background: var(--bg);
}

/* Layout */
.container{width:min(1100px, 92%); margin-inline:auto;}
.grid-2{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center;}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}

/* Header */
.site-header{
  position:sticky; top:0; z-index:50;
  background:linear-gradient(180deg, rgba(11,27,43,.9), rgba(11,27,43,.55) 40%, transparent), var(--bg);
  backdrop-filter:saturate(120%) blur(6px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:14px 0;}
.brand{display:flex; align-items:center; gap:10px;}
.logo{width:42px; height:42px; border-radius:8px; background:linear-gradient(135deg,#6aa8ff00,#89b8ff00); box-shadow:0 6px 20px rgba(106, 168, 255, 0);}
.brand-name{color:#fff; text-decoration:none; font-weight:700; letter-spacing:.2px;}
.links a{color:var(--text); opacity:.9; text-decoration:none; margin-left:18px;}
.links a:hover{opacity:1;}
.btn{
  display:inline-block; padding:10px 16px; border-radius:12px; background:var(--brand);
  color:#ffffff; font-weight:700; text-decoration:none; border:1px solid transparent; transition:.2s;
}
.btn:hover{transform:translateY(-1px);}
.btn.ghost{background:transparent; border-color:var(--border); color:var(--text);}
.btn.full{width:100%}

/* Hero */
.hero{padding:88px 0 52px;}
.hero h1{font-size:44px; line-height:1.1; margin:0 0 12px;}
.hero p{color:var(--muted); margin:8px 0 22px;}
.cta-row{display:flex; gap:12px; flex-wrap:wrap;}
.hero-card .glass{
  border:1px solid var(--border);
  background:linear-gradient(180deg, var(--glass), transparent);
  border-radius:18px; padding:18px;
  height:310px; display:grid; place-items:center;
  position:relative; overflow:hidden;
}
.hero-card .dots{
  position:absolute; inset:-30% -10% auto auto; width:300px; height:300px;
  background:radial-gradient(circle at 30% 30%, #0f3377, transparent 60%);
  filter:blur(30px);
}
.hero-illus{width:100%; height:100%; border-radius:14px;
  background:
    linear-gradient(120deg, rgba(255,255,255,.06), rgba(255,255,255,0) 30%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 10px),
    linear-gradient(180deg, #15314f, #0e2236);
  border:1px solid var(--border);
}

/* Sections */
.section-head h2{margin:0 0 8px;}
.section-head p{color:var(--muted); margin:0;}
.about{padding:54px 0;}

/* Partners marquee */
.partners { padding: 18px 0 42px; }
.partners .section-head { margin-bottom: 10px; }

.marquee-wrap {
  overflow: hidden;
  background: var(--bg-2);
  margin-top: 25px;
  /* choose one border style; solid or none */
  border: none;
}

.marquee {
  display: flex;
  align-items: center;
  gap: 40px;
  padding: 40px 0;
  animation: scroll 26s linear infinite;
  will-change: transform;
}

.marquee img {
  opacity: .92;
  height: 40px;
  width: auto;
}

@keyframes scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Stats */
.stats{padding:46px 0;}
.stat-card{
  border:1px solid var(--border); background:linear-gradient(180deg,var(--glass),transparent);
  border-radius:16px; padding:22px; text-align:center;
}
.stat{display:block; font-size:28px; font-weight:800;}
.label{display:block; color:var(--muted); margin-top:15px;}

/* Contact */
.contact{padding:52px 0 72px;}
.card{
  border:1px solid var(--border);
  /* flatten to avoid banding */
  background: rgba(255,255,255,.06);
  background-image: none;
  border-radius:16px; padding:18px; gap:12px; display:grid;
}
.card label{display:grid; gap:6px; font-size:14px; color:var(--muted);}
.card input,.card textarea{
  background:#0a1a2a; color:var(--text); border:1px solid var(--border);
  border-radius:10px; padding:10px 12px; outline:none;
}
.card input:focus,.card textarea:focus{border-color:#082E74; box-shadow:0 0 0 3px rgba(47,111,182,.25);}
.bullets{margin:14px 0; padding-left:18px; color:var(--muted);}
.bullets li{margin:8px 0;}

/* Footer */
.site-footer{border-top:1px solid var(--border); padding:16px 0; background:rgba(0,0,0,.15);}
.footer-flex { display:flex; justify-content:space-between; align-items:center; color:var(--muted); }
.socials a { margin-left:16px; color:var(--text); opacity:.8; text-decoration:none; font-weight:500; transition:opacity .2s; }
.socials a:hover { opacity:1; }

/* Responsive */
@media (max-width: 900px){
  .grid-2{grid-template-columns:1fr; gap:24px;}
  .grid-3{grid-template-columns:1fr; gap:12px;}
  .hero{padding-top:66px;}
  .hero h1{font-size:34px;}
}

.hero-photo { width:100%; height:100%; object-fit:cover; border-radius:14px; }
.nowrap { white-space:nowrap; }

.fineprint a { color:#a8c9ff; text-decoration:none; }
.fineprint a:hover { color:#ffffff; }

.site-footer{ border-top:1px solid var(--border); background:rgba(0,0,0,.15); text-align:initial; }
.footer-grid{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:24px; padding:16px 0; }
.foot-left{ color:var(--muted); text-align:left; }
.socials{ display:flex; gap:20px; }
.socials a{ color:#a8c9ff; text-decoration:none; font-weight:600; opacity:.95; }
.socials a:hover{ opacity:1; text-decoration:underline; }

@media (max-width: 640px){
  .footer-grid{ grid-template-columns: 1fr; }
  .socials{ justify-content:flex-start; }
}

/* Typewriter lines */
.type-line{ display:inline-block; white-space:nowrap; overflow:hidden; vertical-align:bottom; border-right:.08em solid rgba(255,255,255,.45); }
@keyframes blinkCaret { 0%,49%{border-color:rgba(255,255,255,.45);} 50%,100%{border-color:transparent;} }
.type-line.typing { animation: blinkCaret .9s step-end infinite; }
@media (prefers-reduced-motion: reduce){ .type-line{ border-right:0 !important; } }

/* Hero image hover */
.hero-photo{ transition: transform .35s ease, filter .35s ease; will-change: transform; }
@media (hover: hover){ .hero-card:hover .hero-photo{ transform: scale(1.03); } }
@media (hover: hover){ .hero-card:hover .glass{ box-shadow:0 12px 40px rgba(0,0,0,.35); } }
@media (prefers-reduced-motion: reduce){ .hero-photo{ transition:none; } }

/* ===== Mobile Polish Pack (NotroDan) ===== */
@media (max-width: 900px){
  .container { width: min(100%, 92%); }
  .hero { padding-top: 64px; padding-bottom: 40px; }
  .hero h1 { font-size: 32px; line-height: 1.15; }
  .hero p  { font-size: 15px; }
  .cta-row { gap: 10px; }
  .btn { padding: 12px 16px; border-radius: 12px; }
  .btn.full, .nl-btn { width: 100%; }
  .grid-2 { grid-template-columns: 1fr; gap: 20px; }
  .grid-3 { grid-template-columns: 1fr; gap: 12px; }
  .hero-card .glass { height: 260px; }
  .hero-photo { object-position: center top; }
  .partners { padding: 16px 0 32px; }
  .partners .section-head { margin-bottom: 8px; }
  .marquee-wrap { margin-top: 12px; padding: 24px 0; }
  .marquee { gap: 28px; animation-duration: 32s; }
  .marquee img { height: 34px; }
  .stat-card { padding: 16px; }
  .stat { font-size: 24px; }
  .card { gap: 10px; }
  .card input, .card textarea, .nl-input { padding: 12px 14px; font-size: 16px; }
  .nl-card { grid-template-columns: 1fr; }
  .nl-form { grid-template-columns: 1fr; }
  .nl-btn { width: 100%; }
  .footer-grid { grid-template-columns: 1fr; gap: 12px; }
  .footer-flex { flex-direction: column; align-items: flex-start; gap: 12px; }
  .socials { justify-content: flex-start; gap: 16px; }
}

@media (max-width: 360px){
  .hero h1 { font-size: 28px; }
  .marquee img { height: 30px; }
}

@media (prefers-reduced-motion: reduce){
  .marquee { animation-duration: 40s; }
  .hero-photo { transition: none; }
}

/* ===== Bottom-of-page fixes ===== */

/* 1) Contact section spacing & card sizing on mobile */
@media (max-width: 900px){
  .contact{ padding: 32px 0 28px; }
  .contact .card{ padding: 14px; border-radius: 14px; }
  .contact .card .fineprint{ margin-top: 8px; }
  .contact .container{ padding-bottom: 0; }
}

/* 2) Footer compact */
.site-footer{ border-top:1px solid var(--border); background:rgba(0,0,0,.15); }
.footer-grid{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:16px; padding:10px 0; }
.foot-left{ color:var(--muted); font-size:14px; }
.socials{ display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end; }
.socials a{ color:#a8c9ff; text-decoration:none; font-weight:600; font-size:14px; opacity:.95; }
.socials a:hover{ opacity:1; text-decoration:underline; }

@media (max-width: 480px){
  .footer-grid{ grid-template-columns: 1fr; }
  .socials{ gap:14px; flex-wrap:nowrap; overflow-x:auto; white-space:nowrap; -webkit-overflow-scrolling: touch; padding-bottom:4px; }
  .socials a{ display:inline-block; }
}

/* 3) Brands ribbon: speed back up on mobile */
@media (max-width: 900px){ .marquee{ animation-duration: 18s !important; } }
@media (max-width: 480px){ .marquee{ animation-duration: 14s !important; } }
@media (max-width: 900px){ .marquee-wrap{ padding: 18px 0; } .marquee img{ height: 32px; } }

/* --- Header/top fixes --- */
.site-header{ position: sticky; top: 0; z-index: 100;
  background: linear-gradient(180deg, rgba(11,27,43,.95), rgba(11,27,43,.65) 40%, transparent), var(--bg);
  backdrop-filter: saturate(120%) blur(6px); border-bottom: 1px solid var(--border); padding-top: env(safe-area-inset-top, 0); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:nowrap; }
.brand{ display:flex; align-items:center; gap:10px; min-width:0; }
.brand-name{ white-space:nowrap; }
.links{ display:flex; align-items:center; gap:18px; flex-wrap:nowrap; margin-left:auto; }
.links a{ white-space:nowrap; }
.links .btn{ padding:8px 12px; border-radius:12px; line-height:1; }
@media (max-width: 900px){ .links{ gap:14px; } .links a{ font-size:15px; } .links .btn{ padding:8px 12px; } }
@media (max-width: 480px){ .links{ gap:12px; } .links a:not(.btn){ display:none; } }

/* Newsletter */
.newsletter { padding: 48px 0 56px; }
.nl-card{
  border: 1px solid var(--border);
  /* flatten to avoid banding */
  background: rgba(255,255,255,.06);
  background-image: none;
  border-radius: 18px;
  padding: 22px;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 22px;
}
.nl-copy h3{ margin: 0 0 6px; font-size: 22px; }
.nl-copy p{ color: var(--muted); margin: 0; }
.nl-form{ display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center; }
.nl-input{ background:#0a1a2a; color:var(--text); border:1px solid var(--border); border-radius:12px; padding:12px 14px; outline:none; font-size:16px; }
.nl-btn{ padding: 12px 16px; border-radius: 12px; }
.nl-note{ grid-column: 1 / -1; margin: 4px 2px 0; font-size: 12px; color: var(--muted); }
.nl-msg{ grid-column: 1 / -1; margin: 6px 2px 0; font-weight: 600; }
.nl-success{ color: #b9ffcf; }
.nl-error{ color: #ffb9c0; }
.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; }
@media (max-width: 900px){ .nl-card{ grid-template-columns:1fr; } .nl-form{ grid-template-columns:1fr; } .nl-btn{ width:100%; } }

/* REMOVE any decorative top fades/borders that could look like lines */
.about, .newsletter, .contact { border:0 !important; background: transparent !important; }
section + section { border-top:0 !important; }
.about::before, .about::after,
.newsletter::before, .newsletter::after,
.contact::before, .contact::after { content:none !important; }

/* Floating pill navbar (frosted glass) */
.floating-dock{
  position: fixed;
  left: 50%;
  top: calc(env(safe-area-inset-top, 0px) + 12px);
  transform: translateX(-50%);
  z-index: 9999;
  display: flex; align-items: center; gap: 6px;
  padding: 8px;
  border-radius: 9999px;
  background: rgba(8,18,30,.55);                  /* frosted glass base */
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.floating-dock a{
  text-decoration: none;
  color: #eaf2ff;
  font-weight: 600;
  opacity: .92;
  padding: 10px 12px;
  border-radius: 9999px;
  transition: opacity .15s ease, background-color .15s ease, transform .15s ease;
}
.floating-dock a:hover{ opacity: 1; transform: translateY(-1px); }

.brand-mini{ display:flex; align-items:center; gap:8px; padding: 8px 12px; }
.brand-mini img{ height:22px; width:auto; border-radius:6px; }
.brand-mini span{ white-space: nowrap; }

.dock-link.active{ background: rgba(255,255,255,.08); }
.dock-cta{ background: var(--brand); color: #fff; }

.dock-divider{
  width: 1px; height: 22px;
  background: rgba(255,255,255,.25);
  margin: 0 2px;
  border-radius: 1px;
}

/* Responsive: turn it into a bottom “notch” on small screens */
@media (max-width: 700px){
  .floating-dock{
    top: auto;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
    left: 50%; transform: translateX(-50%);
    padding: 8px 10px;
    gap: 4px;
  }
  .brand-mini span{ display:none; }   /* keep just the logo */
  .dock-divider{ display:none; }
  .floating-dock a{ padding: 10px 12px; }
}

/* floating dock brand */
.floating-dock .brand-mini{
  display:flex; align-items:center; gap:8px; padding:8px 12px;
}
.floating-dock .brand-icon{
  height:22px;               /* adjust to taste (20–28px) */
  width:auto;
  border-radius:6px;         /* remove if your logo is an SVG mark */
}

/* --- Background Base --- */
body {
  background-color: #0b1b2b;   /* deep navy */
  color: #eaf2ff;              /* soft white text */
  margin: 0;
  padding: 0;
  font-family: 'Noto Sans', sans-serif;
}

/* --- Optional glow / spotlight effect --- */
.header-effect {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at center,
    rgba(255, 255, 255, 0.05) 0%,
    transparent 70%);
  pointer-events: none;
  z-index: -1;
}

/* keep this container above the body bg but under content */
.god-rays {
  position: fixed;
  inset: -12% -12% -12% -12%;  /* extra bleed so blur isn’t clipped */
  pointer-events: none;
  z-index: -1;
}

.god-rays {
  position: fixed;
  inset: -200%;             /* way bigger than the screen */
  pointer-events: none;
  z-index: -2;
  overflow: hidden;         /* hide any spill */
}

.god-rays {
  position: fixed;
  inset: -200%;             
  pointer-events: none;
  z-index: -2;
  overflow: hidden;
}

.god-rays .rays {
  position: absolute;
  inset: 0;
  left: 50%;
  transform: translateX(-50%) scale(1.2);
  width: 400%;
  height: 400%;
  background: repeating-conic-gradient(
    from -12deg,
    rgba(255,255,255,0.08) 0deg 5deg,   /* thinner bright ray */
    transparent 5deg 15deg              /* slightly smaller gap */
  );
  animation: spin-rays 120s linear infinite;
  filter: blur(20px);
  opacity: 0.6;

  -webkit-mask-image: radial-gradient(circle, rgba(0,0,0,1) 70%, rgba(0,0,0,0) 100%);
          mask-image: radial-gradient(circle, rgba(0,0,0,1) 70%, rgba(0,0,0,0) 100%);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: cover;
          mask-size: cover;
}

@keyframes spin-rays {
  0%   { transform: translateX(-50%) scale(1.2) rotate(0deg); }
  100% { transform: translateX(-50%) scale(1.2) rotate(360deg); }
}

/* Keep the floating pill NAV at the TOP on phones too */
@media (max-width:700px){
  .floating-dock{
    top: calc(env(safe-area-inset-top, 0px) + 12px);
    bottom: auto;                 /* undo the bottom notch */
    left: 50%;
    transform: translateX(-50%);
    padding: 8px 10px;
  }
  /* optional: tighten contents on small screens */
  .brand-mini span{ display: none; }  /* hide text, keep logo */
  .dock-divider{ display: none; }
  .floating-dock a{ padding: 10px 12px; }
}

