/* ============================================================
   DIAMOND DAVE LA - standalone static site
   ============================================================ */

:root{
  --cream:#F4F1E9;
  --cream-2:#ECE7DA;
  --ink:#171613;
  --ink-2:#201E1A;
  --tan:#C2AD88;
  --tan-deep:#B09563;
  --muted:#6E685B;
  --muted-dark:#A7A092;
  --line:rgba(23,22,19,.14);
  --line-dark:rgba(244,241,233,.16);
  --maxw:1280px;
  --pad:clamp(20px,5vw,80px);
  --ease:cubic-bezier(.16,.84,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:"Space Grotesk",system-ui,sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- typography ---------- */
.display{
  font-family:"Archivo",sans-serif;
  font-weight:900;
  line-height:.94;
  letter-spacing:-.02em;
  text-transform:none;
}
.accent{
  font-family:"Instrument Serif",serif;
  font-weight:400;
  font-style:italic;
  letter-spacing:.01em;
  color:var(--tan-deep);
}
.eyebrow{
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--muted);
}
.dark .eyebrow{color:var(--tan)}
.lede{font-size:clamp(17px,1.5vw,20px);color:var(--muted);max-width:46ch}
.dark .lede{color:var(--muted-dark)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative}
.dark{background:var(--ink);color:var(--cream)}
.pad-y{padding-top:clamp(70px,11vw,150px);padding-bottom:clamp(70px,11vw,150px)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--pad);
  color:var(--cream);
  transition:padding .4s var(--ease),background .4s var(--ease),color .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.scrolled{
  background:rgba(244,241,233,.82);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:var(--ink);
  padding:14px var(--pad);
  box-shadow:0 1px 0 var(--line);
}
.nav__brand{font-family:"Archivo",sans-serif;font-weight:800;letter-spacing:-.01em;font-size:18px}
.nav__links{display:flex;gap:34px;align-items:center}
.nav__links a{font-size:15px;opacity:.85;transition:opacity .25s}
.nav__links a:hover{opacity:1}
.nav__cta{
  padding:11px 22px;border-radius:100px;font-weight:600;font-size:15px;
  background:var(--cream);color:var(--ink);
  transition:transform .25s var(--ease),background .3s,color .3s;
}
.nav.scrolled .nav__cta{background:var(--ink);color:var(--cream)}
@media(max-width:860px){.nav__links{display:none}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;border-radius:100px;font-weight:600;font-size:16px;
  transition:transform .3s var(--ease),background .3s,color .3s,box-shadow .3s;
  will-change:transform;
}
.btn--primary{background:var(--ink);color:var(--cream)}
.btn--primary.on-dark{background:var(--cream);color:var(--ink)}
.btn--ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.dark .btn--ghost{border-color:var(--line-dark);color:var(--cream)}
.btn--primary:hover{box-shadow:0 14px 34px rgba(23,22,19,.22)}
.btn .dot{width:8px;height:8px;border-radius:50%;background:#46d07f;box-shadow:0 0 0 4px rgba(70,208,127,.18)}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}

/* ============================================================
   HERO
   ============================================================ */
.hero{background:var(--ink);color:var(--cream);min-height:100vh;display:flex;align-items:center;padding-top:120px;padding-bottom:60px;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center;width:100%}
.hero__eyebrow{margin-bottom:26px}
.hero h1{font-size:clamp(54px,8.5vw,128px);margin-bottom:30px}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line span{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
.hero.in h1 .line span{transform:none}
.hero h1 .line:nth-child(2) span{transition-delay:.09s}
.hero h1 .line:nth-child(3) span{transition-delay:.18s}
.hero__lede{color:var(--muted-dark);font-size:clamp(16px,1.4vw,19px);max-width:42ch;margin-bottom:38px}
.hero__cta{margin-bottom:18px}
.hero__ig{font-size:14px;color:var(--muted-dark);letter-spacing:.03em}
.hero__fade{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease) .45s,transform .9s var(--ease) .45s}
.hero.in .hero__fade{opacity:1;transform:none}

.hero__media{position:relative}
.hero__imgwrap{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 40px 90px rgba(0,0,0,.45)}
.hero__imgwrap img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform 1.4s var(--ease)}
.hero.in .hero__imgwrap img{transform:scale(1)}
.hero__badge{
  position:absolute;top:16px;right:16px;z-index:2;
  background:rgba(20,19,16,.62);backdrop-filter:blur(8px);
  color:var(--cream);font-size:13px;font-weight:500;letter-spacing:.02em;
  padding:8px 14px;border-radius:100px;
  opacity:0;transition:opacity .8s ease .7s;
}
.hero.in .hero__badge{opacity:1}
.hero__stat{
  position:absolute;left:-18px;bottom:-22px;z-index:3;
  background:var(--cream);color:var(--ink);
  padding:18px 26px;border-radius:14px;box-shadow:0 24px 50px rgba(0,0,0,.3);
  opacity:0;transform:translateY(16px);transition:opacity .8s var(--ease) .8s,transform .8s var(--ease) .8s;
}
.hero.in .hero__stat{opacity:1;transform:none}
.hero__stat b{font-family:"Archivo";font-weight:900;font-size:34px;display:block;line-height:1}
.hero__stat span{font-size:13px;color:var(--muted);letter-spacing:.04em}
.scrollcue{position:absolute;left:var(--pad);bottom:26px;font-size:11px;letter-spacing:.3em;color:var(--muted-dark);display:flex;align-items:center;gap:10px}
.scrollcue::after{content:"";width:40px;height:1px;background:var(--muted-dark);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%,100%{transform:scaleX(.4);opacity:.4;transform-origin:left}50%{transform:scaleX(1);opacity:1;transform-origin:left}}
@media(max-width:860px){
  .hero__grid{grid-template-columns:1fr;gap:60px}
  .hero{min-height:auto}
  .hero__stat{left:auto;right:16px}
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--tan);color:var(--ink);padding:18px 0;overflow:hidden;white-space:nowrap;border-top:1px solid rgba(23,22,19,.1);border-bottom:1px solid rgba(23,22,19,.1)}
.marquee__track{display:inline-flex;gap:0;animation:marquee 32s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:"Archivo";font-weight:800;font-size:15px;letter-spacing:.06em;text-transform:uppercase;padding:0 26px;display:inline-flex;align-items:center;gap:26px}
.marquee__track span::after{content:"·";color:var(--tan-deep)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.shead{margin-bottom:clamp(40px,6vw,80px)}
.shead .eyebrow{margin-bottom:22px;display:block}
.shead h2{font-size:clamp(38px,5.6vw,82px);max-width:14ch}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
@media(max-width:860px){.two-col{grid-template-columns:1fr;gap:48px}}

/* ============================================================
   HOW IT WORKS - chat
   ============================================================ */
.how__text h2{font-size:clamp(38px,5.4vw,76px);margin-bottom:28px}
.how__text .lede{margin-bottom:34px}
.chat{display:flex;flex-direction:column;gap:30px}
.chat__group{}
.chat__tag{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.bubble{
  max-width:78%;padding:14px 18px;border-radius:20px;font-size:15.5px;line-height:1.45;margin-bottom:10px;
  opacity:0;transform:translateY(14px) scale(.98);transition:opacity .55s var(--ease),transform .55s var(--ease);
}
.bubble.is-visible{opacity:1;transform:none}
.bubble--in{background:var(--cream-2);color:var(--ink);border-bottom-left-radius:6px;margin-right:auto}
.bubble--out{background:var(--ink);color:var(--cream);border-bottom-right-radius:6px;margin-left:auto}
.chat__card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px}

/* ============================================================
   STEPS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(26px,3vw,46px);margin-top:30px}
.step__n{font-family:"Archivo";font-weight:900;font-size:18px;color:var(--tan);letter-spacing:.05em;margin-bottom:20px}
.step h3{font-family:"Archivo";font-weight:800;font-size:23px;margin-bottom:12px;line-height:1.15}
.step p{color:var(--muted-dark);font-size:15.5px}
.step{padding-top:26px;border-top:1px solid var(--line-dark)}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:8px}}

/* ============================================================
   THE DEAL
   ============================================================ */
.deal__text h2{font-size:clamp(40px,5.6vw,80px);margin-bottom:30px}
.deal__text p{color:var(--muted);margin-bottom:18px;max-width:48ch}
.deal__stats{display:flex;gap:30px;margin-top:38px;flex-wrap:wrap}
.deal__stat{border-top:1px solid var(--line);padding-top:14px;min-width:90px}
.deal__stat b{font-family:"Archivo";font-weight:900;font-size:clamp(30px,3.4vw,44px);display:block;line-height:1}
.deal__stat span{font-size:13px;color:var(--muted);letter-spacing:.04em}
.deal__media{display:grid;gap:18px}
.deal__media figure{border-radius:16px;overflow:hidden}
.deal__media img{width:100%;height:100%;object-fit:cover}
.deal__media .a{aspect-ratio:16/10}
.deal__media .b{aspect-ratio:16/9}

/* ============================================================
   SERVICES
   ============================================================ */
.svc__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:50px}
.svc__head h2{font-size:clamp(38px,5.4vw,78px)}
.svc__list{border-top:1px solid var(--line)}
.svc__row{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:30px 4px;border-bottom:1px solid var(--line);position:relative;
  transition:padding-left .4s var(--ease);
}
.svc__row::before{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--ink);transition:width .5s var(--ease)}
.svc__row:hover{padding-left:16px}
.svc__row:hover::before{width:100%}
.svc__row h3{font-family:"Archivo";font-weight:800;font-size:clamp(22px,2.4vw,30px);margin-bottom:4px}
.svc__row p{color:var(--muted);font-size:15px}
.svc__arrow{font-size:22px;transition:transform .4s var(--ease);color:var(--muted)}
.svc__row:hover .svc__arrow{transform:translateX(10px);color:var(--ink)}

/* ============================================================
   GALLERY
   ============================================================ */
.work__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:46px}
.work__head h2{font-size:clamp(38px,5.4vw,78px)}
.work__head a{color:var(--tan)}
.grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;gap:16px}
.grid figure{position:relative;overflow:hidden;border-radius:14px;background:#222}
.grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .6s}
.grid figure:hover img{transform:scale(1.06);filter:brightness(1.08)}
.grid .tall{grid-row:span 2;aspect-ratio:auto}
.grid .tall img{height:100%}
.grid .sq{aspect-ratio:1/1}
.grid .wide{grid-column:span 2;aspect-ratio:2/1}
@media(max-width:760px){
  .grid{grid-template-columns:1fr 1fr}
  .grid .tall{grid-row:span 1;aspect-ratio:1/1}
  .grid .wide{grid-column:span 2}
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}
.quote{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px}
.quote .stars{color:var(--tan-deep);letter-spacing:3px;margin-bottom:16px;font-size:14px}
.quote p{font-size:16px;margin-bottom:22px;line-height:1.5}
.quote .who{font-family:"Archivo";font-weight:800;font-size:16px}
.quote .what{color:var(--muted);font-size:13px;letter-spacing:.03em}
@media(max-width:860px){.quotes{grid-template-columns:1fr}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,70px);align-items:start}
.contact__intro h2{font-size:clamp(40px,5.6vw,80px);margin-bottom:26px}
.contact__intro .lede{margin-bottom:30px}
.contact__hours{margin-top:40px;border-top:1px solid var(--line);padding-top:22px;max-width:340px}
.contact__hours .eyebrow{margin-bottom:16px;display:block}
.hours-row{display:flex;justify-content:space-between;padding:7px 0;font-size:15px;color:var(--muted)}
.contact__portrait{margin-top:34px;border-radius:16px;overflow:hidden;aspect-ratio:5/4;max-width:420px}
.contact__portrait img{width:100%;height:100%;object-fit:cover}

.form{background:#fff;border:1px solid var(--line);border-radius:22px;padding:clamp(24px,3vw,38px)}
.form .field{margin-bottom:24px}
.form label.lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:12px}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{padding:9px 16px;border:1px solid var(--line);border-radius:100px;font-size:14px;color:var(--ink);background:var(--cream);transition:all .2s}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.form input[type=text],.form input[type=tel],.form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:16px;background:var(--cream);color:var(--ink);transition:border-color .2s;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--ink)}
.form textarea{resize:vertical;min-height:90px}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form button[type=submit]{width:100%;margin-top:6px;background:var(--ink);color:var(--cream);padding:17px;border-radius:100px;font-weight:600;font-size:16px;transition:transform .3s var(--ease),opacity .3s}
.form button[type=submit]:hover{box-shadow:0 14px 30px rgba(23,22,19,.2)}
.form__note{font-size:14px;margin-top:14px;text-align:center}
.form__note.ok{color:#2f8f55}
.form__note.err{color:#c0392b}
.hp{position:absolute;left:-9999px}
@media(max-width:860px){.contact__grid{grid-template-columns:1fr}.form .two{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:var(--cream);padding:70px var(--pad) 40px}
.footer__top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;border-bottom:1px solid var(--line-dark);padding-bottom:34px;margin-bottom:24px}
.footer__brand{font-family:"Archivo";font-weight:900;font-size:clamp(30px,5vw,60px);letter-spacing:-.02em}
.footer__links{display:flex;flex-direction:column;gap:10px;text-align:right;color:var(--muted-dark)}
.footer__links a:hover{color:var(--cream)}
.footer__bottom{font-size:13px;color:var(--muted-dark)}

/* ============================================================
   MOST WANTED - 3D-tilt product carousel
   ============================================================ */
.carousel{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center;margin-top:10px}
.car__stage{position:relative;perspective:1300px}
.car__frame{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;background:#0e0d0b;border:0.5px solid rgba(255,255,255,.09);transform-style:preserve-3d;transition:transform .5s var(--ease);will-change:transform}
.car__frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.05);transition:opacity .85s var(--ease),transform 1.3s var(--ease)}
.car__frame img.active{opacity:1;transform:scale(1)}
.car__glow{position:absolute;inset:0;pointer-events:none;border-radius:18px;box-shadow:inset 0 0 120px 24px rgba(0,0,0,.5)}
.car__hint{position:absolute;left:16px;bottom:14px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.4);pointer-events:none}
.car__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;background:rgba(20,18,14,.55);border:0.5px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--cream);transition:background .35s var(--ease)}
.car__nav:hover{background:rgba(48,42,32,.85)}
.car__prev{left:-12px}.car__next{right:-12px}
.car__index{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--tan);margin-bottom:18px}
.car__text{transition:opacity .4s var(--ease),transform .4s var(--ease)}
.car__name{font-family:"Archivo";font-weight:800;font-size:clamp(28px,3.6vw,46px);line-height:1.04;margin-bottom:14px}
.car__specs{color:var(--muted-dark);font-size:16px;line-height:1.5;margin-bottom:28px;max-width:34ch}
.car__cta{margin-bottom:30px}
.car__dots{display:flex;gap:10px}
.car__dot{width:9px;height:9px;border-radius:50%;background:rgba(244,241,233,.25);border:none;cursor:pointer;padding:0;transition:width .4s var(--ease),background .4s var(--ease),border-radius .4s var(--ease)}
.car__dot.active{width:26px;border-radius:5px;background:var(--tan)}
@media(max-width:860px){.carousel{grid-template-columns:1fr;gap:34px}.car__prev{left:8px}.car__next{right:8px}}

/* ============================================================
   SPIN SHOWCASE - drag-to-rotate 360 viewer
   ============================================================ */
.spin{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center;margin-top:10px}
.spin__stage{position:relative}
.spin__frame{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;background:#0e0d0b;border:0.5px solid rgba(255,255,255,.09);cursor:grab;touch-action:pan-y}
.spin__frame:active{cursor:grabbing}
.spin__v{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s var(--ease);pointer-events:none}
.spin__v.active{opacity:1}
.spin__glow{position:absolute;inset:0;pointer-events:none;border-radius:18px;box-shadow:inset 0 0 120px 24px rgba(0,0,0,.5)}
.spin__hint{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);pointer-events:none;display:flex;align-items:center;gap:8px}
.spin__hint::before{content:"";width:15px;height:15px;border:1px solid rgba(255,255,255,.4);border-radius:50%}
.spin__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;background:rgba(20,18,14,.55);border:0.5px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--cream);transition:background .35s var(--ease)}
.spin__nav:hover{background:rgba(48,42,32,.85)}
.spin__prev{left:-12px}.spin__next{right:-12px}
.spin__index{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--tan);margin-bottom:18px}
.spin__text{transition:opacity .4s var(--ease),transform .4s var(--ease)}
.spin__name{font-family:"Archivo";font-weight:800;font-size:clamp(28px,3.6vw,46px);line-height:1.04;margin-bottom:14px}
.spin__specs{color:var(--muted-dark);font-size:16px;line-height:1.5;margin-bottom:28px;max-width:34ch}
.spin__cta{margin-bottom:30px}
.spin__dots{display:flex;gap:10px}
.spin__dot{width:9px;height:9px;border-radius:50%;background:rgba(244,241,233,.25);border:none;cursor:pointer;padding:0;transition:width .4s var(--ease),background .4s var(--ease),border-radius .4s var(--ease)}
.spin__dot.active{width:26px;border-radius:5px;background:var(--tan)}
@media(max-width:860px){.spin{grid-template-columns:1fr;gap:34px}.spin__prev{left:8px}.spin__next{right:8px}}

/* ---------- no-JS / load-failure safety: always show content ---------- */
html:not(.js) .reveal,
html:not(.js) .hero__fade,
html:not(.js) .hero__badge,
html:not(.js) .hero__stat,
html:not(.js) .bubble{opacity:1!important;transform:none!important}
html:not(.js) .hero h1 .line span,
html:not(.js) .hero__imgwrap img{transform:none!important}

/* ============================================================
   reduced motion
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.hero__fade,.hero__badge,.hero__stat,.bubble{opacity:1!important;transform:none!important}
  .hero h1 .line span{transform:none!important}
  .hero__imgwrap img{transform:none!important}
  html{scroll-behavior:auto}
}
