/* ==========================================================================
   AURELIA INTERIORS — Design System
   Primary (Luxury Gold) #C8A97E | Charcoal #1E1E1E | BG #FFFFFF | Accent #F5F5F5
   ========================================================================== */
:root{
  --gold:#C8A97E;
  --gold-dark:#b08f63;
  --charcoal:#1E1E1E;
  --bg:#FFFFFF;
  --accent:#F5F5F5;
  --text:#2b2b2b;
  --muted:#6b6b6b;
  --line:#ece7df;
  --radius:6px;
  --shadow:0 24px 60px rgba(30,30,30,.10);
  --shadow-sm:0 10px 30px rgba(30,30,30,.07);
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --head:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --body:"Jost",system-ui,Segoe UI,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.75;font-size:17px;font-weight:300;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
h1,h2,h3,h4,h5,h6{font-family:var(--head);color:var(--charcoal);font-weight:600;line-height:1.1;margin:0 0 .4em;letter-spacing:0}
h1{font-size:clamp(3rem,6.2vw,5.4rem);font-weight:500}
h2{font-size:clamp(2.2rem,4.2vw,3.6rem);font-weight:500}
h3{font-size:clamp(1.4rem,2.2vw,1.9rem)}
p{margin:0 0 1.1em}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:clamp(64px,8vw,120px) 0}
.section--accent{background:var(--accent)}
.section--dark{background:var(--charcoal);color:#e9e6e0}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}
.text-center{text-align:center}
.muted{color:var(--muted)}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--body);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:20px}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--gold);display:inline-block}
.text-center .eyebrow::after{content:"";width:30px;height:1px;background:var(--gold);display:inline-block}
.section-head{max-width:760px;margin:0 auto 64px}
.section-head.left{margin-left:0;text-align:left}
.lead{font-size:1.15rem;color:var(--muted);font-weight:300}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:17px 38px;border-radius:2px;font-family:var(--body);font-weight:500;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border:1px solid transparent;transition:all .35s var(--ease);will-change:transform}
.btn:hover{transform:translateY(-3px)}
.btn-gold{background:var(--gold);color:#fff;box-shadow:0 10px 24px rgba(200,169,126,.35)}
.btn-gold:hover{background:var(--gold-dark);box-shadow:0 16px 32px rgba(200,169,126,.45)}
.btn-outline{border-color:var(--gold);color:var(--charcoal)}
.btn-outline:hover{background:var(--gold);color:#fff}
.btn-ghost-light{border-color:rgba(255,255,255,.6);color:#fff}
.btn-ghost-light:hover{background:#fff;color:var(--charcoal)}
.btn-dark{background:var(--charcoal);color:#fff}
.btn-dark:hover{background:#000}
.btn-sm{padding:13px 26px;font-size:.7rem}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:900;transition:all .4s var(--ease)}
.topbar{background:rgba(30,30,30,.55);color:#f1ede6;font-size:.82rem;backdrop-filter:blur(6px);transition:all .4s var(--ease)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:42px}
.topbar a:hover{color:var(--gold)}
.topbar .tb-left span,.topbar .tb-right a{display:inline-flex;align-items:center;gap:7px;margin-right:22px}
.topbar .tb-right a{margin-right:0;margin-left:22px}
.topbar svg{width:15px;height:15px;flex:0 0 auto}
.hide-sm{display:inline-flex}
@media(max-width:1100px){.hide-sm{display:none}}
.header-main{transition:all .4s var(--ease)}
.header-main .container{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{font-family:var(--head);font-weight:600;font-size:1.95rem;color:#fff;letter-spacing:.14em;line-height:1}
.brand span{color:var(--gold)}
.brand small{display:block;font-family:var(--body);font-size:.54rem;letter-spacing:.46em;font-weight:400;color:#cfc9bf;margin-top:5px;text-transform:uppercase}
.nav-menu{display:flex;align-items:center;gap:38px;list-style:none;margin:0;padding:0}
.nav-menu a{color:#fff;font-weight:400;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;position:relative;padding:6px 0}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:width .3s var(--ease)}
.nav-menu a:hover::after,.nav-menu .current-menu-item>a::after{width:100%}
.nav-menu a:hover{color:var(--gold)}
.sub-menu{position:absolute;top:120%;left:0;background:#fff;min-width:220px;box-shadow:var(--shadow);border-radius:10px;padding:10px 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .3s var(--ease);list-style:none}
.menu-item-has-children{position:relative}
.menu-item-has-children:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.sub-menu a{display:block;color:var(--charcoal);padding:9px 22px;font-size:.9rem}
.sub-menu a::after{display:none}
.sub-menu a:hover{background:var(--accent);color:var(--gold)}
.header-cta{display:flex;align-items:center;gap:18px}
.header-actions{display:flex;align-items:center;gap:18px}
.phone-link{color:#fff;display:inline-flex}
.phone-link svg{width:20px;height:20px}
.site-header.scrolled .phone-link{color:var(--gold)}

/* scrolled state */
.site-header.scrolled .topbar{display:none}
.site-header.scrolled .header-main{background:#fff;box-shadow:0 6px 24px rgba(0,0,0,.07)}
.site-header.scrolled .header-main .container{height:72px}
.site-header.scrolled .brand{color:var(--charcoal)}
.site-header.scrolled .nav-menu a{color:var(--charcoal)}
.site-header.scrolled .nav-menu a:hover{color:var(--gold)}
.site-header.scrolled .menu-toggle span{background:var(--charcoal)}

/* mobile toggle */
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.menu-toggle span{width:26px;height:2px;background:#fff;transition:all .3s var(--ease)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.08);transition:opacity 1.4s var(--ease),transform 7s linear}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(15,15,15,.82) 0%,rgba(20,20,20,.55) 45%,rgba(20,20,20,.25) 100%)}
.hero-inner{position:relative;z-index:2;max-width:760px;padding-top:60px}
.hero h1{color:#fff;margin-bottom:.35em}
.hero p{font-size:1.2rem;font-weight:300;color:#ece8e1;max-width:600px;margin-bottom:2em}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:42px;left:50%;transform:translateX(-50%);display:flex;gap:12px;z-index:3}
.hero-dots button{width:38px;height:4px;border:0;border-radius:4px;background:rgba(255,255,255,.4);cursor:pointer;transition:background .3s}
.hero-dots button.active{background:var(--gold)}
.hero-scroll{position:absolute;bottom:38px;right:40px;z-index:3;color:#fff;font-size:.75rem;letter-spacing:.2em;writing-mode:vertical-rl;opacity:.8}

/* ===== Stats / counters ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:26px 14px}
.stat-num{font-family:var(--head);font-size:clamp(3rem,4.6vw,4.2rem);font-weight:600;color:var(--gold);line-height:1}
.stat-num span{color:var(--gold)}
.stat-label{margin-top:10px;font-size:.95rem;color:var(--muted);letter-spacing:.04em}

/* ===== About grid ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-media{position:relative}
.about-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.about-media .badge{position:absolute;bottom:-26px;left:-26px;background:var(--gold);color:#fff;padding:24px 30px;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}
.about-media .badge b{display:block;font-size:2.6rem;font-family:var(--head);font-weight:600;line-height:1}
.about-media .badge small{font-size:.8rem;letter-spacing:.06em}
.ticks{list-style:none;padding:0;margin:1.4em 0;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ticks li{display:flex;align-items:center;gap:10px;font-weight:500}
.ticks li::before{content:"";width:20px;height:20px;border-radius:50%;background:var(--gold);flex:0 0 auto;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/14px no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/14px no-repeat}

/* ===== Cards grid (services) ===== */
.grid{display:grid;gap:28px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:38px 32px;transition:all .4s var(--ease);position:relative;overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);transition:width .4s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{width:100%}
.card .ico{width:62px;height:62px;border-radius:14px;background:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:all .4s var(--ease)}
.card:hover .ico{background:var(--gold)}
.card .ico svg{width:30px;height:30px;stroke:var(--gold);transition:stroke .4s var(--ease)}
.card:hover .ico svg{stroke:#fff}
.card h3{margin-bottom:.4em}
.card p{font-size:.96rem;color:var(--muted);margin-bottom:1em}
.card .more{font-weight:600;color:var(--gold);font-size:.9rem;display:inline-flex;align-items:center;gap:6px}
.card .more::after{content:"→";transition:transform .3s var(--ease)}
.card:hover .more::after{transform:translateX(5px)}

/* ===== Why choose us ===== */
.why-box{display:flex;gap:18px;align-items:flex-start;padding:24px;border-radius:var(--radius);transition:background .3s var(--ease)}
.why-box:hover{background:#fff;box-shadow:var(--shadow-sm)}
.why-box .n{font-family:var(--head);font-size:1.6rem;font-weight:700;color:var(--gold);flex:0 0 auto;width:54px;height:54px;border:1.5px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center}
.why-box h3{font-size:1.15rem;margin-bottom:.3em}
.why-box p{font-size:.92rem;color:var(--muted);margin:0}

/* ===== Portfolio ===== */
.filters{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-bottom:42px}
.filters button{background:transparent;border:1.5px solid var(--line);color:var(--muted);padding:9px 22px;border-radius:50px;font-weight:500;cursor:pointer;transition:all .3s var(--ease)}
.filters button.active,.filters button:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.masonry{columns:3;column-gap:24px}
.masonry .pf-item{margin-bottom:24px;break-inside:avoid}
.pf-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer}
.pf-item img{width:100%;transition:transform .7s var(--ease)}
.pf-item:hover img{transform:scale(1.08)}
.pf-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,20,20,.85),transparent 60%);opacity:0;transition:opacity .4s var(--ease);display:flex;flex-direction:column;justify-content:flex-end;padding:26px}
.pf-item:hover .pf-overlay{opacity:1}
.pf-overlay .cat{color:var(--gold);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:6px}
.pf-overlay h3{color:#fff;font-size:1.25rem;margin:0 0 12px}
.pf-overlay .btn{align-self:flex-start;transform:translateY(10px);transition:transform .4s var(--ease)}
.pf-item:hover .pf-overlay .btn{transform:translateY(0)}

/* ===== Process timeline ===== */
.process{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;position:relative}
.process::before{content:"";position:absolute;top:38px;left:8%;right:8%;height:2px;background:repeating-linear-gradient(90deg,var(--gold) 0 12px,transparent 12px 22px)}
.step{text-align:center;position:relative;z-index:1}
.step .circle{width:76px;height:76px;border-radius:50%;background:#fff;border:2px solid var(--gold);color:var(--gold);font-family:var(--head);font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;transition:all .35s var(--ease)}
.step:hover .circle{background:var(--gold);color:#fff;transform:translateY(-5px)}
.step h3{font-size:1.05rem;margin-bottom:.3em}
.step p{font-size:.85rem;color:var(--muted);margin:0}

/* ===== Testimonials ===== */
.testi-track{display:flex;transition:transform .6s var(--ease)}
.testi-wrap{overflow:hidden}
.testi{flex:0 0 100%;padding:0 12px}
.testi-inner{background:#fff;border-radius:var(--radius);padding:48px;box-shadow:var(--shadow-sm);max-width:820px;margin:0 auto;text-align:center}
.section--dark .testi-inner{background:#262626}
.stars{color:var(--gold);letter-spacing:3px;font-size:1.1rem;margin-bottom:18px}
.testi-quote{font-size:1.3rem;line-height:1.7;font-style:italic;margin-bottom:26px}
.testi-person{display:flex;align-items:center;justify-content:center;gap:14px}
.testi-person img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid var(--gold)}
.testi-person b{display:block}
.testi-person small{color:var(--muted)}
.testi-nav{display:flex;justify-content:center;gap:12px;margin-top:30px}
.testi-nav button{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--gold);background:transparent;color:var(--gold);cursor:pointer;font-size:1.1rem;transition:all .3s var(--ease)}
.testi-nav button:hover{background:var(--gold);color:#fff}

/* ===== FAQ ===== */
.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:24px 0;font-family:var(--head);font-weight:600;font-size:1.12rem;color:var(--charcoal);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .pm{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.faq-item.open .faq-q .pm{background:var(--gold);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding:0 0 24px;color:var(--muted);margin:0}

/* ===== CTA band ===== */
.cta-band{position:relative;color:#fff;text-align:center;background-size:cover;background-position:center;overflow:hidden}
.cta-band::after{content:"";position:absolute;inset:0;background:rgba(20,20,20,.78)}
.cta-band .container{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band .hero-btns{justify-content:center;margin-top:8px}

/* ===== Team ===== */
.team-card{text-align:center}
.team-card .ph{border-radius:var(--radius);overflow:hidden;margin-bottom:18px;position:relative}
.team-card img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .6s var(--ease)}
.team-card:hover img{transform:scale(1.06)}
.team-card h3{margin-bottom:.1em}
.team-card .role{color:var(--gold);font-size:.9rem;letter-spacing:.05em;margin-bottom:.6em}
.team-card p{font-size:.9rem;color:var(--muted)}

/* ===== Values ===== */
.value{padding:32px;border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm);height:100%}
.value .ico{width:54px;height:54px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.value .ico svg{width:26px;height:26px;stroke:var(--gold)}

/* ===== Service detail row ===== */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-bottom:84px}
.svc-row:nth-child(even) .svc-media{order:2}
.svc-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.svc-row ul{list-style:none;padding:0;margin:1em 0}
.svc-row ul li{padding-left:30px;position:relative;margin-bottom:10px}
.svc-row ul li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}

/* ===== Gallery ===== */
.gallery-grid{columns:3;column-gap:18px}
.gallery-grid figure{margin:0 0 18px;break-inside:avoid;border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative}
.gallery-grid img{width:100%;transition:transform .6s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.07)}
.gallery-grid figcaption{position:absolute;inset:0;background:rgba(20,20,20,.6);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .35s;font-weight:600;letter-spacing:.04em}
.gallery-grid figure:hover figcaption{opacity:1}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(15,15,15,.94);z-index:2000;display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:8px}
.lightbox .lb-close{position:absolute;top:24px;right:34px;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:3rem;cursor:pointer;padding:0 18px;user-select:none}
.lb-prev{left:10px}.lb-next{right:10px}

/* ===== Blog ===== */
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:all .4s var(--ease);height:100%;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card .thumb{overflow:hidden;aspect-ratio:16/10}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover .thumb img{transform:scale(1.07)}
.post-card .pc-body{padding:26px;flex:1;display:flex;flex-direction:column}
.post-card .meta{font-size:.8rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}
.post-card h3{font-size:1.2rem;margin-bottom:.4em}
.post-card p{font-size:.92rem;color:var(--muted);flex:1}
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.sidebar .widget{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-bottom:26px}
.sidebar .widget h4{font-size:1.05rem;border-left:3px solid var(--gold);padding-left:12px;margin-bottom:16px}
.sidebar ul{list-style:none;padding:0;margin:0}
.sidebar li{padding:8px 0;border-bottom:1px solid var(--line)}
.sidebar li:last-child{border:0}
.search-form{display:flex;gap:8px}
.search-form input{flex:1;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font-family:inherit}
.search-form button{background:var(--gold);color:#fff;border:0;border-radius:8px;padding:0 18px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.search-form button svg{width:15px;height:15px}
.svc-row .ico svg{width:28px;height:28px;stroke:var(--gold)}

/* ===== Contact / forms ===== */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.info-list{list-style:none;padding:0;margin:0}
.info-list li{display:flex;gap:16px;align-items:flex-start;margin-bottom:26px}
.info-list .ico{width:50px;height:50px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.info-list .ico svg{width:24px;height:24px;stroke:var(--gold)}
.info-list b{display:block;margin-bottom:2px}
.info-list span{color:var(--muted)}
.lead-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:38px;box-shadow:var(--shadow-sm)}
.lead-form .fld{margin-bottom:18px}
.lead-form label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:var(--charcoal)}
.lead-form input,.lead-form select,.lead-form textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:#fdfcfa;transition:border-color .25s}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--gold)}
.lead-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{padding:14px;border-radius:10px;margin-bottom:16px;font-size:.92rem;display:none}
.form-note.ok{display:block;background:#eaf7ee;color:#1c6b34}
.form-note.err{display:block;background:#fdeaea;color:#a12626}
.map-embed iframe{width:100%;height:420px;border:0;border-radius:var(--radius);display:block}

/* ===== Floating buttons ===== */
.floaters{position:fixed;right:20px;bottom:24px;z-index:950;display:flex;flex-direction:column;gap:14px}
.floaters a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 10px 26px rgba(0,0,0,.22);transition:transform .3s var(--ease)}
.floaters a:hover{transform:scale(1.1)}
.fl-wa{background:#25D366}
.fl-call{background:var(--gold)}
.floaters svg{width:28px;height:28px;fill:#fff}

/* ===== Page hero / breadcrumb ===== */
.page-hero{position:relative;color:#fff;padding:170px 0 80px;background-size:cover;background-position:center;text-align:center}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,20,20,.65),rgba(20,20,20,.78))}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:#fff;margin-bottom:.2em}
.breadcrumb{font-size:.88rem;color:#d8d3ca}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{margin:0 8px;color:var(--gold)}

/* ===== Single project ===== */
.proj-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;margin:-60px auto 50px;position:relative;z-index:2;box-shadow:var(--shadow)}
.proj-meta .pm-item small{display:block;color:var(--gold);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px}
.proj-meta .pm-item b{font-size:1.05rem}

/* ===== Footer ===== */
.site-footer{background:var(--charcoal);color:#c9c4ba;padding-top:74px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:42px;padding-bottom:54px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:22px;letter-spacing:.02em}
.site-footer a:hover{color:var(--gold)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:11px;font-size:.94rem;display:flex;gap:9px;align-items:flex-start}
.site-footer li svg{width:16px;height:16px;flex:0 0 auto;color:var(--gold);margin-top:3px}
.foot-brand .brand{color:#fff;margin-bottom:18px}
.foot-brand p{font-size:.94rem;line-height:1.8}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.socials a:hover{background:var(--gold);border-color:var(--gold)}
.socials svg{width:18px;height:18px;fill:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;font-size:.86rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ===== Reveal animations ===== */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ===== Pagination ===== */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:48px}
.pagination .page-numbers{padding:10px 16px;border:1px solid var(--line);border-radius:8px;font-weight:600}
.pagination .current,.pagination a:hover{background:var(--gold);color:#fff;border-color:var(--gold)}

/* ===== Responsive ===== */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(3,1fr);gap:34px}
  .process::before{display:none}
  .blog-layout{grid-template-columns:1fr}
  .masonry,.gallery-grid{columns:2}
}
@media(max-width:820px){
  body{font-size:16px}
  .topbar{display:none}
  .menu-toggle{display:flex}
  .header-actions .btn,.header-actions .phone-link{display:none}
  .nav-menu{position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;background:#fff;flex-direction:column;align-items:flex-start;padding:100px 32px 32px;gap:6px;box-shadow:-10px 0 40px rgba(0,0,0,.18);transition:right .4s var(--ease);overflow-y:auto}
  .nav-menu.open{right:0}
  .nav-menu a{color:var(--charcoal);width:100%;padding:14px 0;border-bottom:1px solid var(--line)}
  .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding-left:14px}
  .nav-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-open .menu-toggle span:nth-child(2){opacity:0}
  .nav-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-open .menu-toggle span{background:var(--charcoal)}
  .about-grid,.contact-grid,.svc-row,.grid-3,.grid-2{grid-template-columns:1fr;gap:34px}
  .svc-row:nth-child(even) .svc-media{order:0}
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr;gap:14px}
  .proj-meta{grid-template-columns:1fr 1fr;margin-top:30px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .about-media .badge{left:0}
  .hero-scroll{display:none}
}
@media(max-width:520px){
  .grid-4,.portfolio-grid,.stats,.footer-grid{grid-template-columns:1fr}
  .masonry,.gallery-grid{columns:1}
  .lead-form .row2{grid-template-columns:1fr}
  .hero-btns .btn,.hero-btns{width:100%}
  .lead-form{padding:26px}
  .testi-inner{padding:30px 22px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
