/* =========================================================
   LanderBoost — Dark Premium Tech (Option A / gold-led)
   Built from "LanderBoost Visual System Report"
   ========================================================= */

/* -------------------------
   TOKENS
   ------------------------- */
:root{
  --bg:#0B0D12;
  --surface:#121826;
  --surface2:#0F1522;

  --text:#F3F5FF;
  --muted:#A8B0C5;

  --gold:#D6B25E;
  --gold-hi:#E3C77A;
  --gold-lo:#B7923E;

  --focus:#2AE6C4;

  --bdr:#32415C;
  --danger:#FF5A6A;

  --r-sm:10px;
  --r-md:14px;
  --r-lg:18px;

  --shadow-1: 0 10px 30px rgba(0,0,0,.35);
  --shadow-2: 0 18px 55px rgba(0,0,0,.45);

  --s-1:4px;
  --s-2:8px;
  --s-3:12px;
  --s-4:16px;
  --s-5:24px;
  --s-6:32px;
  --s-7:48px;
  --s-8:64px;
  --s-9:96px;

  --container:1120px;
  --pad:20px;

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

  --ico: clamp(160px, 12vw, 210px);        
  --step-ico: clamp(120px, 9vw, 170px);   
}

/* -------------------------
   BASE / RESET
   ------------------------- */
*,
*::before,
*::after{ box-sizing:border-box; }

html{ 
  color-scheme: dark;
   overflow-y: scroll;
  scrollbar-gutter: stable; 
}

body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  text-rendering:optimizeLegibility;
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{ color:inherit; text-decoration:none; }

p{ margin:0 0 var(--s-4); color:var(--muted); }
p.lead{ font-size:1.125rem; line-height:1.6; color:var(--muted); }

h1,h2,h3{
  margin:0 0 var(--s-3);
  letter-spacing:-.02em;
  color:var(--text);
}

h1{
  font-size:clamp(2.2rem, 3vw, 3.2rem);
  line-height:1.08;
  font-weight:700;
}
h2{
  font-size:clamp(1.6rem, 2vw, 2.2rem);
  line-height:1.15;
  font-weight:700;
}
h3{
  font-size:1.2rem;
  line-height:1.25;
  font-weight:600;
}

ul,ol{ margin:0; padding:0; }
li{ margin:0; }
[role="list"]{ list-style:none; padding:0; margin:0; }

.fineprint{
  font-size:.875rem;
  line-height:1.6;
  color:var(--muted);
}

a,
button,
.btn,
.nav a,
.work-card,
.feature,
.price-card,
.steps li{
  transition:
    transform .5s ease,
    box-shadow .5s ease,
    background .5s ease,
    border-color .5s ease,
    color .5s ease,
    filter .5s ease,
    opacity .5s ease;
}
/* Focus visibility */
:focus{ outline:none; }
:focus-visible{
  outline:3px solid color-mix(in srgb, var(--focus) 85%, transparent);
  outline-offset:3px;
  border-radius:10px;
}

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

/* -------------------------
   LAYOUT UTILITIES
   ------------------------- */
.container{
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--pad);
}

.section{
  padding:var(--s-8) 0;
}

.section--alt{
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}

.section-head{
  margin-bottom:var(--s-6);
  max-width:72ch;
}

.section-head--row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:var(--s-5);
}

.kicker{
  display:inline-block;
  font-weight:600;
  color:var(--gold);
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.85rem;
  margin-bottom:var(--s-3);
}

/* ICONS */

.ico,
.step-icon{
  display:block;
  margin-inline:auto;       
  margin-bottom: var(--s-3);
  width: var(--ico);
  height: var(--ico);
  filter:
    drop-shadow(0 0 14px rgba(214,178,94,.28))
    drop-shadow(0 0 40px rgba(214,178,94,.14));
  opacity: .98;
}


.step-icon{
  width: var(--step-ico);
  height: var(--step-ico);
}

/* -------------------------
   HEADER / NAV
   ------------------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:
    linear-gradient(180deg, rgba(11,13,18,.92), rgba(11,13,18,.70));
  backdrop-filter:saturate(120%) blur(10px);
  border-bottom:1px solid color-mix(in srgb, var(--bdr) 45%, transparent);
}

.site-header::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("../assets/images/nav_background.webp");
  background-size:cover;
  background-position:center;
  opacity:.35;
  pointer-events:none;
  mix-blend-mode:screen;
}

.header-inner{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--s-5);
  padding:var(--s-4) 0;
}

.site-header .container{
  padding-inline: 24px;
}

.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  min-height:44px;
  flex-shrink:0;
}

.brand__logo{
  width:32px;
  height:32px;
  display:block;
  border-radius:7px;
  flex-shrink:0;
}

.brand-name{
  font-weight:800;
  letter-spacing:-.02em;
  font-size:1.2rem;
  line-height:1;
}
.nav{
  display:flex;
  align-items:center;
  gap:var(--s-4);
  flex-wrap:wrap;
}

.nav a{
  color:var(--muted);
  font-weight:500;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid transparent;
}

.nav a:hover{
  color:var(--text);
  background:rgba(255,255,255,.03);
}

.nav a[aria-current="page"]{
  color:var(--text);
  background:rgba(214,178,94,.10);
  border:1px solid color-mix(in srgb, var(--gold) 28%, transparent);
}

/* ===== Mobile nav ===== */
.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;
}

.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  background:rgba(12,18,32,.6);
  box-shadow: var(--shadow-1);
}

.nav-toggle__bars{
  width:18px;
  height:2px;
  background:rgba(255,255,255,.9);
  border-radius:999px;
  position:relative;
  display:block;
}
.nav-toggle__bars::before,
.nav-toggle__bars::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background:rgba(255,255,255,.9);
  border-radius:999px;
}
.nav-toggle__bars::before{ top:-6px; }
.nav-toggle__bars::after{ top:6px; }

.nav-toggle{
  cursor:pointer;
}

.nav-toggle__bars{
  transition: transform .18s ease, background .18s ease;
}

.nav-toggle__bars::before,
.nav-toggle__bars::after{
  transition: transform .18s ease, top .18s ease, opacity .18s ease;
}

/* X state */
.nav-toggle[aria-expanded="true"] .nav-toggle__bars{
  background: transparent;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bars::before{
  top: 0;
  transform: rotate(45deg);
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bars::after{
  top: 0;
  transform: rotate(-45deg);
}

/* mobile layout */
@media (max-width: 760px){
  .header-inner{
    position:relative;
  }

    .nav a:hover{
    background: rgba(255,255,255,.06);
  }

  .nav a:focus-visible{
    outline: 2px solid color-mix(in srgb, var(--gold) 45%, transparent);
    outline-offset: 2px;
  }

  .nav-toggle{ display:flex; }

  /* hide nav by default */
     .nav{
    position: fixed;
    left: 50%;
    top: 88px;
    transform: translateX(-50%);
    width: min(92vw, 420px);

    display: none;
    flex-direction: column;
    gap: var(--s-2);

    padding: var(--s-4);
    border-radius: var(--r-lg);
    border: 1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
    background: rgba(10,16,28,.92);
    backdrop-filter: blur(12px);
    box-shadow: 0 30px 80px rgba(0,0,0,.55), 0 0 40px rgba(214,178,94,.10);
    z-index: 9999;
  }

  .nav.is-open{ display:flex; }

  .nav a{
    padding:.9rem 1rem;
    border-radius: 14px;
  }

  /* CTA inside menu — full width and loud */
  .nav .btn.btn--small{
    width:100%;
    justify-content:center;
    padding: 1rem 1rem;
    border-radius: 16px;
    margin-top: var(--s-2);
  }

   .header-inner{
  gap: var(--s-3);
  padding-block: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.site-header .container{
  padding-inline: 18px;
}

.brand{
  gap: 10px;
  order: 1;
}

.brand__logo{
  width:42px;
  height:42px;
}

.brand-name{
  display: none;
  
}

.nav-toggle{
  margin-left:8px;
  flex-shrink:0;
  order:3;
}

.site-header .btn{
  margin-left:10px;
  order: 2;
}
}

/* ===== Nav CTA (more contrast + premium) ===== */
.nav .btn.btn--small{
  background: linear-gradient(180deg, #f6e2ab, var(--gold));
  color: #0b1220; /* darker text for contrast */
  box-shadow:
    0 0 0 1px rgba(0,0,0,.38) inset,
    0 14px 36px rgba(214,178,94,.32),
    0 0 44px rgba(214,178,94,.18);
}



/* -------------------------
   BUTTONS
   ------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  min-height:44px;
  border-radius:14px;
  font-weight:600;
  border:1px solid transparent;
  background:var(--gold);
  color:var(--bg);
  box-shadow:0 0 24px rgba(214,178,94,.18);
  text-align: center;
}




.btn:active{ background:var(--gold-lo); }

.btn--ghost{
  background:transparent;
  color:var(--text);
  border-color:color-mix(in srgb, var(--bdr) 70%, transparent);
  box-shadow:none;
}

.btn--ghost:hover{
  border-color:color-mix(in srgb, var(--gold) 55%, transparent);
  background:rgba(255,255,255,.03);
}

.btn--small{
  padding:10px 12px;
  border-radius:12px;
  min-height:40px;
  font-size:.95rem;
}

/* =========================
   CTA: animated border glow
   ========================= */
.btn--glow{
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: linear-gradient(
    145deg,
    #f6d67a 0%,
    #e6b94a 35%,
    #c9962f 70%,
    #f3d37a 100%
  );
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -2px 4px rgba(0,0,0,.25),
    0 10px 26px rgba(214,178,94,.28),
    0 0 28px rgba(214,178,94,.16);
  animation: cta-breathe 6s ease-in-out infinite;
}

/* moving light sweep */
.btn--glow::before{
  content: "";
  position: absolute;
  top: -20%;
  bottom: -20%;
  width: 42%;
  left: -55%;
  transform: skewX(-24deg);
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,248,220,0.00) 20%,
    rgba(255,255,255,0.18) 48%,
    rgba(255,255,255,0.38) 52%,
    rgba(255,248,220,0.00) 80%,
    rgba(255,255,255,0) 100%
  );
  animation: cta-sheen 3.8s ease-in-out infinite;
  pointer-events: none;
}

.btn--glow:hover{
  transform: translateY(-1px);
  filter: brightness(1.05);
  background: linear-gradient(
    145deg,
    #f8dd8d 0%,
    #ebc158 35%,
    #d2a23b 70%,
    #f5d983 100%
  );
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.50),
    inset 0 -2px 4px rgba(0,0,0,.22),
    0 14px 34px rgba(214,178,94,.34),
    0 0 36px rgba(214,178,94,.22);
}

@keyframes cta-sheen{
  0%{
    left: -55%;
    opacity: 0;
  }
  8%{
    opacity: 1;
  }
  30%{
    left: 115%;
    opacity: 1;
  }
  31%, 100%{
    left: 115%;
    opacity: 0;
  }
}

@keyframes cta-breathe{
  0%, 100%{
    transform: translateY(0) scale(1);
  }
  50%{
    transform: translateY(0) scale(1.025);
  }
}

/* -------------------------
   HERO
   ------------------------- */
.hero{
  padding:var(--s-9) 0 var(--s-8);
}

.hero-inner{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:var(--s-8);
  align-items:center;
}

.hero-copy .lead{ margin-bottom:var(--s-5); }

.hero-cta{
  display:flex;
  gap:var(--s-4);
  flex-wrap:wrap;
  margin:var(--s-5) 0 var(--s-4);
}

.microtrust{
  display:flex;
  flex-wrap:wrap;
  gap:var(--s-3);
}

.microtrust li{
  font-size:.9rem;
  color:var(--muted);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--bdr) 55%, transparent);
  background:rgba(255,255,255,.02);
}

.hero-visual{
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  box-shadow:var(--shadow-1);
}

.hero-visual img{
  aspect-ratio:4/3;
  object-fit:cover;
}

/* -------------------------
   GRIDS / CARDS
   ------------------------- */
.grid-3{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--s-5);
}

.feature{
  background:var(--surface);
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  border-radius:var(--r-lg);
  padding:var(--s-6);
  box-shadow:var(--shadow-1);
}

.feature p{ margin:0; }

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--s-5);
}

.price-card{
  background:var(--surface);
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  border-radius:var(--r-lg);
  padding:var(--s-6);
  box-shadow:var(--shadow-1);

  display:flex;
  flex-direction:column;
  height:100%;
  position: relative;
}

.price-cta{
margin-top:20px;
display:inline-block;
}


.price-card.featured{
  border-color:color-mix(in srgb, var(--gold) 55%, transparent);
  box-shadow:0 0 28px rgba(214,178,94,.14), var(--shadow-1);
}

.price{
  font-size:1.7rem;
  font-weight:800;
  color:var(--text);
  margin:var(--s-3) 0 var(--s-4);
}

.price-card ul{
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}

.price-card li{
  color:var(--muted);
}

.price-card li:last-child{
  margin-top:auto;
}

.price-card strong{
  color:var(--text);
}


/* ------------------------------

ADDONS

--------------------------------*/

.addons{
  display:grid;
  grid-template-columns: 1fr 520px;
  gap: var(--s-6);
  align-items:center;
}

.addons-image{
  justify-self:end;
  max-width:520px;
}

.addons-image img{
  width:100%;
  border-radius:16px;
   transform: rotate(-2deg);
  box-shadow:
    0 20px 40px rgba(0,0,0,.5),
    0 0 40px rgba(214,178,94,.15);
}

.addons-image img:hover{
  transform: rotate(-1deg) scale(1.03);
}
@media (max-width: 960px){
  .addons{
    grid-template-columns: 1fr;
  }

  .addons-image{
    justify-self:start;
    margin-top: var(--s-4);
  }
}
/* -------------------------
   WORK (index + work page)
   ------------------------- */
.work-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--s-5);
}

@media (min-width: 768px){
.work-page .work-grid{
  display: grid;
  gap: var(--s-6);
  grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
}}


.work-card{
  display:flex;
  flex-direction:column;
  background:var(--surface);
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-1);
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
  flex: 1;
  position: relative;
}
.work-card::before{
  content:"";
  position:absolute;
  inset:0;

  background: radial-gradient(
    600px circle at var(--x) var(--y),
    rgba(255,210,140,0.15),
    transparent 40%
  );

  opacity:0;
  transition: opacity .25s ease;

  pointer-events:none;
}

.work-card:hover::before{
  opacity:1;
}
.work-card:hover{
  transform:translateY(-2px);
  border-color:color-mix(in srgb, var(--gold) 45%, transparent);
  box-shadow:var(--shadow-2);
}

.work-thumb{
  position:relative;
  background:rgba(255,255,255,.02);
  border-bottom:1px solid color-mix(in srgb, var(--bdr) 55%, transparent);
}

.work-thumb::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-10px;
  transform:translateX(-50%);

  width:70%;
  height:60px;

  background: radial-gradient(
    ellipse at center,
    rgba(255, 200, 120, 0.25),
    rgba(255, 200, 120, 0.05) 60%,
    transparent 80%
  );

  filter: blur(18px);
  z-index:-1;
  pointer-events:none;
}

/* ===== Mockups: desktop base + mobile overlay that can "escape" ===== */
.work-thumb{ overflow:visible; }
.work-thumb .mockups{
  position:relative;
  padding:var(--s-4);
  overflow:visible;
}


.work-thumb .mock--desktop{
  width:100%;
  aspect-ratio:16/10;
  border-radius:14px;
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  box-shadow:0 12px 30px rgba(0,0,0,.35);
  object-fit:cover;
}


.work-thumb .mock--mobile{
  position:absolute;
  right: calc(var(--s-4) * -0.35);   
  bottom: calc(var(--s-4) * -0.45);  

  width: min(24%, 160px);            
  aspect-ratio:9/16;

  border-radius:18px;
  border:1px solid color-mix(in srgb, var(--bdr) 65%, transparent);
  box-shadow:
    0 22px 60px rgba(0,0,0,.62),
    0 0 34px rgba(214,178,94,.14);
  object-fit:cover;

  transform: translateY(0);
  transition: transform .2s ease, box-shadow .2s ease;
}

.work-card:hover .mock--mobile{
  transform: translateY(-8px);
  box-shadow:
    0 26px 70px rgba(0,0,0,.68),
    0 0 42px rgba(214,178,94,.18);
}

/* mobile sizing tweak on small screens */
@media (max-width: 560px){
  .work-thumb .mock--mobile{
    width: min(32%, 150px);
    right: calc(var(--s-4) * -0.15);
    bottom: calc(var(--s-4) * -0.25);
  }
}




/* Work meta */
.work-meta{
  padding:var(--s-5);
  min-height:190px;

  display:flex;
  flex-direction:column;
  gap:6px;
}

.work-meta .work-open{
  position:relative;
  display:inline-block;
  align-self: flex-start;

  margin-top:auto;
  font-size:.9rem;
  color:var(--gold);
  opacity:.9;

  text-decoration:none;
}


.work-open::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-2px;

  width:0%;
  height:1px;
  background:var(--gold);

  transition:width .25s ease;
}


.work-open:hover::after{
  width:100%;
}

.work-meta h2,
.work-meta h3{
  margin-bottom:6px;
  
  
}

.work-meta p{
  margin:0;
  color:var(--muted);
}

.work-item{
  display:flex;
  flex-direction:column;
  gap:var(--s-4);
}

.work-points{
  display:grid;
  gap:8px;
  padding:0 var(--s-2) var(--s-2);
}

.work-points li{
  color:var(--muted);
  padding-left:18px;
  position:relative;
}

.work-points li::before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:8px;
  height:8px;
  border-radius:999px;
  background:color-mix(in srgb, var(--gold) 85%, transparent);
  box-shadow:0 0 18px rgba(214,178,94,.18);
}

/* Mockup controls (work.html) */
.mockup-controls{
  display:flex;
  gap:var(--s-2);
  flex-wrap:wrap;
  align-items:center;
  padding:0 var(--s-2);
  margin-bottom: var(--s-3);
}

.mockup-btn{
  appearance:none;
  background:transparent;
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  color:var(--muted);
  border-radius:999px;
  padding:8px 12px;
  min-height:38px;
  font-weight:600;
  cursor:pointer;
}

.mockup-btn:hover{
  color:var(--text);
  border-color:color-mix(in srgb, var(--gold) 45%, transparent);
  background:rgba(255,255,255,.03);
}

.mockup-btn[aria-pressed="true"]{
  color:var(--bg);
  background:var(--gold);
  border-color:transparent;
}

/* -------------------------
   PROCESS / STEPS
   ------------------------- */
.steps{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:var(--s-5);
  
}

.steps li{
  background:var(--surface);
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  border-radius:var(--r-lg);
  padding:var(--s-6);
  box-shadow:var(--shadow-1);
  position:relative;
}



.steps h3{ margin-top:0; }
.steps p{ margin:0; }

/* -------------------------
   FAQ
   ------------------------- */
.faq{
  display:grid;
  gap:var(--s-3);
}

summary::-webkit-details-marker {
  display: none;
}

details {
  background: var(--surface);
  border: 1px solid var(--bdr);
  border-radius: var(--r-lg);
  padding: var(--s-4) var(--s-5);
  transition: border-color .25s ease, box-shadow .25s ease;
}

details:hover {
  border-color: var(--gold);
  box-shadow:
    0 0 0 1px rgba(214,178,94,.15),
    0 10px 30px rgba(0,0,0,.35);
}

summary {
  cursor: pointer;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}

summary::after {
  content: "+";
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  font-weight: 700;

  color: var(--gold);
  background: rgba(214,178,94,.08);
  border: 1px solid rgba(214,178,94,.5);

  box-shadow: 0 0 14px rgba(214,178,94,.15);
  transition: all .25s ease;
}



details[open] summary::after {
  content: "–";
  background: var(--gold);
  color: var(--bg);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.35) inset,
    0 0 20px rgba(214,178,94,.35);
}

details p{
  margin:var(--s-4) 0 0;
  color:var(--muted);
}

/* -------------------------
   CTA STRIP
   ------------------------- */
.cta-strip{
  margin-top:var(--s-8);
  padding:var(--s-7);
  border-radius:var(--r-lg);
  border:1px solid color-mix(in srgb, var(--gold) 35%, transparent);

  display:grid;
  place-items:center;
  text-align:center;
  gap:var(--s-3);

  min-height:260px;

  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0)),
    url("../assets/images/cta_banner.webp");
  background-size:cover;
  background-position:center;
  box-shadow:0 0 28px rgba(214,178,94,.12), var(--shadow-1);
}


.cta-strip{
  position:relative;
  overflow:hidden;
}

.cta-strip::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(60% 70% at 50% 45%, rgba(0,0,0,.55), transparent 65%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.35));
  pointer-events:none;
}

.cta-strip > *{
  position:relative;
  z-index:1;
}

/* gradient title */
.cta-strip h2{
  margin:0;
  background: linear-gradient(
    90deg,
    #fff,
    color-mix(in srgb, var(--gold) 75%, #fff),
    #fff
  );
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow: 0 2px 14px rgba(0,0,0,.55);
}


.cta-strip h2{ margin:0; }
.cta-strip p{ margin:0; max-width:70ch; }



/* -------------------------
   BULLETS LIST (Add-ons)
   ------------------------- */
.bullets{
  display:grid;
  gap:10px;
}

.bullets li{
  color:var(--muted);
  padding-left:18px;
  position:relative;
}

.bullets li::before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:8px;
  height:8px;
  border-radius:999px;
  background:color-mix(in srgb, var(--focus) 70%, transparent);
}

/* -------------------------
   FOOTER
   ------------------------- */
.site-footer{
  padding:var(--s-7) 0;
  border-top:1px solid color-mix(in srgb, var(--bdr) 45%, transparent);
  background:rgba(255,255,255,.01);
}

.footer-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--s-6);
  flex-wrap:wrap;
}

.footer-inner p{ margin:0; }

/* -------------------------
   FORMS (contact)
   ------------------------- */
form{
  display:grid;
  gap:var(--s-4);
  max-width:640px;
}

label{
  font-weight:600;
  color:var(--text);
}

input, textarea, select{
  width:100%;
  font:inherit;
  color:var(--text);
  background:var(--surface);
  border:1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  border-radius:14px;
  padding:12px 14px;
}

textarea{ min-height:140px; resize:vertical; }

input::placeholder, textarea::placeholder{ color:color-mix(in srgb, var(--muted) 70%, transparent); }

input:focus-visible, textarea:focus-visible, select:focus-visible{
  border-color:color-mix(in srgb, var(--focus) 60%, transparent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--focus) 25%, transparent);
}

/* -------------------------
   RESPONSIVE
   ------------------------- */
@media (max-width: 960px){
  .hero-inner{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:repeat(2, 1fr); }
  .pricing-grid{ grid-template-columns:repeat(2, 1fr); }
  .work-grid{ grid-template-columns:repeat(2, 1fr); }
  .steps{ grid-template-columns:repeat(2, 1fr); }
  .section-head--row{ align-items:flex-start; }
}

@media (max-width: 640px){
  .section{ padding:var(--s-7) 0; }
  .grid-3{ grid-template-columns:1fr; }
  .pricing-grid{ grid-template-columns:1fr; }
  .work-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .hero{ padding:var(--s-8) 0 var(--s-7); }
  .cta-strip{ padding:var(--s-6); }
  .nav{ gap:8px; }

  .hero-cta{
  display:grid;
  grid-template-columns:auto auto;
  gap:8px;
  margin-bottom:var(--s-4);
  justify-content:start;
}

.hero-cta .btn{
  flex:none;
  min-width:0;
  white-space:nowrap;
  text-align:center;
  padding:10px 12px;
  font-size:.92rem;
}

 .hero{
  padding-top: 24px;
}
  .hero-inner{
    grid-template-columns:1fr;
    gap: var(--s-4);
  }

}




.steps{
  list-style: none;      
  padding-left: 0;       
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
}

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

@media (max-width: 720px){
  .steps{
    grid-template-columns: 1fr;   
  }
}


/* ===== Back to top ===== */
.back-to-top{
  position:fixed;
  right:20px;
  bottom:24px;
  width:52px;
  height:52px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--gold) 40%, transparent);
  background:rgba(12,18,32,.75);
  backdrop-filter:blur(8px);
  color:var(--gold);
  font-size:1.2rem;
  display:grid;
  place-items:center;
  cursor:pointer;

  opacity:0;
  transform:translateY(12px);
  pointer-events:none;

  transition:
    opacity .3s ease,
    transform .3s ease,
    box-shadow .3s ease;
  
  box-shadow:
    0 0 18px rgba(214,178,94,.15),
    var(--shadow-1);
}

.back-to-top.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

.back-to-top:hover{
  box-shadow:
    0 0 28px rgba(214,178,94,.35),
    0 0 60px rgba(214,178,94,.15);
  transform:translateY(-3px);
}

/* Arrows between steps (desktop only) */
@media (min-width: 900px){
  .steps li{
    position: relative;
  }

  .steps li:not(:last-child)::after{
    content:"";
    position:absolute;
    top: 50%;
    right: calc(-1 * var(--s-5));
    transform: translateY(-50%);
    width: var(--s-5);
    height: 2px;

    background: linear-gradient(
      90deg,
      transparent,
      color-mix(in srgb, var(--gold) 70%, transparent),
      transparent
    );

    filter: drop-shadow(0 0 10px rgba(214,178,94,.25));
    opacity: .9;
  }

 
  .steps li:not(:last-child)::before{
    content:"";
    position:absolute;
    top: 50%;
    right: calc(-1 * var(--s-5) + 2px);
    transform: translateY(-50%) rotate(45deg);
    width: 10px;
    height: 10px;

    border-right: 2px solid color-mix(in srgb, var(--gold) 75%, transparent);
    border-top: 2px solid color-mix(in srgb, var(--gold) 75%, transparent);
    filter: drop-shadow(0 0 10px rgba(214,178,94,.25));
  }
}



/* =========================
   MOCKUP MODAL (dialog)
   ========================= */
.mock-modal{
  border:0;
  padding:0;
  background:transparent;
  max-width:none;
  max-height:none;
}

.mock-modal::backdrop{
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(8px);
}

.mock-modal__img{
  display:block;
  max-width: min(1200px, 94vw);
  max-height: 86vh;
  border-radius: 18px;
  box-shadow: 0 30px 120px rgba(0,0,0,.75);
}

.mock-modal__close{
  position: fixed;
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.45);
  color:#fff;
  font-size:20px;
  cursor:pointer;
}
.mock-modal__close:hover{ background: rgba(0,0,0,.60); }

.work-card{
  cursor: pointer;
}

.work-card .mockups{
  transition: transform .22s ease, filter .22s ease;
}

.work-card:hover .mockups{
  transform: translateY(-2px);
  filter: brightness(1.03);
}

.nav a.is-active{
  color:var(--text);
  background:rgba(214,178,94,.10);
  border:1px solid color-mix(in srgb, var(--gold) 28%, transparent);
}

.feature,
.price-card,
.steps li,
.work-card{
   background:
    linear-gradient(
      180deg,
      rgba(255,255,255,.03) 0%,
      rgba(0,0,0,.25) 100%
    ),
    var(--surface);

  box-shadow:
    inset 0 3px 0 rgba(255,255,255,.08),   
    inset 0 -8px 22px rgba(0,0,0,.75),     
    inset 0 0 28px rgba(0,0,0,.55),        
    0 20px 40px rgba(0,0,0,.45);           

      border: 1px solid rgba(255,255,255,.05);
}

.feature:hover,
.price-card:hover,
.steps li:hover,
.work-card:hover{
  transform: translateY(-4px);
  box-shadow:
    0 26px 56px rgba(0,0,0,.32),
    0 0 0 1px rgba(214,178,94,.08) inset;
}

.section{
  position: relative;
}

.section::before{
  content:"";
  position:absolute;
  inset:0;

  background:
    radial-gradient(
      800px 300px at 50% -100px,
      rgba(255,215,120,.08),
      transparent 70%
    );

  pointer-events:none;
}

.nav .btn.btn--small{
  color: #0b1220;
}

.nav .btn.btn--small.btn--glow{
  background: linear-gradient(
    145deg,
    #f6d67a 0%,
    #e6b94a 35%,
    #c9962f 70%,
    #f3d37a 100%
  );
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -2px 4px rgba(0,0,0,.25),
    0 6px 16px rgba(0,0,0,.35);
}

.nav .btn.btn--small.btn--glow:hover{
  transform: translateY(-1px);
  filter: brightness(1.05);
  background: linear-gradient(
    145deg,
    #f8dd8d 0%,
    #ebc158 35%,
    #d2a23b 70%,
    #f5d983 100%
  );
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.50),
    inset 0 -2px 4px rgba(0,0,0,.22),
    0 14px 34px rgba(214,178,94,.34),
    0 0 36px rgba(214,178,94,.22);
}

.pricing-badge{
position:absolute;
top:-12px;
left:50%;
transform:translateX(-50%);
background:linear-gradient(145deg,#f6d67a,#d7a63a);
color:#000;
font-size:.75rem;
padding:4px 10px;
border-radius:20px;
font-weight:600;
}

/* CONTACT SPLIT LAYOUT */

.split{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap: var(--s-6);
  align-items:start;
}

.split form{
  justify-self:start;
}

.split h2{
  margin-top: var(--s-5);
}

.split .bullets{
  margin-top: var(--s-3);
}

.form{
  
  padding: var(--s-5);
  border-radius: var(--r-lg);
  border: 1px solid color-mix(in srgb, var(--bdr) 70%, transparent);
  box-shadow: var(--shadow-1);
}

@media (max-width: 720px){

  .split{
    grid-template-columns: 1fr;
  }

  .split form{
    order:-1;
    padding-left: var(--s-5);
  }

}

.legal-page h1{
  margin-bottom: var(--s-5);
}

.legal-page h2{
  font-size: 1.15rem;
  margin-top: var(--s-6);
  margin-bottom: var(--s-3);
}

.legal-page p{
  max-width: 100%;
  line-height: 1.65;
}

.legal-page p strong{
  display:block;
  margin-bottom:4px;
  font-weight:700;
}