/* ===========================
   iRelateDigital Theme v2
   "Midnight Glass + Electric Mint"
   Drop-in replacement for css/styles.css
   =========================== */

:root{
  /* Core */
  --bg: #070A12;
  --bg-2: #0B1220;
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
  --faint: rgba(255,255,255,.55);

  /* Surfaces */
  --card: rgba(255,255,255,.05);
  --card-2: rgba(255,255,255,.08);
  --stroke: rgba(255,255,255,.14);
  --stroke-2: rgba(255,255,255,.18);

  /* Accents */
  --primary: #66F6D2;   /* electric mint */
  --primary-2: #64B5FF; /* soft blue */
  --accent: #A78BFA;    /* violet */
  --warn: #FBBF24;

  /* Effects */
  --shadow: 0 14px 35px rgba(0,0,0,.45);
  --shadow-soft: 0 10px 24px rgba(0,0,0,.28);

  /* Radius */
  --radius: 18px;
  --radius-sm: 14px;

  /* Layout */
  --container: 1120px;
  --container-narrow: 780px;

  /* Type */
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: var(--font);
  color: var(--text);
  line-height:1.55;
  background:
    radial-gradient(900px 500px at 14% -10%, rgba(102,246,210,.20), transparent 60%),
    radial-gradient(900px 520px at 88% 0%, rgba(100,181,255,.18), transparent 55%),
    radial-gradient(800px 480px at 60% 110%, rgba(167,139,250,.12), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-2));
}

a{ color: inherit; text-decoration:none; }
a:hover{ opacity:.98; }
img{ max-width:100%; display:block; }

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

.grid{ display:grid; gap:18px; }
.cards-2{ grid-template-columns: repeat(2, minmax(0,1fr)); }
.cards-3{ grid-template-columns: repeat(3, minmax(0,1fr)); }
.cards-4{ grid-template-columns: repeat(4, minmax(0,1fr)); }

@media (max-width: 980px){
  .cards-4{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .cards-3{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  .cards-4, .cards-3, .cards-2{ grid-template-columns: 1fr; }
}

.section{ padding: 74px 0; }
.section-alt{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  border-top: 1px solid var(--stroke);
  border-bottom: 1px solid var(--stroke);
}

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom: 22px;
}
@media (max-width: 860px){
  .section-head{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}

.section-actions{ display:flex; gap:12px; margin-top: 18px; flex-wrap:wrap; }

h1{
  font-size: clamp(34px, 4vw, 58px);
  line-height:1.06;
  margin: 10px 0 14px;
  letter-spacing:-.03em;
}
h2{
  font-size: clamp(26px, 3vw, 38px);
  line-height:1.18;
  margin: 0 0 12px;
  letter-spacing:-.02em;
}
h3{ margin: 0 0 8px; }
.h4{ font-size: 20px; margin:0 0 8px; }
.h5{ font-size: 16px; margin:0 0 6px; }
.h6{
  font-size: 12px;
  margin:0 0 6px;
  color: var(--faint);
  text-transform: uppercase;
  letter-spacing:.12em;
}

.lead{ font-size: 18px; color: var(--muted); margin: 0 0 14px; }
.muted{ color: var(--muted); }
.fineprint{ color: var(--faint); font-size: 13px; margin: 10px 0 0; }

.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 12px;
  border: 1px solid rgba(102,246,210,.22);
  border-radius: 999px;
  background: rgba(102,246,210,.08);
  color: rgba(255,255,255,.78);
  font-size: 13px;
}

.card{
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(10px);
}
.card.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border: 1px solid var(--stroke-2);
  box-shadow: var(--shadow);
}

.card:hover{
  border-color: rgba(102,246,210,.22);
  transform: translateY(-1px);
  transition: transform .14s ease, border-color .14s ease;
}

.divider{
  height: 1px;
  background: var(--stroke);
  margin: 16px 0;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: 44px;
  padding: 0 16px;
  border-radius: 12px;
  border: 1px solid transparent;
  font-weight: 800;
  letter-spacing: .01em;
  cursor:pointer;
  transition: transform .12s ease, filter .12s ease, background .12s ease, border-color .12s ease;
}
.btn:hover{ transform: translateY(-1px); filter: brightness(1.05); }
.btn:active{ transform: translateY(0px); }

.btn-primary{
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #061018;
  border-color: rgba(255,255,255,.10);
}
.btn-secondary{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
  color: var(--text);
}
.btn-ghost{
  background: transparent;
  border-color: rgba(255,255,255,.18);
  color: var(--text);
}
.w-full{ width:100%; }

/* Lists */
.checklist, .bullet{ margin: 12px 0 0; padding: 0; }
.checklist li, .bullet li{
  list-style:none;
  padding-left: 28px;
  position: relative;
  margin: 10px 0;
  color: var(--muted);
}
.checklist li::before{
  content: "✓";
  position:absolute; left: 0; top: 0;
  color: var(--primary);
  font-weight: 900;
}
.bullet li::before{
  content: "•";
  position:absolute; left: 6px; top: -1px;
  color: var(--primary-2);
  font-weight: 900;
}

/* Header / Nav */
.site-header{
  position: sticky; top:0; z-index: 50;
  backdrop-filter: blur(14px);
  background: rgba(7,10,18,.55);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.nav-wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
  gap: 16px;
}

.brand{
  display:flex; align-items:center; gap: 10px;
  font-weight: 900;
  letter-spacing: -.01em;
}
.brand-mark{
  width: 36px; height: 36px;
  display:grid; place-items:center;
  border-radius: 12px;
  background:
    radial-gradient(14px 14px at 30% 30%, rgba(102,246,210,.55), transparent 70%),
    linear-gradient(135deg, rgba(100,181,255,.18), rgba(167,139,250,.14));
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 18px rgba(0,0,0,.25);
}
.brand-name{ opacity:.95; }

.site-nav{
  display:flex; align-items:center; gap: 16px;
}
.site-nav a{
  color: rgba(255,255,255,.72);
  font-weight: 800;
}
.site-nav a.active{ color: var(--text); }

.nav-toggle{
  display:none;
  background: transparent;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  width: 44px; height: 44px;
  color: var(--text);
}
.nav-toggle-lines{
  width: 18px; height: 2px; background: var(--text);
  display:block; margin: 0 auto;
  position: relative;
}
.nav-toggle-lines::before, .nav-toggle-lines::after{
  content:""; position:absolute; left:0;
  width: 18px; height: 2px; background: var(--text);
}
.nav-toggle-lines::before{ top:-6px; }
.nav-toggle-lines::after{ top:6px; }

@media (max-width: 860px){
  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .site-nav{
    position: absolute;
    right: 20px; top: 64px;
    width: min(92vw, 420px);
    display:none;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 14px;
    background: rgba(7,10,18,.92);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 16px;
    box-shadow: var(--shadow);
  }
  .site-nav.open{ display:flex; }
  .site-nav a{ padding: 10px 12px; border-radius: 12px; }
  .site-nav a:hover{ background: rgba(255,255,255,.06); }
  .site-nav a.btn{ padding: 0 16px; height: 44px; }
}

/* Hero */
.hero{
  position:relative;
  padding: 78px 0 56px;
  overflow:hidden;
}
.hero-grid{
  grid-template-columns: 1.2fr .8fr;
  align-items: start;
  gap: 22px;
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
}
.hero-bg{
  position:absolute; inset:-220px -220px auto -220px;
  height: 560px;
  background:
    radial-gradient(820px 420px at 20% 20%, rgba(102,246,210,.20), transparent 60%),
    radial-gradient(760px 420px at 80% 10%, rgba(100,181,255,.18), transparent 55%),
    radial-gradient(720px 420px at 55% 60%, rgba(167,139,250,.10), transparent 55%);
  filter: blur(10px);
  pointer-events:none;
}
.hero-copy{ position:relative; z-index:1; }
.hero-cta{ display:flex; gap: 12px; flex-wrap:wrap; margin-top: 16px; }

.trust-row{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 18px;
}
@media (max-width: 640px){
  .trust-row{ grid-template-columns: 1fr; }
}
.trust-item{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  border-radius: 14px;
  padding: 12px;
}
.trust-kpi{ font-weight: 900; }
.trust-label{ color: var(--muted); font-size: 13px; }

.steps{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
@media (max-width: 980px){
  .steps{ grid-template-columns: 1fr; }
}
.step{
  display:flex; gap: 12px;
  padding: 16px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
}
.step-num{
  width: 34px; height: 34px;
  border-radius: 12px;
  display:grid; place-items:center;
  font-weight: 900;
  background: linear-gradient(135deg, rgba(102,246,210,.16), rgba(100,181,255,.16));
  border: 1px solid rgba(255,255,255,.16);
}

.cta-band{
  margin-top: 22px;
  padding: 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.16);
  background:
    linear-gradient(135deg, rgba(102,246,210,.10), rgba(100,181,255,.10));
  display:flex; align-items:center; justify-content:space-between;
  gap: 14px;
}
@media (max-width: 860px){
  .cta-band{ flex-direction: column; align-items:flex-start; }
}

.page-hero{ padding: 56px 0 18px; }

.pricing-grid{
  grid-template-columns: .9fr 1.1fr;
  align-items:start;
}
@media (max-width: 980px){
  .pricing-grid{ grid-template-columns: 1fr; }
}
.price{ margin: 14px 0; }
.price-main{
  font-size: 36px;
  font-weight: 950;
  letter-spacing:-.02em;
}
.price-sub{ color: var(--muted); }

.form-grid{
  grid-template-columns: 1fr 1fr;
  align-items:start;
}
@media (max-width: 980px){
  .form-grid{ grid-template-columns: 1fr; }
}
.form{
  display:grid; gap: 12px;
  margin-top: 12px;
}
label{ display:grid; gap: 8px; color: var(--muted); font-weight: 800; }
input, select, textarea{
  width:100%;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: var(--text);
  padding: 12px 12px;
  outline:none;
}
input::placeholder, textarea::placeholder{ color: rgba(255,255,255,.45); }
input:focus, select:focus, textarea:focus{
  border-color: rgba(102,246,210,.55);
  box-shadow: 0 0 0 3px rgba(102,246,210,.12);
}

.faq{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  margin: 12px 0;
}
.faq summary{ cursor:pointer; font-weight: 900; }
.faq p{ margin: 10px 0 0; }

/* Footer */
.site-footer{
  padding: 36px 0 22px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 20px;
  align-items:start;
}
@media (max-width: 860px){
  .footer-grid{ grid-template-columns: 1fr; }
}
.footer-links{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.footer-links a{
  display:block;
  color: rgba(255,255,255,.72);
  padding: 6px 0;
}
.footer-bottom{
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.10);
}

/* Accessibility helpers */
.skip-link{
  position:absolute; left:-999px; top:auto;
  width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left: 12px; top: 12px;
  width:auto; height:auto;
  padding: 10px 12px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 12px;
  z-index: 999;
}
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}

/* Sticky CTA (safe-area + no overlap) */
.sticky-cta{
  position: fixed;
  left: 20px;
  right: 20px;
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 80;
  height: 50px;
  border-radius: 16px;
  display: none;
  align-items: center;
  justify-content: center;
  font-weight: 950;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #061018;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: var(--shadow);
}

@media (max-width: 860px){
  .sticky-cta{ display:flex; }
  /* Make room so content never sits behind the sticky button */
  main{ padding-bottom: calc(120px + env(safe-area-inset-bottom)); }
}