/* ═══════════════════════════════════════════════
   AANTRIK — Luxury Light Theme
   Soft Beige + Wood Gold Palette
═══════════════════════════════════════════════ */

:root {
  --cream:    #FAF8F4;
  --white:    #FFFFFF;
  --warm:     #F3EFE8;
  --border:   #E5E0D8;
  --bronze:   #8A6820;
  --bronze-l: #C9A84C;
  --bronze-d: #5C4510;
  --text:     #1A1208;
  --text-2:   #5A4F3C;
  --text-3:   #9A8F7A;
  --accent:   #B8912A;
  --radius:   6px;
  --shadow:   0 2px 20px rgba(138,104,32,0.08);
  --shadow-h: 0 8px 40px rgba(138,104,32,0.16);
  --nav-h:    72px;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { background:var(--cream); color:var(--text); font-family:'Inter',system-ui,sans-serif; font-weight:400; line-height:1.6; overflow-x:hidden; }
::selection { background:var(--bronze-l); color:#fff; }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-thumb { background:var(--bronze-l); border-radius:2px; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }

/* ── UTILITIES ── */
.container { max-width:1180px; margin:0 auto; padding:0 24px; }
.section { padding:96px 0; }
.section-alt { background:var(--white); }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.section-label { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--bronze); margin-bottom:12px; }
.section-title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(28px,3.5vw,42px); font-weight:400; line-height:1.2; color:var(--text); margin-bottom:16px; }
.section-title em { font-style:italic; color:var(--bronze); }
.section-sub { font-size:15px; line-height:1.8; color:var(--text-2); max-width:540px; }
.section-header { margin-bottom:48px; }
.section-header.centered { text-align:center; }
.section-header.centered .section-sub { margin:0 auto; }
.divider { width:48px; height:2px; background:var(--bronze-l); margin:20px 0 28px; }
.philosophy { font-family:'Playfair Display',serif; font-style:italic; font-size:15px; color:var(--bronze); border-left:3px solid var(--bronze-l); padding-left:16px; margin:20px 0; line-height:1.7; }

/* ── FADE IN ── */
.fade-in { opacity:0; transform:translateY(28px); transition:opacity .75s ease, transform .75s ease; }
.fade-in.visible { opacity:1; transform:none; }

/* ── BUTTONS ── */
.btn-primary { display:inline-block; padding:13px 30px; background:var(--bronze); color:#fff; font-size:11px; letter-spacing:2.5px; text-transform:uppercase; font-weight:500; border-radius:var(--radius); transition:all .3s; cursor:pointer; border:none; }
.btn-primary:hover { background:var(--bronze-d); transform:translateY(-2px); box-shadow:var(--shadow-h); }
.btn-outline { display:inline-block; padding:12px 28px; background:transparent; color:var(--bronze); font-size:11px; letter-spacing:2.5px; text-transform:uppercase; font-weight:500; border:1.5px solid var(--bronze-l); border-radius:var(--radius); transition:all .3s; cursor:pointer; }
.btn-outline:hover { background:var(--bronze); color:#fff; border-color:var(--bronze); transform:translateY(-2px); }
.btn-link { font-size:13px; color:var(--bronze); letter-spacing:1px; text-decoration:underline; text-underline-offset:4px; transition:color .3s; }
.btn-link:hover { color:var(--bronze-d); }
.btn-wa { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; background:#25D366; color:#fff; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-weight:500; border-radius:var(--radius); transition:all .3s; }
.btn-wa:hover { background:#1da851; transform:translateY(-2px); }
.btn-lg { padding:15px 38px; font-size:12px; letter-spacing:2.5px; }

/* ── NAVBAR ── */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--nav-h); background:rgba(250,248,244,0.94); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border-bottom:1px solid var(--border); transition:box-shadow .3s; }
.navbar.scrolled { box-shadow:0 2px 28px rgba(138,104,32,0.1); }
.nav-container { max-width:1280px; margin:0 auto; padding:0 32px; height:100%; display:flex; align-items:center; justify-content:space-between; }
.nav-brand { display:flex; align-items:center; flex-shrink:0; }
.nav-logo-img { height:38px; width:auto; }
.nav-links { display:flex; gap:28px; list-style:none; }
.nav-links a { font-size:10.5px; letter-spacing:2px; text-transform:uppercase; color:var(--text-2); transition:color .3s; padding-bottom:3px; border-bottom:1.5px solid transparent; }
.nav-links a:hover, .nav-links a.active { color:var(--bronze); border-bottom-color:var(--bronze-l); }
.nav-cta { padding:9px 22px; background:transparent; color:var(--bronze); font-size:10.5px; letter-spacing:2px; text-transform:uppercase; font-weight:500; border:1.5px solid var(--bronze-l); border-radius:var(--radius); transition:all .3s; flex-shrink:0; }
.nav-cta:hover { background:var(--bronze); color:#fff; border-color:var(--bronze); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--text); transition:.3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.mobile-nav { display:none; position:fixed; top:var(--nav-h); left:0; right:0; background:var(--white); padding:24px 28px; border-bottom:1px solid var(--border); z-index:999; box-shadow:0 12px 32px rgba(0,0,0,.08); }
.mobile-nav.open { display:block; animation:slideDown .25s ease; }
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
.mobile-nav a { display:block; padding:13px 0; font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--text-2); border-bottom:1px solid var(--border); transition:color .2s; }
.mobile-nav a:hover { color:var(--bronze); }
.mobile-nav .mobile-cta { display:inline-block; margin-top:18px; padding:12px 28px; background:var(--bronze); color:#fff; border-radius:var(--radius); border:none; letter-spacing:2px; font-size:10.5px; text-transform:uppercase; }

/* ── WA FLOAT ── */
.wa-float { position:fixed; bottom:28px; right:28px; z-index:998; width:52px; height:52px; background:#25D366; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,.35); animation:wapulse 2.5s infinite; transition:transform .3s; }
.wa-float:hover { transform:scale(1.1); }
@keyframes wapulse { 0%,100%{ box-shadow:0 4px 20px rgba(37,211,102,.35);} 50%{ box-shadow:0 4px 36px rgba(37,211,102,.6);} }

/* ── BOOK CONSULTATION SIDEBAR ── */
.book-consult { position:fixed; right:0; top:50%; transform:translateY(-50%); z-index:990; display:flex; align-items:center; gap:10px; background:var(--bronze); color:#fff; padding:14px 10px; border-radius:6px 0 0 6px; transition:all .3s; text-decoration:none; }
.book-consult:hover { background:var(--bronze-d); padding-left:16px; }
.book-consult-text { font-size:9px; letter-spacing:3px; text-transform:uppercase; writing-mode:vertical-rl; text-orientation:mixed; transform:rotate(180deg); color:#fff; white-space:nowrap; font-weight:500; }

/* ═══════════════════════════════════════════════
   HERO SLIDER
═══════════════════════════════════════════════ */
.hero-section { display:flex; height:100vh; min-height:660px; padding-top:var(--nav-h); }

/* Left text panel */
.hero-left { flex:0 0 38%; display:flex; align-items:center; padding:48px 56px; background:var(--cream); position:relative; z-index:2; }
.hero-inner { max-width:420px; }
.hero-eyebrow { display:block; font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--bronze); margin-bottom:18px; transition:opacity .4s ease; }
.hero-title { font-family:'Playfair Display',serif; font-size:clamp(38px,4.5vw,66px); font-weight:400; line-height:1.08; color:var(--text); margin-bottom:20px; text-transform:uppercase; letter-spacing:-.5px; }
.hero-title em { font-style:italic; color:var(--bronze); text-transform:none; letter-spacing:0; }
.hero-desc { font-size:14px; line-height:1.9; color:var(--text-2); margin-bottom:36px; max-width:320px; transition:opacity .4s ease; }
.hero-cta-btn { display:inline-flex; align-items:center; gap:12px; padding:14px 32px; background:var(--bronze); color:#fff; font-size:10px; letter-spacing:3px; text-transform:uppercase; font-weight:500; border-radius:var(--radius); transition:all .3s; margin-bottom:52px; }
.hero-cta-btn:hover { background:var(--bronze-d); transform:translateY(-2px); box-shadow:var(--shadow-h); }
.hero-cta-btn svg { transition:transform .3s; }
.hero-cta-btn:hover svg { transform:translateX(5px); }

/* Slider navigation */
.hero-nav { display:flex; align-items:center; gap:18px; }
.hero-arr { width:38px; height:38px; border:1.5px solid var(--border); border-radius:50%; background:none; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-2); font-size:14px; transition:all .3s; font-family:inherit; line-height:1; }
.hero-arr:hover { background:var(--bronze); color:#fff; border-color:var(--bronze); }
.hero-pagination { display:flex; align-items:center; gap:12px; font-family:'Playfair Display',serif; }
.hero-pag-current { font-size:22px; font-weight:600; color:var(--text); min-width:26px; line-height:1; }
.hero-pag-line { width:52px; height:1px; background:var(--border); flex-shrink:0; }
.hero-pag-total { font-size:14px; color:var(--text-3); }

/* Right image area */
.hero-right { flex:1; position:relative; overflow:hidden; }
.hero-slide { position:absolute; inset:0; opacity:0; transition:opacity 1s ease; }
.hero-slide.active { opacity:1; }
.hero-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.hero-dots { position:absolute; bottom:28px; right:28px; display:flex; gap:8px; z-index:5; }
.hero-dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.4); border:none; cursor:pointer; transition:all .35s; padding:0; }
.hero-dot.active { background:#fff; width:28px; border-radius:4px; }
.hero-dot:hover { background:rgba(255,255,255,.7); }
.hero-progress { position:absolute; bottom:0; left:0; right:0; height:3px; background:rgba(255,255,255,.15); }
.hero-progress-bar { height:100%; background:var(--bronze-l); width:0%; transition:width linear; }

/* ── FEATURES STRIP ── */
.features-strip { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:32px 0; }
.features-inner { max-width:1180px; margin:0 auto; padding:0 32px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:24px; }
.feature-item { display:flex; flex-direction:column; align-items:center; gap:12px; flex:1; min-width:120px; text-align:center; padding:8px 20px; position:relative; }
.feature-item:not(:last-child)::after { content:''; position:absolute; right:0; top:50%; transform:translateY(-50%); height:44px; width:1px; background:var(--border); }
.feature-icon { color:var(--bronze); display:flex; align-items:center; justify-content:center; }
.feature-text { font-size:9.5px; letter-spacing:2.5px; text-transform:uppercase; color:var(--text); font-weight:500; line-height:1.5; }

/* ── TICKER ── */
.ticker { background:var(--bronze); padding:12px 0; overflow:hidden; white-space:nowrap; }
.ticker-track { display:inline-flex; animation:ticker 32s linear infinite; }
.ticker-track span { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:#fff; padding:0 32px; opacity:.9; }
.ticker-track span::after { content:" \25C6 "; opacity:.4; margin-left:32px; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── ABOUT SECTION (HOME) ── */
.about-home { padding:100px 0; background:var(--cream); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; max-width:1180px; margin:0 auto; padding:0 24px; }
.about-stats-row { display:flex; align-items:center; gap:0; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; width:fit-content; background:var(--white); }
.about-stat { padding:18px 26px; text-align:center; }
.about-stat-num { display:block; font-family:'Playfair Display',serif; font-size:28px; font-weight:600; color:var(--bronze); line-height:1; }
.about-stat-lbl { display:block; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); margin-top:5px; }
.about-stat-div { width:1px; background:var(--border); align-self:stretch; }
.about-right { display:grid; grid-template-columns:1fr 1fr; gap:12px; align-items:start; }
.about-img-main { grid-row:span 2; border-radius:var(--radius); overflow:hidden; aspect-ratio:2/3; }
.about-img-col { display:flex; flex-direction:column; gap:12px; }
.about-img-sub { border-radius:var(--radius); overflow:hidden; aspect-ratio:1; }
.about-badge-box { background:var(--bronze); border-radius:var(--radius); padding:22px 20px; flex:1; display:flex; align-items:center; }
.about-philosophy { font-family:'Playfair Display',serif; font-style:italic; font-size:13px; color:rgba(255,255,255,.9); line-height:1.7; }
.about-img-main img, .about-img-sub img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.about-img-main:hover img, .about-img-sub:hover img { transform:scale(1.04); }

/* ── SERVICES ── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.svc-card { background:var(--white); padding:34px 30px; transition:background .25s; }
.svc-card:hover { background:var(--warm); }
.svc-num { font-family:'Playfair Display',serif; font-size:34px; font-weight:400; color:var(--border); line-height:1; margin-bottom:16px; display:block; }
.svc-card h3 { font-size:14px; font-weight:600; color:var(--text); margin-bottom:8px; }
.svc-card p { font-size:13px; color:var(--text-2); line-height:1.7; }

/* ── PROJECTS GRID ── */
.projects-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; }
.proj-card { display:block; background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:all .35s; }
.proj-card:hover { box-shadow:var(--shadow-h); transform:translateY(-5px); }
.proj-img-wrap { position:relative; overflow:hidden; aspect-ratio:4/3; background:var(--warm); }
.proj-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.proj-card:hover .proj-img-wrap img { transform:scale(1.06); }
.proj-badge { position:absolute; top:12px; left:12px; background:var(--bronze); color:#fff; font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:4px 10px; border-radius:40px; }
.proj-info { padding:20px 22px; }
.proj-cat { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--bronze); }
.proj-name { font-family:'Playfair Display',serif; font-size:17px; font-weight:400; color:var(--text); margin:6px 0; line-height:1.3; }
.proj-client { font-size:12px; color:var(--text-3); }

/* ── STATS SECTION ── */
.stats-section { background:var(--bronze-d); padding:80px 0; }
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); max-width:1180px; margin:0 auto; padding:0 24px; }
.stat-block { text-align:center; padding:40px 16px; border-right:1px solid rgba(255,255,255,.08); }
.stat-block:last-child { border-right:none; }
.big-num { font-family:'Playfair Display',serif; font-size:56px; font-weight:600; color:var(--bronze-l); line-height:1; }
.big-suf { font-family:'Playfair Display',serif; font-size:36px; color:var(--bronze-l); }
.big-lbl { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.4); margin-top:12px; }

/* ── TESTIMONIALS ── */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.tcard { background:var(--warm); padding:30px; border-radius:var(--radius); border-top:3px solid var(--bronze-l); transition:box-shadow .3s; }
.tcard:hover { box-shadow:var(--shadow-h); }
.tcard-stars { color:var(--bronze-l); font-size:13px; letter-spacing:2px; margin-bottom:16px; }
.tcard-quote { font-family:'Playfair Display',serif; font-style:italic; font-size:15px; color:var(--text-2); line-height:1.8; margin-bottom:22px; }
.tcard-author { display:flex; align-items:center; gap:12px; }
.tcard-avatar { width:40px; height:40px; border-radius:50%; background:var(--bronze); color:#fff; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:600; flex-shrink:0; }
.tcard-author strong { font-size:13px; font-weight:600; color:var(--text); display:block; }
.tcard-author span { font-size:12px; color:var(--text-3); }

/* ── CLIENTS ── */
.clients-grid { display:flex; flex-wrap:wrap; gap:10px; }
.client-chip { padding:9px 20px; background:var(--warm); border:1px solid var(--border); border-radius:40px; font-size:12px; letter-spacing:1px; color:var(--text-2); transition:all .3s; cursor:default; }
.client-chip:hover { border-color:var(--bronze-l); color:var(--bronze); background:rgba(201,168,76,.08); }

/* ── CTA SECTION ── */
.cta-section { background:var(--bronze); padding:80px 0; }
.cta-inner { display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.cta-inner h2 { font-family:'Playfair Display',serif; font-size:clamp(24px,3vw,38px); font-weight:400; color:#fff; margin-bottom:8px; }
.cta-inner p { font-size:15px; color:rgba(255,255,255,.7); }
.cta-actions { display:flex; gap:12px; flex-shrink:0; flex-wrap:wrap; }
.cta-actions .btn-primary { background:#fff; color:var(--bronze); }
.cta-actions .btn-primary:hover { background:var(--warm); }
.cta-actions .btn-wa { background:rgba(255,255,255,.15); border:1.5px solid rgba(255,255,255,.4); color:#fff; }
.cta-actions .btn-wa:hover { background:rgba(255,255,255,.25); }

/* ── PAGE HERO ── */
.page-hero { background:var(--white); padding:140px 0 56px; border-bottom:1px solid var(--border); }
.page-hero-title { font-family:'Playfair Display',serif; font-size:clamp(36px,5vw,60px); font-weight:400; color:var(--text); line-height:1.1; }
.page-hero-title em { color:var(--bronze); font-style:italic; }
.page-hero-sub { font-size:14px; color:var(--text-3); margin-top:10px; letter-spacing:1px; }
.page-hero-sm { padding:120px 0 40px; }
.breadcrumb { font-size:12px; color:var(--text-3); margin-bottom:12px; letter-spacing:.5px; }
.breadcrumb a { color:var(--bronze); }

/* ── ABOUT PAGE ── */
.info-card { background:var(--warm); padding:24px; border-radius:var(--radius); }
.info-card h4 { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--bronze); margin-bottom:10px; }
.info-card p { font-size:14px; color:var(--text-2); line-height:1.7; }
.team-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.team-card { background:var(--white); padding:40px; border-radius:var(--radius); border:1px solid var(--border); text-align:center; transition:box-shadow .3s; }
.team-card:hover { box-shadow:var(--shadow-h); }
.team-avatar { width:64px; height:64px; border-radius:50%; background:var(--bronze); color:#fff; font-size:20px; font-weight:600; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.team-card h3 { font-family:'Playfair Display',serif; font-size:20px; margin-bottom:6px; }
.team-role { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--bronze); display:block; margin-bottom:14px; }
.team-card p { font-size:13px; color:var(--text-2); line-height:1.7; }
.timeline { display:flex; flex-direction:column; gap:0; border-left:2px solid var(--border); margin-left:80px; padding-left:32px; }
.timeline-item { position:relative; padding:0 0 32px 0; }
.timeline-item::before { content:''; position:absolute; left:-38px; top:6px; width:12px; height:12px; border-radius:50%; background:var(--bronze-l); border:2px solid var(--white); }
.tl-year { position:absolute; left:-110px; top:2px; font-family:'Playfair Display',serif; font-size:18px; font-weight:600; color:var(--bronze); width:68px; text-align:right; }
.tl-content strong { font-size:14px; color:var(--text); display:block; margin-bottom:4px; }
.tl-content p { font-size:13px; color:var(--text-2); line-height:1.6; }

/* ── ABOUT HOME STRENGTH CARDS ── */
.strength-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.strength-card { padding:22px; background:var(--warm); border-radius:var(--radius); border-left:3px solid var(--bronze-l); transition:box-shadow .3s; }
.strength-card:hover { box-shadow:var(--shadow); }
.sc-icon { font-size:20px; color:var(--bronze-l); margin-bottom:10px; }
.strength-card h4 { font-size:13px; font-weight:600; color:var(--text); margin-bottom:7px; }
.strength-card p { font-size:13px; color:var(--text-2); line-height:1.6; }

/* ── PROJECTS PAGE ── */
.filter-bar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:36px; }
.filter-btn { padding:8px 20px; background:var(--white); border:1.5px solid var(--border); color:var(--text-2); font-size:10px; letter-spacing:2px; text-transform:uppercase; cursor:pointer; border-radius:40px; font-family:'Inter',sans-serif; transition:all .3s; }
.filter-btn:hover, .filter-btn.active { border-color:var(--bronze); color:var(--bronze); background:rgba(201,168,76,.06); }
.empty-state { grid-column:1/-1; text-align:center; padding:80px; color:var(--text-3); }

/* ── PROJECT DETAIL ── */
.project-detail-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:48px; }
.gallery-main { position:relative; border-radius:var(--radius); overflow:hidden; background:var(--warm); aspect-ratio:4/3; }
.gallery-main img { width:100%; height:100%; object-fit:cover; }
.gallery-prev, .gallery-next { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.9); border:none; width:40px; height:40px; border-radius:50%; font-size:18px; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text); transition:.25s; box-shadow:0 2px 10px rgba(0,0,0,.1); }
.gallery-prev { left:12px; }
.gallery-next { right:12px; }
.gallery-prev:hover, .gallery-next:hover { background:var(--bronze); color:#fff; }
.gallery-counter { position:absolute; bottom:12px; right:14px; background:rgba(0,0,0,.5); color:#fff; font-size:11px; padding:4px 10px; border-radius:40px; }
.gallery-thumbs { display:flex; gap:8px; margin-top:10px; flex-wrap:wrap; }
.thumb { width:72px; height:54px; border-radius:4px; overflow:hidden; cursor:pointer; border:2px solid transparent; transition:.25s; opacity:.65; }
.thumb.active, .thumb:hover { border-color:var(--bronze-l); opacity:1; }
.thumb img { width:100%; height:100%; object-fit:cover; }
.detail-table { width:100%; border-collapse:collapse; margin-bottom:24px; }
.detail-table td { padding:10px 0; border-bottom:1px solid var(--border); font-size:13px; vertical-align:top; }
.detail-table td:first-child { color:var(--text-3); width:100px; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; }
.detail-desc h4 { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--bronze); margin-bottom:10px; }
.detail-desc p { font-size:14px; color:var(--text-2); line-height:1.8; }
.detail-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }

/* ── CONTACT PAGE ── */
.contact-grid { display:grid; grid-template-columns:1.2fr 0.8fr; gap:64px; }
.contact-form { display:flex; flex-direction:column; gap:16px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); }
.form-group input, .form-group textarea, .form-group select { background:var(--white); border:1.5px solid var(--border); color:var(--text); padding:13px 14px; font-family:'Inter',sans-serif; font-size:13px; border-radius:var(--radius); outline:none; transition:border-color .25s; width:100%; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color:var(--bronze-l); }
.form-group textarea { min-height:110px; resize:vertical; }
.form-error { font-size:12px; color:#c0392b; }
.form-hint { font-size:11px; color:var(--text-3); }
.alert { padding:14px 18px; border-radius:var(--radius); margin-bottom:20px; font-size:14px; }
.alert-success { background:rgba(39,174,96,.1); color:#1a7a40; border:1px solid rgba(39,174,96,.25); }
.alert-error { background:rgba(192,57,43,.1); color:#8b2020; border:1px solid rgba(192,57,43,.2); }
.contact-info { display:flex; flex-direction:column; gap:18px; }
.office-card { background:var(--white); padding:24px; border-radius:var(--radius); border:1px solid var(--border); border-top:3px solid var(--bronze-l); }
.office-label { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--bronze); margin-bottom:10px; display:block; }
.office-card p { font-size:13px; color:var(--text-2); line-height:1.6; margin-bottom:12px; }
.office-contact { display:flex; flex-direction:column; gap:6px; }
.office-contact a { font-size:13px; color:var(--text-2); transition:color .2s; }
.office-contact a:hover { color:var(--bronze); }

/* ── FOOTER ── */
.footer { background:var(--text); padding:72px 0 32px; }
.footer-inner { max-width:1180px; margin:0 auto; padding:0 24px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand .footer-logo { height:34px; margin-bottom:16px; filter:brightness(1.6); }
.footer-brand p { font-size:13px; color:rgba(255,255,255,.4); line-height:1.8; max-width:270px; margin-bottom:18px; }
.footer-socials { display:flex; gap:10px; }
.footer-socials a { width:34px; height:34px; border:1px solid rgba(255,255,255,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.45); transition:.3s; }
.footer-socials a:hover { border-color:var(--bronze-l); color:var(--bronze-l); }
.footer-col h5 { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--bronze-l); margin-bottom:18px; }
.footer-col a { display:block; font-size:13px; color:rgba(255,255,255,.4); margin-bottom:10px; transition:color .3s; }
.footer-col a:hover { color:var(--bronze-l); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:24px; border-top:1px solid rgba(255,255,255,.05); flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-size:12px; color:rgba(255,255,255,.25); }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media(max-width:1100px) {
  .hero-left { padding:40px 40px; flex:0 0 42%; }
  .about-grid { gap:48px; }
}

@media(max-width:1024px) {
  .hero-section { flex-direction:column; height:auto; min-height:auto; }
  .hero-left { flex:none; width:100%; padding:80px 32px 48px; }
  .hero-right { width:100%; height:56vw; min-height:340px; position:relative; }
  .hero-slide { position:absolute; }
  .hero-inner { max-width:100%; }
  .hero-cta-btn { margin-bottom:40px; }
  .about-grid { grid-template-columns:1fr; gap:40px; }
  .about-right { grid-template-columns:1fr 1fr; }
  .about-img-main { grid-row:auto; aspect-ratio:4/3; }
  .two-col { grid-template-columns:1fr; gap:40px; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .contact-grid, .project-detail-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .testimonials-grid { grid-template-columns:1fr 1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .book-consult { display:none; }
  .feature-item:not(:last-child)::after { display:none; }
}

@media(max-width:768px) {
  :root { --nav-h: 64px; }
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .section { padding:64px 0; }
  .services-grid { grid-template-columns:1fr; }
  .projects-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .cta-inner { flex-direction:column; align-items:flex-start; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .strength-grid, .team-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .timeline { margin-left:56px; }
  .tl-year { left:-72px; font-size:15px; width:52px; }
  .features-inner { justify-content:center; gap:20px; }
  .feature-item { min-width:90px; flex:0 0 auto; }
  .about-right { grid-template-columns:1fr; }
  .about-img-main { display:none; }
  .about-img-col { flex-direction:row; }
  .hero-title { font-size:36px; }
  .about-stats-row { flex-wrap:wrap; width:100%; }
  .about-stat { flex:1; min-width:80px; }
}

@media(max-width:480px) {
  .hero-left { padding:72px 20px 36px; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .big-num { font-size:44px; }
  .features-inner { gap:12px; }
  .feature-item { min-width:calc(50% - 12px); padding:8px 12px; }
}

/* ═══════════════════════════════════════════════
   BLOG — LISTING
═══════════════════════════════════════════════ */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:24px; }
.blog-card { display:flex; flex-direction:column; background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:all .35s; text-decoration:none; }
.blog-card:hover { box-shadow:var(--shadow-h); transform:translateY(-5px); }
.blog-card-img { position:relative; overflow:hidden; aspect-ratio:16/9; background:var(--warm); flex-shrink:0; }
.blog-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.blog-card:hover .blog-card-img img { transform:scale(1.06); }
.blog-card-cat { position:absolute; top:12px; left:12px; background:var(--bronze); color:#fff; font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:4px 10px; border-radius:40px; }
.blog-card-body { padding:22px; display:flex; flex-direction:column; flex:1; }
.blog-card-title { font-family:'Playfair Display',serif; font-size:17px; font-weight:400; color:var(--text); line-height:1.4; margin-bottom:8px; }
.blog-card:hover .blog-card-title { color:var(--bronze); }
.blog-card-excerpt { font-size:13px; color:var(--text-2); line-height:1.7; flex:1; }
.blog-meta { display:flex; align-items:center; gap:6px; font-size:11px; color:var(--text-3); flex-wrap:wrap; }
.blog-meta svg { color:var(--text-3); flex-shrink:0; }
.blog-meta-dot { color:var(--border); }
.blog-cat-pill { display:inline-block; padding:4px 12px; background:rgba(138,104,32,.08); color:var(--bronze); font-size:10px; letter-spacing:2px; text-transform:uppercase; border-radius:40px; border:1px solid rgba(138,104,32,.15); margin-bottom:12px; }
.blog-cat-pill-light { background:rgba(255,255,255,.15); color:#fff; border-color:rgba(255,255,255,.3); }

/* ── BLOG FEATURED GRID ── */
.blog-featured-grid { display:grid; grid-template-columns:1.6fr 1fr; gap:16px; align-items:stretch; }
.blog-feat-card { display:flex; flex-direction:column; background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:all .35s; text-decoration:none; }
.blog-feat-card:hover { box-shadow:var(--shadow-h); transform:translateY(-4px); }
.blog-feat-img { overflow:hidden; background:var(--warm); flex-shrink:0; }
.blog-feat-main .blog-feat-img { aspect-ratio:16/9; }
.blog-feat-card:not(.blog-feat-main) .blog-feat-img { aspect-ratio:4/3; }
.blog-feat-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.blog-feat-card:hover .blog-feat-img img { transform:scale(1.05); }
.blog-feat-info { padding:24px; flex:1; display:flex; flex-direction:column; }
.blog-feat-title { font-family:'Playfair Display',serif; font-size:20px; font-weight:400; color:var(--text); line-height:1.35; margin-bottom:10px; }
.blog-feat-main .blog-feat-title { font-size:26px; }
.blog-feat-excerpt { font-size:14px; color:var(--text-2); line-height:1.8; margin-bottom:12px; flex:1; }
.blog-feat-card:hover .blog-feat-title { color:var(--bronze); }

/* ── BLOG ARTICLE ── */
.blog-article-hero { position:relative; padding-top:var(--nav-h); background:var(--white); border-bottom:1px solid var(--border); }
.blog-article-cover { position:relative; height:420px; overflow:hidden; }
.blog-article-cover img { width:100%; height:100%; object-fit:cover; }
.blog-article-cover-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(26,18,8,0.3), rgba(26,18,8,0.6)); }
.blog-article-hero-content { position:relative; padding:36px 0 40px; }
.blog-article-cover + .blog-article-hero-content { position:absolute; bottom:0; left:0; right:0; padding:32px 0; }
.blog-article-cover + .blog-article-hero-content .breadcrumb { color:rgba(255,255,255,.6); }
.blog-article-cover + .blog-article-hero-content .breadcrumb a { color:rgba(255,255,255,.8); }
.blog-article-title { font-family:'Playfair Display',serif; font-size:clamp(28px,4vw,52px); font-weight:400; line-height:1.15; color:var(--text); margin:12px 0 20px; max-width:780px; }
.blog-article-cover + .blog-article-hero-content .blog-article-title { color:#fff; }
.blog-article-meta { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.blog-article-author { display:flex; align-items:center; gap:12px; }
.blog-author-avatar { width:40px; height:40px; border-radius:50%; background:var(--bronze); color:#fff; font-size:14px; font-weight:600; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.blog-article-author strong { font-size:13px; font-weight:600; color:var(--text); display:block; }
.blog-article-cover + .blog-article-hero-content .blog-article-author strong { color:#fff; }
.blog-article-author span { font-size:12px; color:var(--text-3); }
.blog-article-cover + .blog-article-hero-content .blog-article-author span { color:rgba(255,255,255,.7); }

.blog-article-section { padding:72px 0 96px; }
.blog-article-grid { display:grid; grid-template-columns:1fr 340px; gap:64px; align-items:start; }
.blog-excerpt-lead { font-family:'Playfair Display',serif; font-style:italic; font-size:18px; color:var(--text-2); line-height:1.8; padding:20px 24px; border-left:3px solid var(--bronze-l); background:var(--warm); border-radius:0 var(--radius) var(--radius) 0; margin-bottom:32px; }
.blog-content { font-size:15px; line-height:1.9; color:var(--text-2); }
.blog-content p { margin-bottom:20px; }
.blog-content h2 { font-family:'Playfair Display',serif; font-size:24px; font-weight:400; color:var(--text); margin:36px 0 16px; }
.blog-content h3 { font-family:'Playfair Display',serif; font-size:20px; font-weight:400; color:var(--text); margin:28px 0 12px; }
.blog-content ul, .blog-content ol { padding-left:24px; margin-bottom:20px; }
.blog-content li { margin-bottom:8px; }
.blog-content strong { color:var(--text); font-weight:600; }
.blog-content a { color:var(--bronze); text-decoration:underline; text-underline-offset:3px; }

/* ── BLOG SHARE ── */
.blog-share { display:flex; align-items:center; gap:16px; flex-wrap:wrap; padding:24px; background:var(--warm); border-radius:var(--radius); margin-top:48px; border-top:3px solid var(--bronze-l); }
.blog-share-btns { display:flex; gap:10px; flex-wrap:wrap; }
.blog-share-btn { display:inline-flex; align-items:center; gap:8px; padding:9px 18px; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; font-weight:500; border-radius:var(--radius); cursor:pointer; font-family:'Inter',sans-serif; transition:all .3s; border:none; text-decoration:none; }
.blog-share-wa { background:#25D366; color:#fff; }
.blog-share-wa:hover { background:#1da851; }
.blog-share-copy { background:var(--white); color:var(--text-2); border:1.5px solid var(--border); }
.blog-share-copy:hover { border-color:var(--bronze-l); color:var(--bronze); }

/* ── BLOG SIDEBAR ── */
.blog-sidebar { position:sticky; top:calc(var(--nav-h) + 24px); display:flex; flex-direction:column; gap:20px; }
.blog-sidebar-card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:24px; }
.blog-sidebar-cta { background:var(--bronze-d); border-color:var(--bronze-d); }
.blog-sidebar-cta h4 { font-family:'Playfair Display',serif; font-size:18px; font-weight:400; color:#fff; margin-bottom:8px; }
.blog-sidebar-cta p { font-size:13px; color:rgba(255,255,255,.7); line-height:1.7; }
.blog-sidebar-title { font-size:11px; letter-spacing:2.5px; text-transform:uppercase; color:var(--bronze); display:block; margin-bottom:16px; }
.blog-sidebar-post { display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); text-decoration:none; transition:opacity .2s; }
.blog-sidebar-post:last-child { border-bottom:none; padding-bottom:0; }
.blog-sidebar-post:hover { opacity:.8; }
.blog-sidebar-post-img { width:60px; height:46px; border-radius:4px; overflow:hidden; flex-shrink:0; background:var(--warm); }
.blog-sidebar-post-img img { width:100%; height:100%; object-fit:cover; }
.blog-sidebar-post-title { display:block; font-size:13px; color:var(--text); line-height:1.4; margin-bottom:4px; }
.blog-sidebar-post-meta { display:block; font-size:11px; color:var(--text-3); }

/* ── BLOG RESPONSIVE ── */
@media(max-width:1024px) {
  .blog-article-grid { grid-template-columns:1fr; gap:40px; }
  .blog-sidebar { position:static; }
  .blog-featured-grid { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  .blog-grid { grid-template-columns:1fr; }
  .blog-article-cover { height:260px; }
  .blog-feat-main .blog-feat-title { font-size:20px; }
}
