@import url('https://api.fontshare.com/v2/css?f[]=satoshi@400,500,600,700,800,900&display=swap');

:root{
  /* Palette: BMW steel blue + warm near-black surfaces + white gold accent */
  --bg:#080b10;
  --surface:rgba(255,255,255,.04);
  --text:#f0f2f5;
  --muted:#8a94a6;
  --line:rgba(255,255,255,.09);
  --blue:#1c6bba;
  --blue-light:#4a90d9;
  --gold:#c9a84c;
  --green:#3aaa6a;
  --radius:20px;
  --font:'Satoshi',ui-sans-serif,system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}

html,body{
  min-height:100%;
  background:#080b10;
  color:var(--text);
  font-family:var(--font);
  -webkit-font-smoothing:antialiased;
}

/* Subtle warm gradient background -- no orbs, just depth */
body::before{
  content:'';
  position:fixed;
  inset:0;
  background:
    radial-gradient(ellipse 60% 40% at 80% 0%,rgba(28,107,186,.10),transparent),
    radial-gradient(ellipse 50% 50% at 10% 100%,rgba(201,168,76,.06),transparent);
  pointer-events:none;
  z-index:0;
}

.app{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px 48px;}
.shell{width:100%;max-width:960px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:28px;overflow:hidden;backdrop-filter:blur(12px);box-shadow:0 24px 60px rgba(0,0,0,.45);}

/* Top bar */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02);}
.brand-name{display:block;font-size:1rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--text);}
.brand-sub{display:block;font-size:.78rem;color:var(--muted);margin-top:2px;}
.meta{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.85rem;}
.dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(58,170,106,.7);flex-shrink:0;}

/* Progress */
.progress-wrap{padding:14px 28px 0;}
.progress-row{display:flex;justify-content:space-between;color:var(--muted);font-size:.82rem;margin-bottom:8px;}
.progress-track{height:5px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;}
.progress-fill{height:100%;background:var(--blue);border-radius:999px;transition:width .4s ease;}

/* Hero */
.hero-wrap{padding:40px 36px 44px;}
.eyebrow{display:inline-block;padding:6px 14px;border-radius:999px;background:rgba(28,107,186,.12);border:1px solid rgba(28,107,186,.25);color:#a8c8f0;font-size:.8rem;letter-spacing:.04em;margin-bottom:20px;}

h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:900;letter-spacing:-.035em;line-height:1.04;margin-bottom:20px;color:var(--text);}
.lead{color:#c8d4e4;font-size:1.05rem;line-height:1.68;max-width:700px;margin-bottom:12px;}
.asterisk{color:var(--muted);font-size:.8rem;line-height:1.6;max-width:660px;margin-bottom:22px;}

.badge-row{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:28px;}
.chip{padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);font-size:.85rem;color:#d0dae8;}

/* Buttons -- solid, no gradients */
.btn-hero{
  display:inline-block;
  background:var(--blue);
  color:#fff;
  font-weight:700;
  font-size:1.05rem;
  padding:15px 30px;
  border-radius:14px;
  border:none;
  cursor:pointer;
  box-shadow:0 8px 24px rgba(28,107,186,.28);
  transition:background .18s ease,transform .18s ease,box-shadow .18s ease;
  text-decoration:none;
}
.btn-hero:hover{background:#1a5ea8;transform:translateY(-2px);box-shadow:0 12px 30px rgba(28,107,186,.35);}

/* Steps */
.step-wrap{padding:30px 36px 38px;}
.step-kicker{text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:#a8c8f0;margin-bottom:10px;font-weight:600;}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:10px;color:var(--text);}
.step-desc{color:var(--muted);font-size:.96rem;line-height:1.62;margin-bottom:24px;max-width:680px;}

/* Choice cards */
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:24px;}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr));}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr));}

.choice{
  width:100%;text-align:left;
  padding:18px 16px;
  border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--line);
  cursor:pointer;
  transition:border-color .18s,background .18s,transform .18s;
  display:flex;flex-direction:column;gap:7px;min-height:100px;
}
.choice:hover{border-color:rgba(28,107,186,.45);background:rgba(28,107,186,.08);transform:translateY(-2px);}
.choice.selected{border-color:rgba(74,144,217,.7);background:rgba(28,107,186,.13);box-shadow:0 0 0 1px rgba(74,144,217,.2);}
.choice-emoji{font-size:1.6rem;line-height:1}
.choice-title{font-size:.98rem;font-weight:700;display:block;color:var(--text);}
.choice-desc{font-size:.86rem;color:#b0bfd4;line-height:1.4}

/* Input cards */
.input-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;display:grid;gap:16px;margin-bottom:24px;}
.field-group{display:grid;gap:7px;}
.field-group label{font-weight:600;font-size:.88rem;color:#d4dde8;}
.field-group input,.field-group textarea,.field-group select{
  width:100%;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  padding:12px 15px;
  border-radius:13px;
  outline:none;
  transition:border-color .18s,background .18s;
  color:var(--text);
  font-family:var(--font);
}
.field-group input:focus,.field-group textarea:focus,.field-group select:focus{border-color:rgba(74,144,217,.55);background:rgba(255,255,255,.07);}
.field-group textarea{min-height:110px;resize:vertical}
.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}

/* Range sliders */
.range-display{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:13px;margin-bottom:10px;}
.range-display .range-label{color:var(--muted);font-size:.88rem}
.range-display strong{font-size:1.6rem;font-weight:800;letter-spacing:-.03em;color:var(--text);}
input[type="range"]{width:100%;accent-color:var(--blue-light);height:5px;cursor:pointer;background:transparent;border:none;padding:0;}

/* Tick / info box */
.tick-box{display:flex;align-items:flex-start;gap:10px;background:rgba(58,170,106,.07);border:1px solid rgba(58,170,106,.18);color:#c8f0db;padding:13px 16px;border-radius:13px;font-size:.88rem;line-height:1.5;}
.hint{color:var(--muted);font-size:.8rem;line-height:1.55;}

/* Navigation */
.nav{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:6px;}

.btn{
  background:var(--blue);
  color:#fff;
  font-weight:700;
  padding:13px 26px;
  border-radius:13px;
  border:none;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(28,107,186,.22);
  transition:background .18s,transform .18s;
  text-decoration:none;
  display:inline-block;
  font-family:var(--font);
  font-size:.95rem;
}
.btn:hover{background:#1a5ea8;transform:translateY(-1px);}

.btn-ghost{
  background:rgba(255,255,255,.05);
  color:var(--text);
  font-weight:600;
  padding:13px 20px;
  border-radius:13px;
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;
  transition:background .18s;
  text-decoration:none;
  display:inline-block;
  font-family:var(--font);
  font-size:.95rem;
}
.btn-ghost:hover{background:rgba(255,255,255,.09);}

/* Summary */
.summary-grid{display:grid;gap:9px;margin-bottom:26px;}
.summary-item{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:15px;padding:13px 16px;}
.summary-item b{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#a8c8f0;margin-bottom:4px;}

/* Success / thank you */
.success-wrap{background:rgba(58,170,106,.08);border:1px solid rgba(58,170,106,.18);border-radius:22px;padding:32px;}
.success-wrap h2{font-size:2.2rem;margin-bottom:10px;}
.success-wrap p{color:#c8d4e4;font-size:.98rem;line-height:1.65;margin-bottom:20px;max-width:600px;}
.btn-row{display:flex;flex-wrap:wrap;gap:10px;}

/* Model body style step */
.model-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:26px;}
.model-card{position:relative;width:100%;text-align:center;padding:18px 12px 15px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);cursor:pointer;transition:border-color .18s,background .18s,transform .18s;display:flex;flex-direction:column;align-items:center;gap:9px;}
.model-card:hover{border-color:rgba(28,107,186,.45);background:rgba(28,107,186,.08);transform:translateY(-2px);}
.model-card.selected{border-color:rgba(74,144,217,.7);background:rgba(28,107,186,.13);box-shadow:0 0 0 1px rgba(74,144,217,.2);}
.tick-indicator{position:absolute;top:9px;right:9px;width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.18);background:transparent;display:flex;align-items:center;justify-content:center;font-size:.65rem;transition:.18s ease;}
.model-card.selected .tick-indicator{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:900;}
.model-svg-wrap{width:100%;max-width:160px;color:#7aa8d4;padding:3px 0;}
.model-svg-wrap svg{width:100%;height:auto;}
.model-name{font-size:.92rem;font-weight:700;color:var(--text);display:block;}
.model-examples{font-size:.73rem;color:var(--muted);line-height:1.4;display:block;}
.select-hint{color:#a8c8f0;font-size:.8rem;margin-bottom:16px;}

/* Checklist items (thankyou + ap6) */
.checklist-item{display:flex;gap:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:18px;}
.check-icon{width:34px;height:34px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;flex-shrink:0;}
.check-body{display:flex;flex-direction:column;gap:5px;}
.check-body strong{font-size:.98rem;font-weight:700;color:var(--text);}
.check-body span{color:var(--muted);font-size:.86rem;line-height:1.5;}

/* Star rating (appraisal condition) */
.rating-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.05);}
.rating-row:last-child{border-bottom:none}
.rating-label{font-size:.93rem;font-weight:600;color:var(--text);flex:1;}
.stars{display:flex;gap:5px;}
.star{font-size:1.3rem;cursor:pointer;opacity:.28;transition:.12s ease;line-height:1;}
.star.on{opacity:1;}

/* Photo guide cards */
.photo-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:15px;padding:13px;display:flex;gap:10px;align-items:flex-start;}
.photo-num{width:26px;height:26px;border-radius:50%;background:rgba(28,107,186,.22);border:1px solid rgba(28,107,186,.35);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#a8c8f0;flex-shrink:0;}
.photo-info strong{font-size:.88rem;font-weight:700;display:block;margin-bottom:2px;color:var(--text);}
.photo-info span{font-size:.76rem;color:var(--muted);line-height:1.4;}

@media(max-width:700px){
  .hero-wrap,.step-wrap{padding:22px 18px 28px}
  .topbar{padding:13px 18px}
  .grid,.grid.three,.two-col{grid-template-columns:1fr}
  .model-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  h1{font-size:1.9rem}
  h2{font-size:1.55rem}
}
@media(max-width:420px){
  .model-grid{grid-template-columns:1fr;}
}


/* ── SHOWROOM IMAGERY ───────────────────────────────────────── */

/* Cinematic strip — horizontal scrolling banner between sections */
.showroom-strip {
  width: 100%;
  overflow: hidden;
  position: relative;
  height: 220px;
  margin: 0;
}
@media(min-width:600px){ .showroom-strip{ height:300px; } }

.strip-track {
  display: flex;
  height: 100%;
  width: max-content;
  animation: stripScroll 32s linear infinite;
}
.strip-track:hover { animation-play-state: paused; }

.strip-img {
  height: 100%;
  width: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
  flex: 0 0 auto;
display: block;
  filter: brightness(0.78) saturate(0.9);
  transition: filter .4s;
}
.strip-img:hover { filter: brightness(0.95) saturate(1.1); }

@keyframes stripScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Full-bleed section divider with parallax-style overlay */
.showroom-divider {
  position: relative;
  width: 100%;
  height: 340px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media(min-width:600px){ .showroom-divider{ height:420px; } }

.showroom-divider .div-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.45) saturate(0.8);
  transform: scale(1.05);
  transition: transform 8s ease;
}
.showroom-divider:hover .div-bg { transform: scale(1.0); }

.showroom-divider .div-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(10,14,20,0.55) 0%,
    rgba(10,14,20,0.10) 40%,
    rgba(10,14,20,0.10) 60%,
    rgba(10,14,20,0.70) 100%
  );
}
.showroom-divider .div-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 24px;
}
.showroom-divider .div-content h3 {
  font-size: clamp(1.3rem, 3.5vw, 2.1rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.25;
  text-shadow: 0 2px 20px rgba(0,0,0,0.6);
  margin-bottom: 8px;
}
.showroom-divider .div-content p {
  font-size: clamp(.82rem, 2vw, 1rem);
  color: rgba(255,255,255,0.75);
  max-width: 52ch;
  margin: 0 auto;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
}

/* Floating gallery thumbnails row */
.gallery-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 24px 0;
}
@media(min-width:520px){
  .gallery-row { grid-template-columns: repeat(3, 1fr); gap: 12px; }
}
.gallery-thumb {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
}
.gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease, filter .3s;
  filter: brightness(0.8) saturate(0.85);
}
.gallery-thumb:hover img {
  transform: scale(1.06);
  filter: brightness(0.95) saturate(1.05);
}
.gallery-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.45) 100%);
  border-radius: 14px;
}

/* Lightbox */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.lightbox.open { display: flex; }
.lightbox img {
  max-width: 100%;
  max-height: 90vh;
  border-radius: 12px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.8);
  object-fit: contain;
}
.lightbox-close {
  position: absolute;
  top: 16px; right: 20px;
  font-size: 2rem;
  color: #fff;
  cursor: pointer;
  background: none;
  border: none;
  line-height: 1;
  opacity: 0.7;
}
.lightbox-close:hover { opacity: 1; }

/* ── Testimonials ─────────────────────────── */
.testimonials {
  padding: 40px 0 8px;
}
.testimonials-kicker {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bmw-blue);
  margin-bottom: 16px;
}
.testimonial-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px) {
  .testimonial-grid { grid-template-columns: 1fr 1fr; }
}
.testimonial-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 20px 22px;
}
.testimonial-stars {
  color: #f5c518;
  font-size: 1rem;
  margin-bottom: 10px;
  letter-spacing: 2px;
}
.testimonial-quote {
  font-size: .88rem;
  line-height: 1.65;
  color: #c8d0dc;
  margin: 0 0 12px;
  font-style: italic;
}
.testimonial-attr {
  font-size: .75rem;
  color: #6b7684;
  font-weight: 600;
}
/* Inline / single-card variant used in pro.html & thankyou.html */
.testimonial-strip {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.testimonial-strip::-webkit-scrollbar { display: none; }
.testimonial-strip .testimonial-card {
  min-width: 280px;
  flex-shrink: 0;
}
/* service.html full-width banner variant */
.testimonial-banner {
  background: rgba(28,105,212,.08);
  border-top: 1px solid rgba(28,105,212,.18);
  border-bottom: 1px solid rgba(28,105,212,.18);
  padding: 32px 0;
  margin: 40px 0;
}
.testimonial-banner .testimonial-grid {
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 900px) {
  .testimonial-banner .testimonial-grid { grid-template-columns: repeat(4, 1fr); }
}
