*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --black: #080808; --black2: #111111; --black3: #1a1a1a;
  --gold: #c9a84c; --gold-light: #e8cc7e; --gold-dim: rgba(201,168,76,0.15);
  --white: #f5f0e8; --white-dim: rgba(245,240,232,0.80); --white-faint: rgba(245,240,232,0.08);
  --font-display: 'Playfair Display'; --font-body: 'Montserrat';
  --fs-2xs: 0.6rem; --fs-xs: 0.7rem; --fs-sm: 0.8rem; --fs-base: 0.9rem;
  --fs-md: 1.5rem; --fs-lg: 2rem; --fs-xl: 3.5rem;
  --fs-display: clamp(2.5rem, 5vw, 8rem);
}
html { scroll-behavior: smooth; overflow-x: hidden; }
body { background: var(--black); color: var(--white); font-family: var(--font-body); font-weight: 300; overflow-x: hidden; cursor: none; }

/* SKIP LINK */
.skip-link { position:absolute; top:-100%; left:1rem; z-index:9999; background:var(--gold); color:var(--black); padding:0.6rem 1.2rem; font-size:var(--fs-sm); font-weight:500; letter-spacing:0.1em; text-decoration:none; transition:top 0.1s; }
.skip-link:focus { top:1rem; }

/* HAMBURGER */
.nav-hamburger { display:none; flex-direction:column; justify-content:center; gap:5px; background:none; border:none; padding:0.4rem; cursor:pointer; z-index:600; flex-shrink:0; }
.nav-hamburger span { display:block; width:22px; height:1.5px; background:var(--white); transition:transform 0.3s ease, opacity 0.3s ease; transform-origin:center; }
.nav-hamburger[aria-expanded="true"] span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav-hamburger[aria-expanded="true"] span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-hamburger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.cursor { position: fixed; width: 8px; height: 8px; background: var(--gold); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); }
.cursor-follower { position: fixed; width: 36px; height: 36px; border: 1px solid rgba(201,168,76,0.4); border-radius: 50%; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: all 0.12s ease; }
body::before { content:''; position:fixed; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E"); pointer-events:none; z-index:1000; opacity:0.4; }

/* LOADER */
.loader { position:fixed; inset:0; background:var(--black); z-index:9000; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:2rem; transition:opacity 0.8s ease,visibility 0.8s ease; }
.loader.hidden { opacity:0; visibility:hidden; }
.loader-logo { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; letter-spacing:0.2em; }
.loader-logo span { color:var(--gold); }
.loader-line { width:0; height:1px; background:linear-gradient(to right,transparent,var(--gold),transparent); animation:loadLine 1.5s ease forwards; }
@keyframes loadLine { to { width:200px; } }

/* NAV */
nav { position:fixed; top:0; left:0; right:0; z-index:500; padding:2rem 4rem; display:flex; justify-content:space-between; align-items:center; transition:background 0.4s,padding 0.4s; }
nav.scrolled { background:rgba(8,8,8,0.95); backdrop-filter:blur(20px); padding:1.2rem 4rem; border-bottom:1px solid var(--white-faint); }
.nav-logo { font-family:var(--font-display); font-size:var(--fs-md); font-weight:400; letter-spacing:0.15em; color:var(--white); text-decoration:none; }
.nav-logo span { color:var(--gold); }
.nav-links { display:flex; gap:3rem; list-style:none; align-items:center; }
.nav-links a { color:var(--white-dim); text-decoration:none; font-size:var(--fs-xs); font-weight:400; letter-spacing:0.2em; text-transform:uppercase; transition:color 0.3s; position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; right:0; height:1px; background:var(--gold); transform:scaleX(0); transition:transform 0.3s; }
.nav-links a:hover { color:var(--white); }
.nav-links a:hover::after { transform:scaleX(1); }
.nav-cta { background:transparent !important; border:1px solid var(--gold) !important; color:var(--gold) !important; padding:0.6rem 1.5rem; font-size:var(--fs-xs) !important; letter-spacing:0.2em !important; text-transform:uppercase; text-decoration:none; transition:background 0.3s,color 0.3s !important; cursor:none; }
.nav-cta:hover { background:var(--gold) !important; color:var(--black) !important; }
.nav-cta::after { display:none !important; }

/* HERO */
.hero { min-height:100vh; display:flex; align-items:center; position:relative; overflow:hidden; padding:10rem 4rem 6rem; }
.hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 70% 50%,rgba(201,168,76,0.06) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(201,168,76,0.04) 0%,transparent 50%); }
.hero-line-v { position:absolute; top:0; right:25%; width:1px; height:100%; background:linear-gradient(to bottom,transparent,rgba(201,168,76,0.15),transparent); }
.hero-content { position:relative; z-index:1; max-width:900px; }
.hero-eyebrow { display:flex; align-items:center; gap:1.5rem; margin-bottom:2.5rem; opacity:0; animation:fadeUp 1s 1.8s forwards; }
.hero-eyebrow-line { width:40px; height:1px; background:var(--gold); }
.hero-eyebrow-text { font-size:var(--fs-xs); letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); }
.hero-title { font-family:var(--font-display); font-size:var(--fs-display); font-weight:400; line-height:1.0; letter-spacing:-0.02em; margin-bottom:3rem; opacity:0; animation:fadeUp 1s 2s forwards; }
.hero-title em { font-style:italic; color:var(--gold); display:block; }
.hero-bottom { display:flex; align-items:flex-end; gap:6rem; opacity:0; animation:fadeUp 1s 2.2s forwards; }
.hero-desc { max-width:380px; font-size:var(--fs-base); line-height:1.8; color:var(--white-dim); font-weight:300; }
.hero-actions { display:flex; flex-direction:column; gap:1rem; align-items:flex-start; }
.scroll-indicator { position:absolute; bottom:3rem; left:4rem; display:flex; align-items:center; gap:1rem; opacity:0; animation:fadeIn 1s 2.8s forwards; }
.scroll-line { width:60px; height:1px; background:rgba(245,240,232,0.2); position:relative; overflow:hidden; }
.scroll-line::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:var(--gold); animation:scrollLine 2s 3s ease-in-out infinite; }
@keyframes scrollLine { 0%{left:-100%} 100%{left:100%} }
.scroll-text { font-size:var(--fs-2xs); letter-spacing:0.25em; text-transform:uppercase; color:rgba(245,240,232,0.3); }

/* BUTTONS */
.btn-gold { display:inline-block; background:var(--gold); color:var(--black); padding:1rem 2.5rem; font-family:var(--font-body); font-size:var(--fs-xs); font-weight:500; letter-spacing:0.2em; text-transform:uppercase; text-decoration:none; transition:background 0.3s,transform 0.3s; position:relative; overflow:hidden; cursor:none; border:none; }
.btn-gold::before { content:''; position:absolute; inset:0; background:var(--gold-light); transform:translateX(-100%); transition:transform 0.3s ease; }
.btn-gold:hover::before { transform:translateX(0); }
.btn-gold span { position:relative; z-index:1; }
.btn-gold:hover { transform:translateY(-2px); }
.btn-outline { display:inline-block; border:1px solid rgba(245,240,232,0.2); color:var(--white-dim); padding:1rem 2.5rem; font-size:var(--fs-xs); letter-spacing:0.2em; text-transform:uppercase; text-decoration:none; transition:border-color 0.3s,color 0.3s,transform 0.3s; cursor:none; background:transparent; font-family:var(--font-body); font-weight:400; }
.btn-outline:hover { border-color:var(--gold); color:var(--white); transform:translateY(-2px); }

/* MARQUEE */
.marquee-section { border-top:1px solid var(--white-faint); border-bottom:1px solid var(--white-faint); padding:1.2rem 0; overflow:hidden; background:var(--black2); }
.marquee-track { display:flex; gap:4rem; animation:marquee 20s linear infinite; white-space:nowrap; }
.marquee-item { display:flex; align-items:center; gap:4rem; font-size:var(--fs-xs); letter-spacing:0.25em; text-transform:uppercase; color:var(--white-dim); flex-shrink:0; }
.marquee-dot { width:4px; height:4px; background:var(--gold); border-radius:50%; flex-shrink:0; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* SECTIONS */
section { padding:8rem 4rem; }
.section-inner { max-width:1200px; margin:0 auto; }
.section-label { display:flex; align-items:center; gap:1rem; margin-bottom:1.5rem; }
.section-label-line { width:30px; height:1px; background:var(--gold); }
.section-label-text { font-size:var(--fs-2xs); letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); }
.section-title { font-family:var(--font-display); font-size:var(--fs-display); font-weight:400; line-height:1.05; letter-spacing:-0.01em; }
.section-title em { font-style:italic; color:var(--gold); }

/* ABOUT */
.about { background:var(--black2); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:8rem; align-items:center; }
.about-text { color:var(--white-dim); line-height:1.9; font-size:var(--fs-base); margin-top:2rem; }
.about-text p+p { margin-top:1.2rem; }
.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:2px; margin-top:3rem; }
.stat-card { background:var(--black3); padding:2rem; border:1px solid var(--white-faint); transition:border-color 0.3s; }
.stat-card:hover { border-color:var(--gold-dim); }
.stat-num { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; color:var(--gold); line-height:1; margin-bottom:0.5rem; }
.stat-label { font-size:var(--fs-xs); letter-spacing:0.15em; text-transform:uppercase; color:var(--white-dim); }
.about-image-wrap { position:relative; aspect-ratio:3/4; background:var(--black3); overflow:hidden; }
.about-image-wrap::before { content:''; position:absolute; inset:-1px; border:1px solid var(--gold); transform:translate(12px,12px); z-index:-1; }
.about-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--black3) 0%,var(--black2) 100%); }
.about-placeholder-text { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; color:var(--gold); opacity:0.15; letter-spacing:0.1em; }

/* SERVICES */
.services { background:var(--black); }
.services-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:5rem; }
.services-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2px; }
.service-card { background:var(--black2); padding:3rem; border:1px solid var(--white-faint); position:relative; overflow:hidden; transition:border-color 0.4s; cursor:none; }
.service-card::before, .auto-card::before { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(to right,var(--gold),var(--gold-light)); transform:scaleX(0); transform-origin:left; transition:transform 0.4s ease; }
.service-card:hover { border-color:rgba(201,168,76,0.2); }
.service-card:hover::before { transform:scaleX(1); }
.service-num { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; color:var(--gold); opacity:0.12; position:absolute; top:1.5rem; right:2rem; line-height:1; }
.service-icon { font-size:var(--fs-lg); margin-bottom:1.5rem; }
.service-title { font-family:var(--font-display); font-size:var(--fs-lg); font-weight:400; margin-bottom:1rem; line-height:1.2; }
.service-title em { font-style:italic; color:var(--gold); }
.service-desc { color:var(--white-dim); font-size:var(--fs-base); line-height:1.8; margin-bottom:2rem; }
.service-features { list-style:none; display:flex; flex-direction:column; gap:0.5rem; }
.service-features li { font-size:var(--fs-sm); color:var(--white-dim); padding-left:1.2rem; position:relative; letter-spacing:0.05em; }
.service-features li::before, .auto-features li::before { content:'—'; position:absolute; left:0; color:var(--gold); }
.service-price { margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid var(--white-faint); display:flex; align-items:baseline; gap:0.5rem; }
.price-from { font-size:var(--fs-xs); letter-spacing:0.15em; text-transform:uppercase; color:var(--white-dim); }
.price-num { font-family:var(--font-display); font-size:var(--fs-lg); font-weight:400; color:var(--gold); }

/* AUTOMATION */
.automation { background:var(--black2); }
.auto-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:2rem; }
.auto-intro { font-size:var(--fs-base); color:var(--white-dim); line-height:1.8; max-width:600px; margin-bottom:5rem; }
.auto-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2px; }
.auto-card { background:var(--black); border:1px solid var(--white-faint); padding:3rem; position:relative; overflow:hidden; transition:border-color 0.4s; cursor:none; display:flex; flex-direction:column; }
.auto-card:hover { border-color:rgba(201,168,76,0.2); }
.auto-card:hover::before { transform:scaleX(1); }
.auto-num { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; color:var(--gold); opacity:0.12; position:absolute; top:1.5rem; right:2rem; line-height:1; }
.auto-icon { font-size:var(--fs-lg); margin-bottom:1.5rem; }
.auto-title { font-family:var(--font-display); font-size:var(--fs-lg); font-weight:400; margin-bottom:1rem; line-height:1.2; }
.auto-title em { font-style:italic; color:var(--gold); }
.auto-desc { color:var(--white-dim); font-size:var(--fs-base); line-height:1.8; margin-bottom:1.5rem; }
.auto-features { list-style:none; display:flex; flex-direction:column; gap:0.5rem; flex-grow:1; }
.auto-features li { font-size:var(--fs-sm); color:var(--white-dim); padding-left:1.2rem; position:relative; letter-spacing:0.05em; }
.auto-price { margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid var(--white-faint); }
.auto-price-row { display:flex; align-items:baseline; gap:0.5rem; }
.auto-price-row-mnd { display:flex; align-items:baseline; gap:0.4rem; margin-top:0.4rem; }
.price-note { font-size:var(--fs-xs); letter-spacing:0.1em; text-transform:uppercase; color:var(--white-dim); }
.price-mnd { font-family:var(--font-display); font-size:var(--fs-md); color:var(--gold); }
.auto-cta { text-align:center; margin-top:5rem; display:flex; flex-direction:column; align-items:center; gap:1rem; }
.why-card:hover { border-color:rgba(201,168,76,0.3) !important; }
/* BLOG */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:4rem; }
.blog-card { background:var(--black); border:1px solid var(--white-faint); padding:2.5rem; display:flex; flex-direction:column; transition:border-color 0.3s; }
.blog-card:hover { border-color:rgba(201,168,76,0.3); }
.blog-tag { font-size:var(--fs-2xs); letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:1.2rem; }
.blog-title { font-family:var(--font-display); font-size:var(--fs-md); font-weight:400; line-height:1.35; margin-bottom:1.2rem; color:var(--white); }
.blog-excerpt { font-size:var(--fs-sm); color:var(--white-dim); line-height:1.9; flex:1; margin-bottom:2rem; }
.blog-meta { font-size:var(--fs-xs); color:var(--white-dim); letter-spacing:0.08em; margin-bottom:1.5rem; }
.blog-link { font-size:var(--fs-xs); letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); text-decoration:none; border-bottom:1px solid rgba(201,168,76,0.3); padding-bottom:2px; transition:border-color 0.3s; align-self:flex-start; }
.blog-link:hover { border-color:var(--gold); }
.auto-cta-note { font-size:var(--fs-sm); color:var(--white-dim); }

/* PROCESS */
.process { background:var(--black); }
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:5rem; position:relative; }
.process-steps::before { content:''; position:absolute; top:2rem; left:calc(12.5% + 1.5rem); right:calc(12.5% + 1.5rem); height:1px; background:linear-gradient(to right,var(--gold),rgba(201,168,76,0.1)); }
.process-step { padding:0 2rem; }
.step-num { width:4rem; height:4rem; border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:var(--fs-md); color:var(--gold); margin-bottom:2rem; background:var(--black2); position:relative; z-index:1; }
.step-title { font-family:var(--font-display); font-size:var(--fs-md); font-weight:400; margin-bottom:0.8rem; }
.step-desc { font-size:var(--fs-sm); color:var(--white-dim); line-height:1.7; }

/* PRICING */
.pricing { background:var(--black); }
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:5rem; }
.pricing-card { background:var(--black2); border:1px solid var(--white-faint); padding:3rem; position:relative; transition:border-color 0.3s; }
.pricing-card.featured { background:var(--black3); border-color:var(--gold); }
.pricing-card:hover { border-color:rgba(201,168,76,0.3); }
.featured-badge { position:absolute; top:-1px; left:50%; transform:translateX(-50%); background:var(--gold); color:var(--black); font-size:var(--fs-2xs); letter-spacing:0.2em; text-transform:uppercase; padding:0.3rem 1.2rem; font-weight:500; }
.pricing-name { font-family:var(--font-display); font-size:var(--fs-md); font-weight:400; margin-bottom:0.5rem; }
.pricing-tagline { font-size:var(--fs-sm); color:var(--white-dim); margin-bottom:2rem; }
.pricing-price { margin-bottom:2rem; padding-bottom:2rem; border-bottom:1px solid var(--white-faint); }
.pricing-amount { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; color:var(--gold); line-height:1; }
.pricing-currency { font-size:var(--fs-md); vertical-align:super; }
.pricing-period { font-size:var(--fs-sm); color:var(--white-dim); margin-top:0.3rem; }
.pricing-features { list-style:none; display:flex; flex-direction:column; gap:0.8rem; margin-bottom:2.5rem; }
.pricing-features li { font-size:var(--fs-sm); color:var(--white-dim); display:flex; align-items:center; gap:0.8rem; }
.pricing-features li::before { content:'✓'; color:var(--gold); font-size:var(--fs-sm); flex-shrink:0; }
.pricing-features li.dim { opacity:0.35; }
.pricing-features li.dim::before { content:'×'; color:rgba(245,240,232,0.3); }

/* MONTHLY */
.monthly { background:var(--black2); }
.monthly-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:5rem; }
.monthly-card { background:var(--black); border:1px solid var(--white-faint); padding:2.5rem; transition:border-color 0.3s,transform 0.3s; }
.monthly-card:hover { border-color:rgba(201,168,76,0.3); transform:translateY(-4px); }
.monthly-price { font-family:var(--font-display); font-size:var(--fs-xl); color:var(--gold); margin-bottom:0.3rem; }
.monthly-period { font-size:var(--fs-xs); color:var(--white-dim); letter-spacing:0.1em; margin-bottom:1.5rem; }
.monthly-name { font-family:var(--font-display); font-size:var(--fs-md); margin-bottom:1rem; }
.monthly-features { list-style:none; display:flex; flex-direction:column; gap:0.6rem; }
.monthly-features li { font-size:var(--fs-sm); color:var(--white-dim); padding-left:1rem; position:relative; }
.monthly-features li::before { content:'—'; position:absolute; left:0; color:var(--gold); }

/* CONTACT */
.contact { background:var(--black); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:8rem; align-items:start; }
.contact-text { color:var(--white-dim); line-height:1.9; margin-top:2rem; margin-bottom:3rem; font-size:var(--fs-base); }
.contact-details { display:flex; flex-direction:column; gap:1.5rem; }
.contact-detail { display:flex; align-items:flex-start; gap:1.5rem; }
.contact-detail-icon { color:var(--gold); font-size:var(--fs-base); margin-top:0.1rem; flex-shrink:0; }
.contact-detail-label { font-size:var(--fs-2xs); letter-spacing:0.2em; text-transform:uppercase; color:rgba(245,240,232,0.3); margin-bottom:0.3rem; }
.contact-detail-value { font-size:var(--fs-base); color:var(--white); }
.contact-detail-value a { color:var(--gold); text-decoration:none; }
.contact-form-simple { display:flex; flex-direction:column; gap:1.5rem; }
.form-input-s { background:var(--black2); border:1px solid var(--white-faint); padding:1rem 1.2rem; color:var(--white); font-family:var(--font-body); font-size:var(--fs-base); font-weight:300; outline:none; transition:border-color 0.3s; width:100%; }
.form-input-s:focus { border-color:var(--gold); }
.form-input-s::placeholder { color:rgba(245,240,232,0.2); }
textarea.form-input-s { resize:vertical; min-height:120px; }
.form-row-s { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.form-label-s { font-size:var(--fs-2xs); letter-spacing:0.2em; text-transform:uppercase; color:var(--white-dim); display:block; margin-bottom:0.6rem; }
select.form-input-s { appearance:none; cursor:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c9a84c' fill='none' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.5rem; background-color:var(--black2); }
select.form-input-s option { background:#111; }
.form-submit-s { background:var(--gold); color:var(--black); border:none; padding:1.1rem 2.5rem; font-family:var(--font-body); font-size:var(--fs-xs); font-weight:500; letter-spacing:0.2em; text-transform:uppercase; cursor:none; transition:background 0.3s,transform 0.3s; align-self:flex-start; }
.form-submit-s:hover { background:var(--gold-light); transform:translateY(-2px); }

/* FOOTER */
footer { background:var(--black2); border-top:1px solid var(--white-faint); padding:4rem; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:4rem; }
.footer-logo { font-family:var(--font-display); font-size:var(--fs-lg); font-weight:400; letter-spacing:0.1em; }
.footer-logo span { color:var(--gold); }
.footer-tagline { font-size:var(--fs-sm); color:var(--white-dim); margin-top:0.5rem; }
.footer-links { display:flex; gap:6rem; }
.footer-col-title { font-size:var(--fs-2xs); letter-spacing:0.25em; text-transform:uppercase; color:var(--gold); margin-bottom:1.5rem; }
.footer-col-links { list-style:none; display:flex; flex-direction:column; gap:0.8rem; }
.footer-col-links a { color:var(--white-dim); text-decoration:none; font-size:var(--fs-sm); transition:color 0.3s; }
.footer-col-links a:hover { color:var(--white); }
.footer-bottom { border-top:1px solid var(--white-faint); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-size:var(--fs-xs); color:rgba(245,240,232,0.25); }
.footer-gold-line { width:40px; height:1px; background:var(--gold); opacity:0.4; }

/* ONBOARDING PANEL */
.onboard-overlay {
  position:fixed; inset:0; z-index:800;
  background:var(--black);
  transform:translateX(100%);
  transition:transform 0.6s cubic-bezier(0.77,0,0.175,1);
  overflow-y:auto;
}
.onboard-overlay.open { transform:translateX(0); }
.onboard-close {
  position:fixed; top:2rem; right:2rem; z-index:901;
  background:none; border:1px solid var(--white-faint);
  color:var(--white-dim); width:3rem; height:3rem;
  font-size:var(--fs-md); cursor:none;
  transition:border-color 0.3s,color 0.3s;
  display:none; align-items:center; justify-content:center;
}
.onboard-overlay.open ~ .onboard-close,
.onboard-close.visible { display:flex; }
.onboard-close:hover { border-color:var(--gold); color:var(--gold); }

.onboard-inner { max-width:800px; margin:0 auto; padding:6rem 4rem 8rem; }
.onboard-header { text-align:center; margin-bottom:4rem; padding-bottom:3rem; border-bottom:1px solid var(--white-faint); }
.onboard-back { display:inline-flex; align-items:center; gap:0.8rem; font-size:var(--fs-xs); letter-spacing:0.2em; text-transform:uppercase; color:var(--white-dim); background:none; border:none; cursor:none; margin-bottom:3rem; transition:color 0.3s; }
.onboard-back:hover { color:var(--gold); }
.onboard-label { display:flex; align-items:center; justify-content:center; gap:1rem; margin-bottom:1.5rem; }
.onboard-label-line { width:30px; height:1px; background:var(--gold); }
.onboard-label-text { font-size:var(--fs-2xs); letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); }
.onboard-title { font-family:var(--font-display); font-size:var(--fs-display); font-weight:400; line-height:1.1; margin-bottom:1rem; }
.onboard-title em { font-style:italic; color:var(--gold); }
.onboard-desc { color:var(--white-dim); font-size:var(--fs-base); line-height:1.8; max-width:500px; margin:0 auto; }

/* PROGRESS */
.progress-wrap { margin-bottom:4rem; }
.progress-bar-ob { display:flex; align-items:center; }
.progress-step-ob { flex:1; display:flex; flex-direction:column; align-items:center; gap:0.8rem; position:relative; }
.progress-step-ob:not(:last-child)::after { content:''; position:absolute; top:1.25rem; left:60%; right:-40%; height:1px; background:var(--white-faint); transition:background 0.5s; }
.progress-step-ob.done:not(:last-child)::after { background:var(--gold); }
.step-dot-ob { width:2.5rem; height:2.5rem; border:1px solid var(--white-faint); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:var(--fs-xs); font-weight:500; color:var(--white-dim); background:var(--black); transition:all 0.4s; position:relative; z-index:1; }
.progress-step-ob.active .step-dot-ob { border-color:var(--gold); color:var(--gold); background:var(--gold-dim); }
.progress-step-ob.done .step-dot-ob { border-color:var(--gold); background:var(--gold); color:var(--black); }
.step-label-ob { font-size:var(--fs-2xs); letter-spacing:0.1em; text-transform:uppercase; color:var(--white-dim); text-align:center; }
.progress-step-ob.active .step-label-ob { color:var(--gold); }

/* FORM STEPS */
.ob-section { display:none; animation:fadeUp 0.5s ease forwards; }
.ob-section.active { display:block; }
.ob-sec-header { margin-bottom:2.5rem; padding-bottom:1.5rem; border-bottom:1px solid var(--white-faint); }
.ob-sec-num { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; color:var(--gold); opacity:0.12; line-height:1; margin-bottom:-0.8rem; }
.ob-sec-title { font-family:var(--font-display); font-size:var(--fs-lg); font-weight:400; }
.ob-sec-title em { font-style:italic; color:var(--gold); }
.ob-sec-sub { font-size:var(--fs-sm); color:var(--white-dim); margin-top:0.4rem; line-height:1.6; }

.fg { display:flex; flex-direction:column; gap:0.6rem; margin-bottom:1.5rem; }
.fl { font-size:var(--fs-2xs); letter-spacing:0.2em; text-transform:uppercase; color:var(--white-dim); }
.fl span { color:var(--gold); }
.fi { background:var(--black2); border:1px solid var(--white-faint); padding:0.9rem 1.2rem; color:var(--white); font-family:var(--font-body); font-size:var(--fs-base); font-weight:300; outline:none; transition:border-color 0.3s; width:100%; }
.fi:focus { border-color:var(--gold); }
.fi::placeholder { color:rgba(245,240,232,0.2); }
textarea.fi { resize:vertical; min-height:90px; }
select.fi { appearance:none; cursor:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c9a84c' fill='none' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.5rem; background-color:var(--black2); }
select.fi option { background:#111; }
.fgrid2 { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.fgrid3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:1.2rem; }

.choice-grid-ob { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:0.8rem; margin-bottom:1.5rem; }
.ch-item { display:none; }
.ch-label { display:flex; flex-direction:column; gap:0.5rem; padding:1.2rem; border:1px solid var(--white-faint); background:var(--black2); cursor:none; transition:all 0.3s; text-align:center; }
.ch-item:checked + .ch-label { border-color:var(--gold); background:var(--gold-dim); }
.ch-label:hover { border-color:rgba(201,168,76,0.3); }
.ch-icon { font-size:1.4rem; }
.ch-text { font-size:var(--fs-xs); }

.style-grid-ob { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; margin-bottom:1.5rem; }
.st-opt { display:none; }
.st-card { padding:1.5rem; border:1px solid var(--white-faint); background:var(--black2); cursor:none; transition:all 0.3s; }
.st-opt:checked + .st-card { border-color:var(--gold); background:var(--gold-dim); }
.st-card:hover { border-color:rgba(201,168,76,0.3); }
.st-name { font-family:var(--font-display); font-size:var(--fs-md); margin-bottom:0.3rem; }
.st-desc { font-size:var(--fs-xs); color:var(--white-dim); line-height:1.5; }

.color-opts { display:flex; flex-wrap:wrap; gap:0.8rem; margin-bottom:1.5rem; }
.col-opt { display:none; }
.col-sw { width:3rem; height:3rem; border:2px solid transparent; cursor:none; transition:all 0.3s; position:relative; }
.col-opt:checked + .col-sw { border-color:var(--gold); transform:scale(1.15); }
.col-sw::after { content:''; position:absolute; inset:-4px; border:1px solid var(--white-faint); }

.toggle-row { display:flex; align-items:center; gap:1rem; padding:1rem 1.2rem; border:1px solid var(--white-faint); background:var(--black2); margin-bottom:0.8rem; }
.toggle-info { flex:1; }
.toggle-name { font-size:var(--fs-base); }
.toggle-sub { font-size:var(--fs-xs); color:var(--white-dim); margin-top:0.2rem; }
.tog { position:relative; width:44px; height:24px; flex-shrink:0; }
.tog input { opacity:0; width:0; height:0; }
.tog-slider { position:absolute; inset:0; background:var(--black3); border:1px solid var(--white-faint); transition:0.3s; cursor:none; }
.tog-slider::before { content:''; position:absolute; width:16px; height:16px; left:3px; bottom:3px; background:var(--white-dim); transition:0.3s; }
.tog input:checked + .tog-slider { background:var(--gold-dim); border-color:var(--gold); }
.tog input:checked + .tog-slider::before { transform:translateX(20px); background:var(--gold); }

.upload-zone-ob { border:1px dashed rgba(201,168,76,0.3); background:var(--black2); padding:2.5rem 2rem; text-align:center; cursor:none; transition:all 0.3s; position:relative; margin-bottom:1.5rem; }
.upload-zone-ob:hover { border-color:var(--gold); background:var(--gold-dim); }
.upload-zone-ob input { position:absolute; inset:0; opacity:0; cursor:none; width:100%; height:100%; }
.upload-icon-ob { font-size:var(--fs-lg); margin-bottom:0.8rem; color:var(--gold); }
.upload-title-ob { font-family:var(--font-display); font-size:var(--fs-base); margin-bottom:0.4rem; }
.upload-sub-ob { font-size:var(--fs-xs); color:var(--white-dim); }
.upload-files-ob { display:flex; flex-wrap:wrap; gap:0.5rem; margin-top:0.8rem; }
.uf-tag { background:var(--gold-dim); border:1px solid rgba(201,168,76,0.3); padding:0.3rem 0.8rem; font-size:var(--fs-xs); color:var(--gold); display:flex; align-items:center; gap:0.5rem; }
.uf-tag button { background:none; border:none; color:var(--gold); cursor:none; font-size:var(--fs-base); padding:0; }

.ob-nav { display:flex; justify-content:space-between; align-items:center; margin-top:3rem; padding-top:2rem; border-top:1px solid var(--white-faint); }
.btn-prev-ob { background:none; border:1px solid var(--white-faint); color:var(--white-dim); padding:0.9rem 2rem; font-family:var(--font-body); font-size:var(--fs-xs); font-weight:400; letter-spacing:0.15em; text-transform:uppercase; cursor:none; transition:all 0.3s; }
.btn-prev-ob:hover { border-color:var(--white-dim); color:var(--white); }
.btn-next-ob { background:var(--gold); border:none; color:var(--black); padding:0.9rem 2.5rem; font-family:var(--font-body); font-size:var(--fs-xs); font-weight:500; letter-spacing:0.2em; text-transform:uppercase; cursor:none; transition:all 0.3s; }
.btn-next-ob:hover { background:var(--gold-light); transform:translateY(-2px); }
.ob-step-count { font-size:var(--fs-xs); letter-spacing:0.15em; color:var(--white-dim); }
.ob-step-count strong { color:var(--gold); }

/* SUCCESS */
.ob-success { display:none; text-align:center; padding:4rem 0; animation:fadeUp 0.6s ease forwards; }
.ob-success.active { display:block; }
.ob-success-icon { font-size:var(--fs-xl); margin-bottom:1.5rem; animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }
.ob-success-title { font-family:var(--font-display); font-size:var(--fs-xl); font-weight:400; margin-bottom:1rem; }
.ob-success-title em { font-style:italic; color:var(--gold); }
.ob-success-text { color:var(--white-dim); font-size:var(--fs-base); line-height:1.8; max-width:450px; margin:0 auto 2.5rem; }
.ob-success-items { display:flex; flex-direction:column; gap:0.8rem; align-items:center; margin-bottom:3rem; }
.ob-success-item { font-size:var(--fs-sm); color:var(--white-dim); display:flex; align-items:center; gap:0.8rem; }
.ob-success-item::before { content:'✓'; color:var(--gold); }

/* COOKIE BANNER */
#cookieBanner { position:fixed; bottom:0; left:0; right:0; z-index:8000; background:rgba(8,8,8,0.97); border-top:1px solid rgba(201,168,76,0.25); backdrop-filter:blur(20px); padding:1.4rem 4rem; display:flex; align-items:center; justify-content:space-between; gap:2rem; transform:translateY(100%); transition:transform 0.5s cubic-bezier(0.16,1,0.3,1); }
#cookieBanner.visible { transform:translateY(0); }
.cookie-text { font-size:var(--fs-sm); color:var(--white-dim); line-height:1.7; max-width:680px; }
.cookie-text a { color:var(--gold); text-decoration:none; border-bottom:1px solid rgba(201,168,76,0.3); transition:border-color 0.3s; }
.cookie-text a:hover { border-color:var(--gold); }
.cookie-actions { display:flex; gap:0.8rem; flex-shrink:0; align-items:center; }
.cookie-btn-accept { background:var(--gold); border:none; color:var(--black); padding:0.65rem 1.6rem; font-family:var(--font-body); font-size:var(--fs-xs); font-weight:500; letter-spacing:0.18em; text-transform:uppercase; cursor:none; transition:background 0.3s; white-space:nowrap; }
.cookie-btn-accept:hover { background:var(--gold-light); }
.cookie-btn-decline { background:none; border:1px solid var(--white-faint); color:var(--white-dim); padding:0.65rem 1.2rem; font-family:var(--font-body); font-size:var(--fs-xs); font-weight:400; letter-spacing:0.18em; text-transform:uppercase; cursor:none; transition:all 0.3s; white-space:nowrap; }
.cookie-btn-decline:hover { border-color:var(--white-dim); color:var(--white); }
@media(max-width:900px){ #cookieBanner { flex-direction:column; align-items:flex-start; padding:1.2rem 1.5rem; gap:1rem; } .cookie-actions { width:100%; } .cookie-btn-accept,.cookie-btn-decline { flex:1; text-align:center; } }

/* ANIMATIONS */
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.reveal { opacity:0; transform:translateY(30px); transition:opacity 0.9s ease,transform 0.9s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* MOBILE */
@media(max-width:900px){
  nav { padding:1.5rem 1.5rem; }
  nav.scrolled { padding:1rem 1.5rem; }
  /* Hamburger visible; nav-links become slide-in overlay */
  .nav-hamburger { display:flex; }
  .nav-links {
    position:fixed; inset:0; z-index:490;
    background:rgba(8,8,8,0.97); backdrop-filter:blur(24px);
    flex-direction:column; align-items:center; justify-content:center; gap:2.5rem;
    transform:translateX(100%); transition:transform 0.45s cubic-bezier(0.77,0,0.175,1);
    padding:2rem;
  }
  .nav-links.open { transform:translateX(0); }
  .nav-links li { width:100%; text-align:center; }
  .nav-links a { font-size:var(--fs-base); letter-spacing:0.15em; }
  .nav-cta { display:inline-block; width:auto; margin-top:0.5rem; }
  section { padding:5rem 1.5rem; }
  .hero { padding:8rem 1.5rem 5rem; }
  .hero-bottom { flex-direction:column; gap:3rem; }
  .about-grid,.contact-grid { grid-template-columns:1fr; gap:4rem; }
  .services-grid,.pricing-grid,.monthly-grid,.auto-grid { grid-template-columns:1fr; }
  .auto-header { flex-direction:column; align-items:flex-start; gap:2rem; }
  .process-steps { grid-template-columns:1fr 1fr; }
  .process-steps::before { display:none; }
  .about-stats { grid-template-columns:1fr 1fr; }
  /* Clamp about-image offset so it cannot overflow narrow viewports */
  .about-image-wrap::before { transform:translate(6px,6px); }
  .footer-top { flex-direction:column; gap:3rem; }
  .footer-links { flex-direction:column; gap:2.5rem; }
  .form-row-s { grid-template-columns:1fr; }
  footer { padding:3rem 1.5rem; }
  .cursor,.cursor-follower { display:none; }
  body { cursor:auto; }
  .services-header { flex-direction:column; align-items:flex-start; gap:2rem; }
  .onboard-inner { padding:5rem 1.5rem 6rem; }
  .fgrid2,.fgrid3 { grid-template-columns:1fr; }
  .style-grid-ob { grid-template-columns:1fr; }
  .step-label-ob { display:none; }
  .onboard-close { top:1rem; right:1rem; }
  /* Prevent hero title from overflowing at very narrow widths */
  .hero-title { font-size:var(--fs-display); word-break:break-word; }
  /* Blog grid single column */
  .blog-grid { grid-template-columns:1fr; }
}
