:root{
  --ink:#0a0a0c;
  --panel:#121214;
  --line:rgba(217,178,100,.16);
  --text:#f2efe8;
  --muted:#a8a49b;
  --gold:#d9b264;
  --gold-soft:#e9d195;
  --gold-grad:linear-gradient(180deg,#f0dba4 0%,#d9b264 45%,#a87f33 100%);
  --blackletter:'UnifrakturMaguntia',serif;
  --display:'Marcellus',serif;
  --body:'Manrope',sans-serif;
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--text);font-family:var(--body);font-size:1.0625rem;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--gold-soft);text-decoration:none}
h1,h2,h3{font-family:var(--display);font-weight:400;line-height:1.15}
.wrap{max-width:1180px;margin:0 auto;padding:0 1.4rem}

/* Nav */
header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(10,10,12,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav-logo{display:flex;align-items:center;padding:.2rem .4rem;border-radius:10px;transition:background .2s}
.nav-logo img{height:44px;width:auto;display:block;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.nav-logo:hover{background:rgba(217,178,100,.08)}
.nav-links{display:flex;align-items:center;gap:1.6rem;font-size:.95rem;font-weight:600}
.nav-links a{color:var(--muted);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--gold-soft)}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:var(--gold-soft);font-size:1.3rem;padding:.25rem .7rem;border-radius:8px;cursor:pointer}

/* Buttons */
.btn{display:inline-block;background:var(--gold-grad);color:#1a1405!important;font-weight:800;padding:.78rem 1.6rem;border-radius:999px;letter-spacing:.01em;transition:transform .15s,box-shadow .15s}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(217,178,100,.25)}
.btn-ghost{background:none;border:1px solid var(--gold);color:var(--gold-soft)!important}
.btn-ghost:hover{box-shadow:0 10px 30px rgba(217,178,100,.12)}

/* Hero, full-bleed cinematic */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-start;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(10,10,12,.7) 0%,rgba(10,10,12,.1) 32%,rgba(10,10,12,.5) 66%,rgba(10,10,12,.97) 100%),
  radial-gradient(900px 500px at 15% 90%,rgba(217,178,100,.1),transparent 60%)}
.hero-content{position:relative;z-index:2;width:100%;max-width:780px;margin:0;padding:7.5rem 1.4rem 5.5rem clamp(1.4rem,4vw,3.5rem)}
.hero-logo{width:min(480px,82vw);filter:drop-shadow(0 10px 36px rgba(0,0,0,.65))}
.hero-tag{font-family:var(--display);font-size:clamp(1.35rem,3.4vw,2.2rem);letter-spacing:.06em;margin-top:1.1rem;color:var(--gold-soft);text-shadow:0 2px 14px rgba(0,0,0,.6)}
.hero-sub{color:var(--text);max-width:560px;margin:1.2rem 0 2rem;font-size:clamp(1rem,1.5vw,1.15rem);text-shadow:0 2px 12px rgba(0,0,0,.8)}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.gbadge{display:inline-flex;align-items:center;gap:.55rem;margin-top:1.9rem;padding:.6rem 1.2rem;border:1px solid var(--line);border-radius:999px;font-size:.92rem;color:var(--text);background:rgba(10,10,12,.5);backdrop-filter:blur(8px)}
.gbadge b{color:var(--text)}
.scroll-hint{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:2;color:var(--muted);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
.stars{color:var(--gold);letter-spacing:.1em}

/* Service cards with photos (home) */
.scards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.3rem}
.scard{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s,border-color .2s}
.scard:hover{transform:translateY(-5px);border-color:rgba(217,178,100,.45)}
.scard-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.scard-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.scard:hover .scard-img img{transform:scale(1.06)}
.scard-img .num{position:absolute;top:.7rem;left:.9rem;margin:0;background:rgba(10,10,12,.7);padding:.2rem .6rem;border-radius:999px;backdrop-filter:blur(4px)}
.scard-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.scard-body h3{font-size:1.25rem;margin-bottom:.5rem}
.scard-body p{color:var(--muted);font-size:.96rem;flex:1}
.scard-body .more{margin-top:1rem}

/* Why / feature band */
.why{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.3rem}
.why-item{padding:1.6rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(217,178,100,.05),transparent)}
.why-item .wnum{font-family:var(--display);color:var(--gold);font-size:2rem;display:block;margin-bottom:.6rem}
.why-item h3{font-size:1.12rem;margin-bottom:.5rem}
.why-item p{color:var(--muted);font-size:.94rem}

/* Process steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.3rem;counter-reset:step}
.step{position:relative;padding:1.6rem 1.4rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--display);color:var(--gold);font-size:1.4rem;display:block;margin-bottom:.7rem}
.step h3{font-size:1.1rem;margin-bottom:.45rem}
.step p{color:var(--muted);font-size:.93rem}

/* Wrap process detail */
.proc-detail{margin-top:2.6rem;padding:2.2rem 2rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(217,178,100,.05),transparent)}
.proc-detail h3{font-size:1.3rem;margin-bottom:.5rem}
.proc-intro{color:var(--muted);margin-bottom:1.4rem}
.proc-steps{list-style:none;counter-reset:pstep;max-width:780px}
.proc-steps li{position:relative;padding:0 0 1.5rem 3rem;color:var(--muted);line-height:1.55}
.proc-steps li:last-child{padding-bottom:0}
.proc-steps li::before{counter-increment:pstep;content:counter(pstep);position:absolute;left:0;top:-.15rem;width:1.95rem;height:1.95rem;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:.92rem;color:#1a1405;background:var(--gold-grad);border-radius:999px;z-index:1}
.proc-steps li::after{content:"";position:absolute;left:.95rem;top:1.95rem;bottom:0;width:1px;background:var(--line)}
.proc-steps li:last-child::after{display:none}

/* Info strip */
.infobar{display:flex;flex-wrap:wrap;gap:1.4rem 2.6rem;justify-content:center;text-align:center}
.infobar>div{min-width:150px}
.infobar .lbl{display:block;font-size:.74rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.infobar .val{font-family:var(--display);font-size:1.15rem;color:var(--text)}

/* Page hero */
.page-hero{text-align:center;padding:9.5rem 1rem 4.5rem;background:radial-gradient(700px 380px at 50% 0%,rgba(217,178,100,.12),transparent 62%),var(--ink);border-bottom:1px solid var(--line)}
.page-hero h1{font-family:var(--display);font-size:clamp(2.8rem,7vw,4.6rem);letter-spacing:.01em;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero p{color:var(--muted);max-width:560px;margin:1rem auto 0}

/* Feature photo band */
.photo-band{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:0}
.photo-band img{width:100%;height:clamp(240px,40vw,460px);object-fit:cover;display:block}
.photo-band figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.6rem 1.4rem .9rem;background:linear-gradient(transparent,rgba(10,10,12,.85));color:var(--text);font-size:.95rem}
.photo-band figcaption b{font-family:var(--display);color:var(--gold-soft)}

/* Sections */
.section{padding:5rem 0;border-top:1px solid var(--line)}
.section-head{text-align:left;max-width:640px;margin-bottom:2.6rem}
.eyebrow{display:block;font-size:.8rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:.8rem}
.section-head p{color:var(--muted)}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.2rem}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem 1.6rem;transition:transform .2s,border-color .2s}
.card:hover{transform:translateY(-4px);border-color:rgba(217,178,100,.4)}
.num{font-family:var(--display);color:var(--gold);font-size:.95rem;letter-spacing:.15em;display:block;margin-bottom:.9rem}
.card h3{font-size:1.25rem;margin-bottom:.6rem}
.card p{color:var(--muted);font-size:.97rem}
.more{display:inline-block;margin-top:1rem;font-size:.92rem;font-weight:700}

/* Service rows */
.svc-row{display:grid;grid-template-columns:360px 1fr;gap:2.6rem;padding:2.6rem 0;border-bottom:1px solid var(--line)}
.svc-row:last-child{border-bottom:none}
.svc-media img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line);margin-bottom:1.1rem}
.svc-row h3{font-size:1.5rem;margin-top:.3rem}
.svc-row p{color:var(--muted)}
.svc-row ul{margin:1rem 0 0 1.2rem;color:var(--muted)}
.svc-row li{margin-bottom:.4rem}

/* Filters */
.filters{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-bottom:2.4rem}
.filter-btn{background:var(--panel);border:1px solid var(--line);color:var(--muted);font-family:var(--body);font-weight:700;font-size:.9rem;letter-spacing:.02em;padding:.6rem 1.3rem;border-radius:999px;cursor:pointer;transition:all .2s}
.filter-btn:hover{color:var(--gold-soft);border-color:rgba(217,178,100,.4)}
.filter-btn.active{background:var(--gold-grad);color:#1a1405;border-color:transparent}

/* Gallery */
.ggrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.2rem}
.ggrid figure img{transition:transform .4s ease}
.ggrid figure:hover img{transform:scale(1.05)}
.ggrid figure{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.ggrid img{width:100%;aspect-ratio:4/3;object-fit:cover}
.ggrid figcaption{padding:.9rem 1.1rem;font-size:.92rem;color:var(--muted)}
.gallery-cta{text-align:center;margin-top:2.4rem;color:var(--muted)}

/* Reviews */
.rev-head{display:flex;align-items:end;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:2.6rem}
.rev-score .big{font-family:var(--display);font-size:2.6rem;color:var(--text)}
.rev-score .sub{color:var(--muted);font-size:.92rem}
.rgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.2rem}
.review{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.review p{color:var(--text);font-size:.97rem;margin:.8rem 0 1.1rem;font-style:italic}
.who{font-weight:700;font-size:.95rem}
.who span{display:block;color:var(--muted);font-weight:400;font-size:.85rem}

/* About */
.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:3rem;align-items:start}
.about-media{display:flex;flex-direction:column;gap:1.2rem}
.about-extra{border:1px solid var(--line);border-radius:var(--radius);width:100%;display:block}
.about-grid p{color:var(--muted);margin-bottom:1.1rem}
.about-grid p b{color:var(--text)}
.shine-panel{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;background:radial-gradient(120% 90% at 70% 20%,#1c1c20 0%,#121214 55%,#0a0a0c 100%);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.shine-panel::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 38%,rgba(233,209,149,.16) 47%,rgba(255,255,255,.28) 50%,rgba(233,209,149,.16) 53%,transparent 62%)}
.panel-logo{width:88%;mix-blend-mode:screen;position:relative}
.about-portrait{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:0;background:var(--panel)}
.about-portrait img{width:100%;height:100%;object-fit:cover;display:block}
.about-portrait figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.2rem .9rem;background:linear-gradient(transparent,rgba(10,10,12,.88));color:var(--text);font-size:.92rem;font-family:var(--display)}

/* Contact */
.contact{background:radial-gradient(700px 360px at 50% 0%,rgba(217,178,100,.11),transparent 65%),var(--ink);text-align:center}
.contact-info{display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;margin:2.4rem 0}
.contact-info>div{min-width:200px}
.contact-info span:first-child{display:block;font-size:.8rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.socials{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;font-weight:700}

/* Quote form */
.qform{max-width:760px;margin:0 auto}
.qgrid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.4rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field.qspan{grid-column:1/-1}
.field>span{font-size:.78rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.qform input,.qform textarea{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:10px;color:var(--text);font-family:var(--body);font-size:1rem;padding:.8rem .9rem;transition:border-color .2s}
.qform input:focus,.qform textarea:focus{outline:none;border-color:rgba(217,178,100,.55)}
.qform textarea{resize:vertical;margin-top:0}
.qform>.field{margin-top:1.2rem}
.addons{border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.4rem;margin-top:1.6rem}
.addons legend{padding:0 .5rem;font-family:var(--display);color:var(--gold-soft);font-size:1.05rem}
.addon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem 1.4rem;margin-top:.4rem}
.check{display:flex;align-items:flex-start;gap:.6rem;color:var(--text);font-size:.96rem;cursor:pointer}
.check input{accent-color:var(--gold);width:1.05rem;height:1.05rem;margin-top:.18rem;flex:none}
.check em{color:var(--muted);font-style:italic}
.qform .btn{margin-top:1.8rem}
.qnote{color:var(--muted);font-size:.9rem;margin-top:1rem}
@media(max-width:560px){.qgrid{grid-template-columns:1fr}}

/* CTA strip & footer */
.cta-strip{text-align:center;padding:4.5rem 1rem;background:radial-gradient(600px 300px at 50% 100%,rgba(217,178,100,.12),transparent 65%),var(--ink);border-top:1px solid var(--line)}
.cta-strip h2{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:1.6rem}
footer{border-top:1px solid var(--line);padding:3.6rem 0 0;font-size:.92rem;color:var(--muted);background:radial-gradient(640px 320px at 50% 130%,rgba(217,178,100,.08),transparent 70%)}
.foot{display:grid;grid-template-columns:1.6fr 1fr 1.3fr;gap:2.6rem;align-items:start}
.foot-logo{height:52px;width:auto;display:block;margin-bottom:1.1rem;filter:drop-shadow(0 2px 10px rgba(0,0,0,.55))}
.foot-brand p{max-width:330px;margin-bottom:.5rem;font-size:.92rem}
.foot-tag{font-family:var(--display);color:var(--gold-soft);font-size:1.05rem}
.foot-col h4{font-family:var(--display);font-weight:400;color:var(--text);font-size:1.08rem;letter-spacing:.02em;margin-bottom:1rem}
.foot-col a,.foot-col span{display:block;color:var(--muted);margin-bottom:.6rem;transition:color .2s}
.foot-col a:hover{color:var(--gold-soft)}
.foot-social{display:flex;gap:1.2rem;margin-top:1rem}
.foot-social a{margin-bottom:0;font-weight:700}
.foot-bottom{margin-top:3rem;border-top:1px solid var(--line);text-align:center;padding:1.6rem 1.4rem;font-size:.84rem;color:var(--muted)}
@media(max-width:760px){.foot{grid-template-columns:1fr;gap:2.2rem}}

@media(max-width:760px){
  .menu-btn{display:block}
  .nav-links{position:absolute;top:70px;left:0;right:0;background:var(--ink);border-bottom:1px solid var(--line);flex-direction:column;padding:1.4rem 0;display:none}
  .nav-links.open{display:flex}
  .svc-row{grid-template-columns:1fr;gap:.6rem}
  .about-grid{grid-template-columns:1fr}
  .hero-content{padding-bottom:3.5rem}
  .hero-sub{font-size:1rem}
}
