/* ---------- CSS DESIGN SYSTEM ---------- */
:root {
  --bg: #0f0d0a;
  --bg-alt: #17130f;
  --surface: #1f1a14;
  --surface-alt: #262017;
  --glass: rgba(255,255,255,0.04);
  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.18);
  --text: #f5efe7;
  --text-dim: #c9baaa;
  --brand: #d9c07c;
  --brand-accent: #e7d39b;
  --brand-soft: #b99d58;
  --brand-deep: #7a5a2a;
  --accent-rose: #c27a65;
  --error: #ff635d;
  --focus: #ffe2a6;
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 28px;
  --shadow-xs: 0 1px 2px -1px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.04) inset;
  --shadow-sm: 0 4px 12px -3px rgba(0,0,0,.5),0 2px 4px -1px rgba(0,0,0,.4);
  --shadow: 0 8px 28px -6px rgba(0,0,0,.6),0 4px 16px -4px rgba(0,0,0,.55);
  --gradient-brand: linear-gradient(135deg,#d9c07c,#c27a65 55%,#805b3a 120%);
  --gradient-soft: linear-gradient(135deg,rgba(217,192,124,.18),rgba(194,122,101,.12) 55%,rgba(128,91,58,.2) 120%);
  --blur-sm: saturate(180%) blur(14px);
  font-synthesis: none;
  color-scheme: dark;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin:0; font-family:'Plus Jakarta Sans',system-ui,sans-serif; background:var(--bg); color:var(--text); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
img { max-width:100%; display:block; }
a { color:var(--brand); text-decoration:none;}
a:hover { color:var(--brand-accent); }

/* Typography */
h1,h2,h3,h4 { font-family: 'Marcellus',serif; font-weight:400; letter-spacing:.5px; line-height:1.12; }
:where(h1){ font-size:clamp(2.6rem,6vw,4.2rem); }
:where(h2){ font-size:clamp(2rem,4vw,3.1rem); }
:where(h3){ font-size:clamp(1.3rem,2.4vw,1.65rem); }
.lead { font-size: clamp(1.05rem,1.55vw,1.25rem); line-height:1.5; max-width: 54ch; }
.small { font-size:.85rem; }
.tiny { font-size:.7rem; text-transform:uppercase; letter-spacing:1.5px; font-weight:600; opacity:.7; }
.dim { color:var(--text-dim); }

p { line-height:1.6; max-width:70ch; }

/* Layout */
.container { width:min(1180px,92%); margin-inline:auto; }
.flex { display:flex; }
.align-center { align-items:center; }
.between { justify-content:space-between; }
.center { text-align:center; }
.max-60 { max-width:60ch; margin-inline:auto; }
.full-vh{ min-height:100svh; }

.section { padding: clamp(4rem,9vw,7rem) 0; position:relative; }
.section.alt { background:radial-gradient(circle at 30% 10%,rgba(217,192,124,.08),transparent 70%),var(--bg-alt); }
.section-title { position:relative; margin:0 0 1.5rem; }
.section-title::after { content:""; position:absolute; left:0; bottom:-.6rem; width:64px; height:2px; background:var(--gradient-brand); border-radius:2px; }
.center .section-title::after { left:50%; translate:-50% 0; }

.two-col { display:grid; gap:clamp(2rem,6vw,4rem); grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); align-items:center; }

/* Header */
.site-header { position:fixed; inset:0 0 auto; z-index:80; backdrop-filter:var(--blur-sm); background:linear-gradient(rgba(15,13,10,.8),rgba(15,13,10,.65)); border-bottom:1px solid var(--border); transition:background .35s,border .35s,padding .4s; padding: .9rem 0; }
.site-header.shrink { padding:.4rem 0; background:rgba(15,13,10,.9); }
.brand-mark { font-size:1.5rem; font-weight:600; letter-spacing:.5px; background:var(--gradient-brand); background-clip:text; -webkit-background-clip:text; color:transparent; display:inline-block; font-family:Marcellus,serif; }
.brand-mark.small{ font-size:1.25rem; }

.main-nav { position:relative; }
.nav-toggle { display:none; flex-direction:column; gap:6px; background:transparent; border:0; cursor:pointer; padding:.4rem; }
.nav-toggle span { width:26px; height:2px; background:var(--text); display:block; border-radius:2px; transition:.4s; }

.nav-list { list-style:none; margin:0; padding:0; display:flex; gap:1.8rem; }
.nav-list a { font-weight:500; font-size:.95rem; position:relative; padding:.4rem .2rem; }
.nav-list a.nav-cta { background:var(--gradient-brand); color:#1d140b; padding:.75rem 1.15rem; border-radius:12px; font-weight:600; box-shadow:0 4px 14px -6px rgba(0,0,0,.55); letter-spacing:.5px; }
.nav-list a.nav-cta:hover { filter:brightness(1.08); box-shadow:0 6px 20px -8px rgba(0,0,0,.65); }
.nav-list a::after { content:""; position:absolute; left:0; bottom:.2rem; width:0; height:2px; background:var(--brand); transition:.4s; }
.nav-list a:hover::after, .nav-list a:focus-visible::after { width:100%; }
.pill { border-radius:14px; }
.pill:hover { filter:brightness(1.05); }

/* Remove old hero styles by overriding / replacing */
.hero, .hero-grid, .hero-copy, .hero-panel, .scroll-hint { display:none !important; }

/* New Hero Styles */
.hero-new { position:relative; min-height:84vh; display:flex; align-items:center; isolation:isolate; }
.hero-new .hero-bg { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1591360056684-0797babc3ebb?auto=format&fit=crop&w=1600&q=60') center/cover no-repeat; filter:brightness(.72) saturate(1.15); }
.hero-new .hero-overlay-new { position:absolute; inset:0; background:linear-gradient(120deg,rgba(15,13,10,0.85) 0%,rgba(15,13,10,0.6) 55%,rgba(15,13,10,0.9) 100%); backdrop-filter:blur(4px); }
.hero-inner { position:relative; padding: clamp(4rem,8vw,6rem) 0 clamp(3rem,6vw,5rem); }
.hero-content { max-width: 740px; }
.hero-content h1 { margin:0 0 1.2rem; font-size: clamp(2.6rem,6vw,4.1rem); line-height:1.07; letter-spacing:.5px; background:var(--gradient-brand); background-clip:text; -webkit-background-clip:text; color:transparent; }
.hero-content .subtitle { margin:0 0 2rem; font-size: clamp(1.05rem,1.6vw,1.28rem); line-height:1.55; color:var(--text-dim); max-width:60ch; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.6rem; }
.hero-micro { display:flex; flex-wrap:wrap; gap:.9rem 1.4rem; font-size:.68rem; letter-spacing:1.2px; text-transform:uppercase; font-weight:600; color:var(--text-dim); opacity:.85; }
.hero-micro span { position:relative; padding-left:1rem; }
.hero-micro span::before { content:""; position:absolute; left:0; top:50%; width:6px; height:6px; background:var(--brand); border-radius:50%; transform:translateY(-50%); box-shadow:0 0 0 4px rgba(217,192,124,.15); }

@media (max-width:820px){
  .hero-new { min-height:78vh; }
  .hero-content h1 { font-size: clamp(2.35rem,8.5vw,3.2rem); }
}
@media (max-width:540px){
  .hero-new { min-height:72vh; }
  .hero-actions { flex-direction:column; align-items:flex-start; }
  .hero-actions .btn { width:100%; }
  .hero-micro { gap:.6rem .9rem; }
}

/* Cards & Surfaces */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.6rem 1.4rem; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; }
.card::before { content:""; position:absolute; inset:0; background:var(--gradient-soft); opacity:.55; pointer-events:none; }
.glass { background:var(--glass); backdrop-filter:var(--blur-sm); }

.badges { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.2rem; }
.badges span { background:var(--surface-alt); padding:.55rem .9rem; border-radius:100px; font-size:.7rem; letter-spacing:1px; text-transform:uppercase; font-weight:600; border:1px solid var(--border); }

.media-stack { position:relative; display:grid; place-items:center; }
.media-stack figure { margin:0; }
.media-stack img { border-radius:20px; box-shadow:var(--shadow); border:1px solid var(--border-strong); }
.media-stack .tilt { transform:rotate(-3deg) translateX(-6%); }
.media-stack .float { position:absolute; width:52%; bottom:-8%; right:2%; transform:rotate(6deg); box-shadow:0 12px 40px -10px rgba(0,0,0,.65); }

/* Services */
.card-grid { display:grid; gap:clamp(1.4rem,3vw,2rem); margin-top:3rem; }
.services-grid { grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); }
.service-card { padding:1.4rem 1.2rem 1.6rem; position:relative; border:1px solid var(--border); border-radius:var(--radius-sm); background:linear-gradient(145deg,var(--surface) 10%,var(--surface-alt) 100%); box-shadow:var(--shadow-xs); overflow:hidden; }
.service-card::after { content:""; position:absolute; inset:0; background:radial-gradient(circle at 20% 0%,rgba(217,192,124,.18),transparent 65%); opacity:.7; pointer-events:none; }
.service-card h3 { margin:0 0 .5rem; font-size:1.1rem; }
.service-card p { font-size:.9rem; margin:0 0 1.3rem; }
.tags { display:flex; gap:.5rem; }
.tags span { background:rgba(255,255,255,.07); padding:.4rem .7rem; font-size:.65rem; letter-spacing:.5px; border-radius:100px; font-weight:600; text-transform:uppercase; }

.minimal-services .service-card p { font-size:.82rem; }

/* Journey */
.journey-steps { display:grid; gap:2rem; margin-top:3rem; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); }
.step { position:relative; padding:1.3rem 1.1rem 1.4rem 1.2rem; border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--surface); box-shadow:var(--shadow-xs); }
.step .num { width:34px; height:34px; display:grid; place-items:center; background:var(--gradient-brand); color:#2a1c0d; font-weight:700; font-size:.85rem; border-radius:50%; margin-bottom:.8rem; box-shadow:0 4px 10px -2px rgba(0,0,0,.6); }
.step h3 { margin:.1rem 0 .4rem; font-size:1.05rem; }
.step p { font-size:.85rem; margin:0; }

/* Benefits */
.benefit-list { list-style:none; padding:0; margin:3rem 0 0; display:grid; gap:1.8rem; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.benefit { background:var(--surface); padding:1.3rem 1.1rem; border:1px solid var(--border); border-radius:var(--radius-sm); position:relative; overflow:hidden; box-shadow:var(--shadow-xs); }
.benefit::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 90%,rgba(194,122,101,.16),transparent 70%); opacity:.7; }
.benefit .icon { width:30px; height:4px; border-radius:4px; background:var(--gradient-brand); margin:0 0 .9rem; }
.benefit h3 { margin:0 0 .4rem; font-size:1.05rem; }
.benefit p { margin:0; font-size:.82rem; line-height:1.4; }

/* Testimonials Slider */
.slider { margin-top:3rem; position:relative; }
.slides { position:relative; overflow:hidden; }
.slide { opacity:0; transform:translateX(30px); transition:.8s cubic-bezier(.6,.2,.2,1); position:absolute; top:0; left:0; width:100%; }
.slide.active { opacity:1; transform:translateX(0); position:relative; }
.slide blockquote { font-size:clamp(1.1rem,2.1vw,1.6rem); line-height:1.4; margin:0 0 1.1rem; font-family:Marcellus,serif; font-weight:400; letter-spacing:.5px; }
.slide figcaption { font-size:.85rem; letter-spacing:1px; font-weight:600; color:var(--brand-accent); text-transform:uppercase; }
.slider-dots { display:flex; gap:.6rem; justify-content:center; margin-top:1.4rem; }
.slider-dots button { width:10px; height:10px; border-radius:50%; background:var(--border); border:0; cursor:pointer; position:relative; }
.slider-dots button.active { background:var(--brand); box-shadow:0 0 0 4px rgba(217,192,124,.18); }
.slider-dots button:hover { filter:brightness(1.2); }

/* Gallery */
.masonry { columns:3 280px; column-gap:1rem; margin-top:3rem; }
.masonry img { width:100%; margin:0 0 1rem; border-radius:18px; break-inside:avoid; border:1px solid var(--border); box-shadow:var(--shadow-xs); filter:grayscale(.2) saturate(1.1) contrast(1.02); transition:.6s; }
.masonry img:hover { filter:grayscale(0) saturate(1.25) contrast(1.06); transform:translateY(-4px); }

/* Pricing */
.pricing-grid { display:grid; gap:clamp(1.4rem,3vw,2.2rem); grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); margin-top:3rem; }
.price-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem 1.2rem 1.8rem; position:relative; overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.price-card.highlight { background:linear-gradient(145deg,var(--surface-alt),var(--surface)); border-color:var(--border-strong); box-shadow:0 10px 38px -10px rgba(0,0,0,.7),0 4px 18px -6px rgba(0,0,0,.5); }
.price-card .badge { position:absolute; top:.85rem; right:.85rem; background:var(--gradient-brand); color:#2a1c0d; font-size:.6rem; letter-spacing:1px; font-weight:700; padding:.4rem .55rem; border-radius:6px; }
.price-card h3 { margin:0 0 .6rem; font-size:1.2rem; }
.price { font-size:2.2rem; font-family:Marcellus,serif; margin:.2rem 0 1.2rem; letter-spacing:1px; background:var(--gradient-brand); background-clip:text; -webkit-background-clip:text; color:transparent; }
.price span { font-size:1rem; margin-right:.2rem; font-weight:500; }
.price-card ul { list-style:none; padding:0; margin:0 0 1.6rem; display:grid; gap:.55rem; font-size:.78rem; }
.price-card ul li { display:flex; gap:.4rem; align-items:flex-start; }
.price-card a.btn { margin-top:auto; }
.note { font-size:.75rem; opacity:.7; margin-top:2rem; }

.compact-pricing { grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
.price-card.simple { display:flex; flex-direction:column; align-items:flex-start; padding:1.1rem 1rem 1.2rem; }
.price-card.simple h3 { font-size:1rem; margin:0 0 .3rem; }
.price-card.simple .price { font-size:1.6rem; margin:0 0 .4rem; }
.price-card.simple p.small { margin:0; }
.small-micro { gap:.8rem; font-size:.6rem; }

/* Contact */
.contact-grid { align-items:start; }
.contact-list { list-style:none; padding:0; margin:1.6rem 0 2rem; display:grid; gap:.8rem; font-size:.85rem; }
.contact-form { display:grid; gap:1rem; background:var(--surface); padding:1.6rem 1.4rem 1.8rem; border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow-sm); }
.contact-form label { display:grid; gap:.4rem; font-size:.75rem; letter-spacing:1px; text-transform:uppercase; font-weight:600; }
.contact-form input, .contact-form select, .contact-form textarea { background:var(--surface-alt); border:1px solid var(--border); color:var(--text); padding:.8rem .9rem; font:inherit; border-radius:var(--radius-sm); resize:vertical; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { outline:2px solid var(--focus); outline-offset:2px; }
.form-status { min-height:1.2rem; font-size:.8rem; }

/* Final CTA */
.cta-final { background:linear-gradient(145deg,#1d1812,#2a2117); text-align:center; }
.cta-final h2 { font-size:clamp(2rem,5vw,3rem); margin:0 0 1rem; }
.cta-final p { margin:0 0 2rem; }

/* Footer */
.site-footer { background:#0d0b08; padding:4rem 0 3rem; border-top:1px solid var(--border); }
.footer-grid { display:grid; gap:3rem; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.foot-links { list-style:none; padding:0; margin:0; display:grid; gap:.6rem; }
.foot-links a { font-size:.85rem; color:var(--text-dim); }
.foot-links a:hover { color:var(--brand); }
.legal { margin-top:1.6rem; }

/* Buttons */
.btn { --btn-bg:var(--surface); --btn-color:var(--text); --btn-border:var(--border); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; gap:.6rem; font-weight:600; padding:.85rem 1.3rem; border-radius:var(--radius-sm); font-size:.85rem; letter-spacing:.5px; text-transform:uppercase; background:var(--btn-bg); color:var(--btn-color); border:1px solid var(--btn-border); position:relative; overflow:hidden; transition:.45s cubic-bezier(.65,.05,.36,1); }
.btn.primary { --btn-bg:var(--gradient-brand); --btn-color:#1d140b; --btn-border:var(--brand-soft); }
.btn.secondary { --btn-bg:linear-gradient(145deg,var(--surface),var(--surface-alt)); }
.btn.ghost { background:transparent; border:1px solid var(--border); }
.btn.subtle { background:var(--surface-alt); }
.btn.small { padding:.65rem 1rem; font-size:.7rem; }
.btn.xl { padding:1.1rem 2.2rem; font-size:.95rem; border-radius:var(--radius); }
.btn.stretch { width:100%; }
.btn:hover { filter:brightness(1.07); box-shadow:0 6px 22px -8px rgba(0,0,0,.7); transform:translateY(-2px); }
.btn:active { transform:translateY(0); box-shadow:0 3px 12px -6px rgba(0,0,0,.7); }
.btn:focus-visible { outline:2px solid var(--focus); outline-offset:2px; }

/* Effects & Animations */
.accent-fade { color:var(--brand); font-weight:300; }
.accent-gradient { background:var(--gradient-brand); background-clip:text; -webkit-background-clip:text; color:transparent; font-weight:400; }
.fade-in { opacity:0; transform:translateY(40px); transition:1s cubic-bezier(.55,.1,.25,1); }
.fade-in.visible { opacity:1; transform:translateY(0); }
.reveal { opacity:0; transform:translateY(30px); }
.reveal.visible { animation:popIn .8s .1s cubic-bezier(.65,.05,.36,1) forwards; }
@keyframes popIn { to { opacity:1; transform:translateY(0);} }

/* --- Sleek Mode: reduce animations & motion --- */
.hero-media, .hero-new .hero-bg { animation:none !important; }
.fade-in, .reveal { opacity:1 !important; transform:none !important; transition:none !important; }
.fade-in.visible, .reveal.visible { opacity:1; transform:none; }
.btn { transition:background .35s ease, color .35s ease, box-shadow .35s ease; }
.btn:hover { transform:none; box-shadow:0 4px 16px -6px rgba(0,0,0,.55); }
.service-card, .step, .benefit, .price-card, .quality-card { transition:background .4s ease, border-color .4s ease, box-shadow .4s ease, transform .4s ease; }
.service-card:hover, .step:hover, .benefit:hover, .price-card:hover, .quality-card:hover { transform:translateY(-2px); }
/* Remove scroll hint styles if any leftover */
.scroll-hint { display:none !important; }
/* Respect reduced motion explicitly */
@media (prefers-reduced-motion: reduce) { * { animation:none !important; transition:none !important; } }
