:root{
  /* Light theme palette */
  --bg:#f6f8fc;              /* page background */
  --ink:#0b1437;             /* primary text */
  --ink-dark:#0b1437;
  --ink-muted:#334155;       /* secondary text */
  --muted:#6b7280;

  --brand:#2b6fff;           /* primary blue */
  --brand2:#7aa2ff;          /* accent blue */

  --panel:#ffffff;           /* cards/header/footer */
  --line:rgba(0,0,0,.10);    /* subtle borders */
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,sans-serif;
  background:var(--bg);
  color:var(--ink);
}

/* Header (now white, friendlier) */
.headerbar{
  position:relative; z-index:2;
  display:flex; gap:20px; align-items:center; justify-content:space-between;
  padding:18px 28px;
  background:var(--panel);
  border-bottom:1px solid var(--line);
}
.headerbar .brand{font-weight:800;letter-spacing:.4px;color:var(--ink)}
.headerbar nav a{
  color:var(--ink); text-decoration:none; opacity:.9; margin-left:16px; padding:6px 8px; border-radius:10px;
}
.headerbar nav a:hover{opacity:1; background:#eef3ff}

/* Hero (keep layout, lighten overlay so text stays readable) */
.hero{
  position:relative; min-height:72vh; display:grid; place-items:center;
  background-size:cover; background-position:center;
}
.hero::after{
  content:""; position:absolute; inset:0;
  /* gentle white veil instead of dark */
  background:linear-gradient(180deg, rgba(255,255,255,.50), rgba(255,255,255,.25));
}
.hero-inner{position:relative; z-index:1; max-width:980px; margin:auto; padding:28px}

/* Primary card (unchanged layout, tuned for light theme) */
.code-card{
  backdrop-filter: blur(8px);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.06);
  border-radius:22px;
  padding:28px;
  box-shadow:0 10px 40px rgba(0,0,0,.12);
  color:var(--ink-dark);
  transition:.2s ease;
}
.code-card:hover{transform:translateY(-2px);}

/* Form bits */
.code-form{display:grid;gap:14px}
.input-xl{
  font-size:28px; letter-spacing:6px; text-align:center;
  padding:20px; border-radius:14px;
  border:1px solid rgba(0,0,0,.2);
  background:#fff; color:var(--ink-dark)
}
input,select,button{font:inherit}
label{display:block;margin:12px 0 6px;color:var(--ink)}

/* Buttons */
.btn{padding:14px 18px;border-radius:12px;border:0;cursor:pointer;font-weight:700}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{filter:brightness(1.07)}
/* Optional subtle secondary if needed elsewhere */
.btn-secondary{background:#eef3ff;color:var(--ink);border:1px solid #c9d7ff}
.btn-secondary:hover{filter:brightness(1.02)}

/* Helpers */
.helper{opacity:.95;color:var(--ink-muted);font-size:.98rem}
.small{opacity:.85;font-size:.9rem;color:var(--ink-muted)}

/* Grid/layout (unchanged) */
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:1fr 1fr}
@media(max-width:780px){.grid-2{grid-template-columns:1fr}}
.container{max-width:1100px;margin:0 auto;padding:24px}

/* Info cards (keep look, lighter shadow) */
.info-card{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px;
  padding:22px;
  color:var(--ink-dark);
  box-shadow:0 8px 24px rgba(0,0,0,.10);
  transition:.2s ease
}
.info-card:hover{transform:translateY(-2px);}

/* Generic card container if used elsewhere */
.card{
  background:var(--panel);
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:24px;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  color:var(--ink)
}

/* Badges/chips readable on light */
.badge{
  display:inline-block;
  background:#eef3ff;
  color:var(--ink);
  border:1px solid #c9d7ff;
  padding:6px 10px;
  border-radius:999px;
  margin:4px 4px 0 0;
  font-weight:700;
}

/* Footer (white, friendly) */
.footer{
  padding:30px 24px;
  background:var(--panel);
  border-top:1px solid var(--line);
  color:var(--ink);
}
.footer .cols{display:grid;gap:16px;grid-template-columns:1fr auto}
.footer small{opacity:.75;color:var(--ink-muted)}


/* ===== Footer refresh ===== */
.footer {
  padding: 0; /* accent bar handles its own spacing */
  background: var(--panel);
  border-top: 1px solid var(--line);
  color: var(--ink);
}

/* Top colored ribbon */
.footer-accent {
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  color: #fff;
}
.footer-accent-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 14px 0;
}
.footer-accent-text { font-weight: 700; }
.footer-accent-cta .btn { box-shadow: 0 6px 18px rgba(0,0,0,.15); }

/* Main footer grid */
.footer-grid {
  display: grid; gap: 18px; padding: 20px 0;
  grid-template-columns: 1.2fr 1fr 1fr;
}
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr; }
}

.footer h4 {
  margin: 6px 0 10px;
  font-size: 1rem; font-weight: 800; color: var(--ink);
}
.footer-list {
  list-style: none; padding: 0; margin: 0;
}
.footer-list li { margin: 6px 0; }
.footer-list a { color: var(--ink); text-decoration: none; }
.footer-list a:hover { color: var(--brand); text-decoration: underline; }

/* Bottom row */
.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 14px 0; border-top: 1px solid var(--line);
}
@media (max-width: 700px) {
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* Footer ribbon centered (no CTA button) */
.footer-accent-inner{
  justify-content:center;           /* center horizontally */
  text-align:center;                /* center text */
}
.footer-accent-cta{ display:none; } /* hide old CTA block if present */

/* Header container: ~70% viewport width, capped for very large screens */
.header-container{
  width: min(70vw, 1400px);
  margin: 0 auto;
  padding: 18px 28px;
  display:flex; gap:20px; align-items:center; justify-content:space-between;
}

/* Keep brand link clean */
.brand,
.brand:link,
.brand:visited,
.brand:hover,
.brand:active { text-decoration:none; color:inherit }

/* --- Mobile overflow fixes for home page cards & code input --- */

/* Make cards never exceed the viewport width */
.code-card,
.info-card {
  max-width: 100%;
  width: 100%;
  overflow-wrap: anywhere; /* prevent long text pushing width */
}

/* Ensure the hero/container never creates horizontal scroll */
.hero,
.hero-inner,
.hero > .container {
  max-width: 100%;
  overflow-x: hidden;
}

/* Let grids truly collapse and avoid side overflow */
.grid,
.grid-2 {
  min-width: 0; /* critical for flex/grid children */
}
.grid-2 {
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 780px) {
  .grid-2 { grid-template-columns: 1fr; }
}

/* The 5-digit input: scale down on small screens */
.input-xl {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  /* shrink font + tracking responsively */
  font-size: clamp(20px, 6vw, 28px);
  letter-spacing: clamp(2px, 1.2vw, 6px);
  padding: 16px; /* a bit tighter on mobile */
  box-sizing: border-box;
}

/* Tighten card padding on narrow phones so content stays inside */
@media (max-width: 420px) {
  .code-card,
  .info-card {
    padding: 16px;
    border-radius: 16px;
  }
  .hero-inner { padding: 18px; }
  .badge { padding: 5px 8px; } /* chip/badge shrink */
}

/* Prevent any accidental long inline elements from forcing overflow */
img, svg, canvas, video {
  max-width: 100%;
  height: auto;
}

/* ========== Mobile menu (slide-in from right) ========== */

/* Hide desktop nav on small screens, show hamburger */
.hamburger { display:none; }
@media (max-width: 720px) {
  .site-nav { display:none; }
  .hamburger {
    display:inline-flex; flex-direction:column; gap:5px;
    width:42px; height:38px; align-items:center; justify-content:center;
    background:#fff; border:1px solid var(--line); border-radius:10px; cursor:pointer;
  }
  .hamburger span {
    display:block; width:22px; height:2px; background:var(--ink); border-radius:2px;
  }
}

/* Off-canvas container */
.mobile-menu{
  position: fixed; inset: 0 0 0 auto; /* top right bottom, width set below */
  width: min(70vw, 300px);  /* adjust this for how far the menu slides out from the right, originally it was width: min(82vw, 360px); */
  height: 100dvh;
  background: #fff;
  border-left: 1px solid var(--line);
  box-shadow: -16px 0 32px rgba(0,0,0,.12);
  transform: translateX(100%);
  transition: transform .28s ease;
  z-index: 1001;
  display:flex; flex-direction:column; justify-content:center; /* center links vertically */
  padding: 24px 22px;
}
.mm-open .mobile-menu { transform: translateX(0); }

/* Backdrop behind drawer */
.mm-backdrop{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.35);
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease;
  z-index: 1000;
}
.mm-open .mm-backdrop{ opacity: 1; pointer-events: auto; }

/* Prevent background scroll when open */
.mm-open { overflow: hidden; }

/* Big friendly mobile links */
.mobile-nav a{
  display:block;
  font-size: clamp(22px, 6.8vw, 34px);  /* very large on phones */
  font-weight: 800;
  color: var(--ink);
  text-decoration: none;
  padding: 14px 6px;
  border-radius: 12px;
}
.mobile-nav a:hover{
  background: var(--primary-soft);
}

.perk{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px;
  padding:0 0 16px;
  overflow:hidden;
  box-shadow:0 8px 26px rgba(0,0,0,.12);
}

.perk-image-wrap{
  width:100%;
  aspect-ratio:390 / 250;
  overflow:hidden;
  background:#eef3fa;
  border-bottom:1px solid rgba(0,0,0,.06);
  margin-bottom:12px;
}

.perk-image{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.perk-title{
  font-weight:800;
  margin:0 16px 8px;
  color:#0b1437;
  display:flex;
  align-items:center;
  gap:8px;
}

.perk-bubble{
  position:relative;
  background:rgba(10,24,64,.06);
  border:1px solid rgba(10,24,64,.12);
  padding:10px 12px;
  border-radius:12px;
  color:#0b1437;
  margin:0 16px;
}

.perk-meta{
  font-size:.85rem;
  opacity:.8;
  margin:8px 16px 0;
}

.thank-you-image-wrap{
  margin: 0 0 18px;
}
.thank-you-image{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.14);
}

.home-trust-links{
  padding: 18px 0 8px;
}

.home-trust-copy{
  text-align: center;
  max-width: 760px;
  margin: 0 auto 18px;
}

.home-trust-copy h2{
  margin: 12px 0 8px;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--ink-dark);
}

.home-trust-copy p{
  margin: 0;
}

.home-trust-grid{
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 14px;
  flex-wrap: wrap;
}

.trust-btn{
  position: relative;
  min-width: 220px;
  text-align: center;
  padding: 16px 24px;
  border-radius: 14px;
  font-weight: 800;
  font-size: 1rem;
  text-decoration: none;
  box-shadow: 0 8px 24px rgba(0,0,0,.10);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

.trust-btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.14);
}

.trust-btn-case{
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(43,111,255,.24);
}

.trust-btn-case::before{
  content: "";
  position: absolute;
  top: -20%;
  left: -35%;
  width: 30%;
  height: 140%;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.18) 35%,
    rgba(255,255,255,.78) 50%,
    rgba(255,255,255,.18) 65%,
    rgba(255,255,255,0) 100%
  );
  transform: rotate(18deg);
  animation: soldcodeShine 3.8s ease-in-out infinite;
  pointer-events: none;
}

.trust-btn-case:hover{
  filter: brightness(1.04);
  box-shadow: 0 14px 32px rgba(43,111,255,.30);
}

.trust-btn-about{
  border: 1px solid #c9d7ff;
}

@keyframes soldcodeShine{
  0%{
    left: -38%;
    opacity: 0;
  }
  10%{
    opacity: 1;
  }
  32%{
    left: 118%;
    opacity: 0;
  }
  100%{
    left: 118%;
    opacity: 0;
  }
}

@media (max-width: 640px){
  .home-trust-grid{
    flex-direction: column;
    align-items: stretch;
  }

  .trust-btn{
    width: 100%;
    min-width: 0;
  }
}