/* ═══════════════════════════════════════
   NATO KAVTARADZE — LAWYER PORTFOLIO
   Main Stylesheet
═══════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Raleway:ital,wght@0,400;0,600;1,600&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --c1: #D4D7D8;
  --c2: #AFB3B6;
  --c3: #858D98;
  --c4: #2B313B;
  --white: #FFFFFF;
  --off:   #F4F4F5;
  --body:  #3A3F47;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'DM Sans',sans-serif; background:var(--white); color:var(--body); }

/* ── NAV ── */
.site-nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  background:var(--white); border-bottom:1px solid var(--c1);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 56px; height:68px;
}
.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-logo-mark { width:38px; height:38px; background:var(--c4); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.nav-logo-mark svg { width:18px; height:18px; stroke:var(--c2); fill:none; stroke-width:2; stroke-linecap:round; }
.nav-logo-text { font-family:'Libre Baskerville',serif; font-size:0.98rem; font-weight:700; color:var(--c4); }
.nav-right { display:flex; align-items:center; gap:36px; }
.nav-menu { display:flex; align-items:center; gap:36px; list-style:none; margin:0; padding:0; }
.nav-menu li { margin:0; padding:0; }
.nav-menu a {
  font-size:0.78rem; font-weight:500; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--c3); text-decoration:none;
  transition:color 0.2s; padding-bottom:2px;
  border-bottom:1.5px solid transparent;
}
.nav-menu a:hover,
.nav-menu .current-menu-item > a,
.nav-menu .current_page_item > a { color:var(--c4); border-bottom-color:var(--c4); }

/* Language Switcher */
.nav-hamburger { display:none; } /* shown only in mobile media query */
.lang-switcher { display:flex; align-items:center; gap:4px; }
.lang-btn {
  background:none; border:none; cursor:pointer;
  font-family:'DM Sans',sans-serif; font-size:0.72rem; font-weight:600;
  letter-spacing:0.1em; text-transform:uppercase; color:var(--c3);
  padding:4px 6px; transition:color 0.2s; line-height:1;
}
.lang-btn:hover { color:var(--c4); }
.lang-btn.active { color:var(--c4); border-bottom:1.5px solid var(--c4); padding-bottom:2px; }
.lang-sep { color:var(--c2); font-size:0.7rem; user-select:none; }

/* ── SHARED ── */
.page-wrap { padding-top:68px; }

.eyebrow {
  font-family:'Raleway',sans-serif; font-size:0.68rem; font-weight:600;
  font-style:italic; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--c3); margin-bottom:16px; display:block;
}
.section-heading {
  font-family:'Libre Baskerville',serif; font-size:clamp(1.4rem,2.4vw,1.95rem);
  font-weight:700; line-height:1.4; color:var(--c4); margin-bottom:20px;
}
.section-body { font-size:0.97rem; font-weight:300; line-height:1.9; color:var(--c3); margin-bottom:32px; }
.text-link {
  font-family:'Raleway',sans-serif; font-size:0.75rem; font-weight:600;
  font-style:italic; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--c4); text-decoration:none; border-bottom:1.5px solid var(--c2);
  padding-bottom:1px; transition:border-color 0.2s,color 0.2s;
}
.text-link:hover { color:var(--c3); border-color:var(--c3); }
.btn-primary {
  display:inline-block; background:var(--c3); color:var(--white);
  font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:500;
  letter-spacing:0.16em; text-transform:uppercase; padding:13px 34px;
  text-decoration:none; transition:background 0.25s; border:none; cursor:pointer;
}
.btn-primary:hover { background:var(--c2); color:var(--white); }
.btn-outline {
  display:inline-block; background:transparent; color:var(--c2);
  font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:500;
  letter-spacing:0.16em; text-transform:uppercase; padding:12px 34px;
  text-decoration:none; border:1px solid var(--c3); transition:all 0.25s; cursor:pointer;
}
.btn-outline:hover { border-color:var(--c2); color:var(--c1); }

/* ── HERO SPLIT ── */
.hero {
  min-height:calc(100vh - 68px); background:var(--c4);
  display:flex; position:relative; overflow:hidden;
}
.hero::after {
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(212,215,216,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(212,215,216,0.03) 1px,transparent 1px);
  background-size:60px 60px; pointer-events:none;
}
.hero-text {
  flex:1; display:flex; flex-direction:column; justify-content:center;
  padding:80px 72px 100px; position:relative; z-index:2;
}
.hero-eyebrow {
  font-family:'Raleway',sans-serif; font-size:0.68rem; font-weight:600;
  font-style:italic; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--c2); margin-bottom:24px;
}
.hero-title {
  font-family:'Libre Baskerville',serif; font-size:clamp(2rem,3.5vw,3.2rem);
  font-weight:700; line-height:1.2; color:var(--c1); margin-bottom:12px;
}
.hero-title em { font-style:italic; font-weight:400; color:var(--c2); }
.hero-name {
  font-family:'Libre Baskerville',serif; font-size:1.3rem; font-weight:700;
  color:var(--c1); margin-bottom:20px; letter-spacing:0.02em;
}
.hero-sub { font-size:0.92rem; font-weight:300; line-height:1.85; color:var(--c3); max-width:460px; margin-bottom:44px; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; }
.hero-photo { width:44%; flex-shrink:0; position:relative; overflow:hidden; }
.hero-photo img { width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
.hero-photo::before {
  content:''; position:absolute; inset:0; z-index:1;
  background:linear-gradient(to right, var(--c4) 0%, rgba(43,49,59,0.2) 30%, transparent 60%);
}
.hero-scroll {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:'Raleway',sans-serif; font-size:0.55rem; letter-spacing:0.3em;
  text-transform:uppercase; color:var(--c3); z-index:3; user-select:none;
}
.hero-scroll-line {
  width:1px; height:36px;
  background:linear-gradient(to bottom,var(--c3),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%   { opacity:0; transform:scaleY(0); transform-origin:top; }
  50%  { opacity:1; transform:scaleY(1); transform-origin:top; }
  100% { opacity:0; transform:scaleY(1); transform-origin:bottom; }
}

/* ── KEY STRENGTHS ── */
.strengths-section { background:var(--c4); padding:88px 24px; }
.strengths-inner { max-width:1060px; margin:0 auto; }
.strengths-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:48px; }
.strength-card { background:rgba(255,255,255,0.04); padding:36px 28px; border-top:2px solid transparent; transition:border-color 0.25s,background 0.25s; }
.strength-card:hover { border-top-color:var(--c3); background:rgba(255,255,255,0.07); }
.strength-icon { width:40px; height:40px; margin-bottom:20px; }
.strength-icon svg { width:24px; height:24px; stroke:var(--c3); fill:none; stroke-width:1.8; stroke-linecap:round; }
.strength-title { font-family:'Libre Baskerville',serif; font-size:0.95rem; font-weight:700; color:var(--c1); margin-bottom:10px; }
.strength-text { font-size:0.83rem; font-weight:300; line-height:1.75; color:var(--c3); }

/* ── SERVICES ICONS ── */
.help-section { background:var(--c1); padding:88px 24px; text-align:center; border-top:1px solid var(--c2); border-bottom:1px solid var(--c2); }
.help-divider { width:100%; max-width:680px; height:1px; background:var(--c2); margin:40px auto; }
.icon-grid { display:flex; justify-content:center; gap:48px; flex-wrap:wrap; max-width:900px; margin:0 auto; }
.icon-item { display:flex; flex-direction:column; align-items:center; gap:14px; text-decoration:none; transition:opacity 0.2s; width:110px; }
.icon-item:hover { opacity:0.65; }
.icon-circle { width:78px; height:78px; background:var(--c4); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background 0.2s; }
.icon-item:hover .icon-circle { background:var(--c3); }
.icon-circle svg { width:30px; height:30px; stroke:var(--c2); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.icon-label { font-family:'Raleway',sans-serif; font-size:0.78rem; font-weight:600; font-style:italic; color:var(--c4); text-align:center; line-height:1.35; }

/* ── SERVICE / PRACTICE AREA CARDS ── */
.service-detail-section { background:var(--white); padding:80px 24px; }
.service-detail-inner { max-width:1060px; margin:0 auto; }
.service-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:48px; }
.service-card { background:var(--off); padding:36px 28px; border-left:3px solid transparent; transition:border-color 0.25s,background 0.25s; }
.service-card:hover { border-left-color:var(--c3); background:var(--c1); }
.service-card-icon { margin-bottom:16px; }
.service-card-icon svg { width:28px; height:28px; stroke:var(--c3); fill:none; stroke-width:1.8; stroke-linecap:round; }
.service-card-title { font-family:'Libre Baskerville',serif; font-size:1rem; font-weight:700; color:var(--c4); margin-bottom:10px; }
.service-card-text { font-size:0.85rem; font-weight:300; line-height:1.8; color:var(--c3); }

/* ── PAGE HERO BANNERS ── */
.page-hero { background:var(--c4); padding:80px 24px 72px; text-align:center; }
.page-hero .section-heading { color:var(--c1); font-size:clamp(1.8rem,3vw,2.6rem); margin-bottom:16px; }
.page-hero p { color:var(--c3); font-size:1rem; font-weight:300; line-height:1.8; max-width:560px; margin:0 auto; }
.page-hero .eyebrow { color:var(--c2); }

/* ── PROMISE ── */
.promise-section { background:var(--white); padding:72px 24px; text-align:center; }
.promise-items { display:flex; justify-content:center; gap:64px; flex-wrap:wrap; margin-top:32px; }
.promise-item {
  font-family:'Raleway',sans-serif; font-size:0.75rem; font-weight:600;
  font-style:italic; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--c4); display:flex; align-items:center; gap:10px;
}
.promise-check {
  width:20px; height:20px; border:1.5px solid var(--c3); border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:0.65rem;
  color:var(--c3); flex-shrink:0;
}

/* ── PRACTICE AREAS (dark bg on home) ── */
.areas-home-section { background:var(--c4); padding:80px 24px; }
.areas-home-inner { max-width:1060px; margin:0 auto; }
.areas-dark-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:40px; }
.area-dark-card {
  background:rgba(255,255,255,0.05); padding:36px 28px;
  border-left:3px solid transparent; transition:border-color 0.25s,background 0.25s;
}
.area-dark-card:hover { border-left-color:var(--c3); background:rgba(255,255,255,0.09); }
.area-dark-card .service-card-title { color:var(--c1); }
.area-dark-card .service-card-text { color:var(--c3); }

/* ── ABOUT PAGE ── */
.about-section { background:var(--white); padding:88px 24px; }
.about-inner { max-width:960px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.about-left .section-body { margin-bottom:16px; }
.about-right { padding-top:8px; }
.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-top:40px; }
.about-stat-num { font-family:'Libre Baskerville',serif; font-size:2.2rem; font-weight:700; color:var(--c4); line-height:1; }
.about-stat-label { font-size:0.78rem; font-weight:300; color:var(--c3); margin-top:6px; line-height:1.4; }
.about-langs { margin-top:40px; padding-top:32px; border-top:1px solid var(--c1); }
.about-langs-title { font-family:'Raleway',sans-serif; font-size:0.62rem; font-weight:600; font-style:italic; letter-spacing:0.18em; text-transform:uppercase; color:var(--c3); margin-bottom:12px; }
.about-lang-tags { display:flex; gap:8px; flex-wrap:wrap; }
.about-lang-tag { font-size:0.78rem; font-weight:400; color:var(--c4); background:var(--off); padding:5px 14px; border:1px solid var(--c1); }

/* ── BLOG ── */
.home-blog-section { background:var(--c1); padding:88px 24px; border-top:1px solid var(--c2); border-bottom:1px solid var(--c2); }
.home-blog-inner { max-width:1060px; margin:0 auto; }
.blog-full-section { background:var(--c1); padding:80px 24px; }
.blog-full-inner { max-width:1060px; margin:0 auto; }
.blog-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:52px; flex-wrap:wrap; gap:16px; }
.blog-filter-row { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:48px; }
.filter-btn {
  font-family:'Raleway',sans-serif; font-size:0.68rem; font-weight:600;
  font-style:italic; letter-spacing:0.12em; text-transform:uppercase;
  background:var(--white); color:var(--c3); border:1px solid var(--c2);
  padding:7px 18px; cursor:pointer; transition:all 0.2s;
}
.filter-btn:hover, .filter-btn.active { background:var(--c4); color:var(--c1); border-color:var(--c4); }
.blog-grid, .blog-grid-full { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.blog-card {
  background:var(--white); display:flex; flex-direction:column;
  text-decoration:none; color:inherit; transition:background 0.25s;
  overflow:hidden; box-shadow:0 1px 4px rgba(43,49,59,0.06);
}
.blog-card:hover { background:var(--off); }
.blog-card-img { width:100%; aspect-ratio:16/9; position:relative; overflow:hidden; flex-shrink:0; background:linear-gradient(135deg,var(--c3) 0%,var(--c4) 100%); }
.blog-card-img img { width:100%; height:100%; object-fit:cover; display:block; }
.blog-card-img-placeholder { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.blog-card-img-placeholder svg { width:32px; height:32px; stroke:rgba(255,255,255,0.4); fill:none; stroke-width:1.5; stroke-linecap:round; }
.blog-card-body { padding:28px 28px 32px; flex:1; display:flex; flex-direction:column; }
.blog-card-meta {
  font-family:'Raleway',sans-serif; font-size:0.62rem; font-weight:600;
  font-style:italic; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--c3); margin-bottom:12px; display:flex; gap:12px; align-items:center;
}
.blog-card-meta::before { content:''; width:20px; height:1px; background:var(--c2); }
.blog-card-title { font-family:'Libre Baskerville',serif; font-size:1rem; font-weight:700; line-height:1.45; color:var(--c4); margin-bottom:12px; transition:color 0.2s; }
.blog-card:hover .blog-card-title { color:var(--body); }
.blog-card-excerpt { font-size:0.85rem; font-weight:300; line-height:1.75; color:var(--c3); flex:1; margin-bottom:20px; }
.blog-card-link {
  font-family:'Raleway',sans-serif; font-size:0.7rem; font-weight:600;
  font-style:italic; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--c4); border-bottom:1px solid var(--c2); padding-bottom:1px;
  align-self:flex-start; transition:color 0.2s;
}
.blog-card:hover .blog-card-link { color:var(--c3); }

/* Single post */
.single-post-hero { background:var(--c4); padding:80px 24px 60px; }
.single-post-hero .eyebrow { color:var(--c2); }
.single-post-hero h1 { font-family:'Libre Baskerville',serif; font-size:clamp(1.8rem,3vw,2.6rem); font-weight:700; color:var(--c1); line-height:1.3; max-width:760px; }
.single-post-content { max-width:760px; margin:0 auto; padding:72px 24px 80px; }
.single-post-content p { font-size:1rem; font-weight:300; line-height:1.9; color:var(--body); margin-bottom:24px; }
.single-post-content h2 { font-family:'Libre Baskerville',serif; font-size:1.45rem; font-weight:700; color:var(--c4); margin:40px 0 16px; }
.single-post-content h3 { font-family:'Libre Baskerville',serif; font-size:1.15rem; font-weight:700; color:var(--c4); margin:32px 0 12px; }
.single-post-content ul, .single-post-content ol { padding-left:24px; margin-bottom:24px; }
.single-post-content li { font-size:0.97rem; font-weight:300; line-height:1.8; color:var(--body); margin-bottom:8px; }
.single-post-content a { color:var(--c4); border-bottom:1px solid var(--c2); text-decoration:none; }
.single-post-content a:hover { color:var(--c3); }
.post-back-link { display:inline-flex; align-items:center; gap:8px; font-family:'Raleway',sans-serif; font-size:0.72rem; font-weight:600; font-style:italic; letter-spacing:0.12em; text-transform:uppercase; color:var(--c2); text-decoration:none; margin-bottom:32px; transition:color 0.2s; }
.post-back-link:hover { color:var(--c1); }

/* ── CONTACT ── */
.contact-main { background:var(--white); padding:80px 24px; }
.contact-inner { max-width:960px; margin:0 auto; display:grid; grid-template-columns:1fr 1.4fr; gap:80px; align-items:start; }
.contact-info-title { font-family:'Libre Baskerville',serif; font-size:1.3rem; font-weight:700; color:var(--c4); margin-bottom:28px; }
.contact-info-item { display:flex; align-items:flex-start; gap:16px; margin-bottom:28px; }
.contact-info-icon { width:40px; height:40px; background:var(--c1); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-info-icon svg { width:18px; height:18px; stroke:var(--c4); fill:none; stroke-width:1.8; stroke-linecap:round; }
.contact-info-label { font-family:'Raleway',sans-serif; font-size:0.62rem; font-weight:600; font-style:italic; letter-spacing:0.16em; text-transform:uppercase; color:var(--c3); margin-bottom:4px; }
.contact-info-value { font-size:0.95rem; color:var(--c4); }
.contact-info-value a { color:var(--c4); text-decoration:none; transition:color 0.2s; }
.contact-info-value a:hover { color:var(--c3); }
.contact-hours { margin-top:40px; padding-top:32px; border-top:1px solid var(--c1); }
.contact-hours-title { font-family:'Raleway',sans-serif; font-size:0.68rem; font-weight:600; font-style:italic; letter-spacing:0.18em; text-transform:uppercase; color:var(--c3); margin-bottom:16px; }
.contact-hours-row { display:flex; justify-content:space-between; font-size:0.88rem; padding:8px 0; border-bottom:1px solid var(--c1); color:var(--body); }
.contact-hours-row:last-child { border-bottom:none; }
.contact-form-wrap { background:var(--off); padding:44px 40px; }
.contact-form-title { font-family:'Libre Baskerville',serif; font-size:1.15rem; font-weight:700; color:var(--c4); margin-bottom:28px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:20px; }
.form-group label { font-size:0.62rem; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; color:var(--c3); }
.form-group input,
.form-group select,
.form-group textarea {
  padding:10px 0; border:none; border-bottom:1px solid var(--c2);
  background:transparent; font-family:'DM Sans',sans-serif; font-size:0.9rem;
  color:var(--c4); outline:none; transition:border-color 0.2s; appearance:none; width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--c4); }
.form-group textarea { resize:vertical; min-height:90px; }
.form-submit {
  margin-top:8px; padding:14px 0; background:var(--c4); color:#fff;
  font-family:'DM Sans',sans-serif; font-size:0.72rem; font-weight:500;
  letter-spacing:0.18em; text-transform:uppercase; border:none; cursor:pointer;
  width:100%; transition:background 0.25s;
}
.form-submit:hover { background:var(--c3); }
.contact-form-message { padding:12px 16px; margin-top:16px; font-size:0.85rem; display:none; }
.contact-form-message.success { background:#e8f5e9; color:#2e7d32; border:1px solid #a5d6a7; display:block; }
.contact-form-message.error   { background:#fce4e4; color:#c62828; border:1px solid #ef9a9a; display:block; }

/* ── FOOTER ── */
.site-footer { background:var(--c4); padding:60px 24px 36px; text-align:center; border-top:1px solid rgba(133,141,152,0.25); }
.footer-cta-row { display:flex; align-items:center; justify-content:center; gap:36px; flex-wrap:wrap; margin-bottom:22px; }
.footer-cta-text { font-family:'Libre Baskerville',serif; font-size:clamp(1.2rem,2vw,1.65rem); font-weight:400; color:var(--c1); }
.footer-contact-line { font-size:0.85rem; font-weight:300; color:var(--c3); margin-bottom:40px; }
.footer-contact-line a { color:var(--c3); text-decoration:none; transition:color 0.2s; }
.footer-contact-line a:hover { color:var(--c1); }
.footer-divider { width:100%; max-width:480px; height:1px; background:rgba(133,141,152,0.25); margin:0 auto 36px; }
.footer-social { display:flex; justify-content:center; gap:20px; margin-bottom:32px; }
.footer-social a { width:36px; height:36px; border-radius:50%; border:1px solid rgba(175,179,182,0.25); display:flex; align-items:center; justify-content:center; color:var(--c3); text-decoration:none; transition:all 0.2s; }
.footer-social a:hover { border-color:var(--c2); color:var(--c2); }
.footer-social a svg { width:15px; height:15px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; }
.footer-legal { font-size:0.7rem; font-weight:300; color:rgba(133,141,152,0.55); line-height:1.9; }
.footer-legal a { color:rgba(175,179,182,0.55); text-decoration:none; transition:color 0.2s; }
.footer-legal a:hover { color:var(--c2); }

/* ── RESPONSIVE — TABLET (max 1024px) ── */
@media (max-width:1024px) {
  .site-nav { padding:0 28px; }
  .nav-menu { gap:20px; }
  .nav-menu a { font-size:0.72rem; }
  .hero-text { padding:64px 48px 80px; }
  .hero-photo { width:42%; }
}

/* ── RESPONSIVE — TABLET PORTRAIT / LARGE MOBILE (max 900px) ── */
@media (max-width:900px) {
  /* NAV — hide text menu, show hamburger */
  .site-nav { padding:0 24px; height:60px; }
  .page-wrap { padding-top:60px; }
  .nav-menu { display:none; }
  .nav-menu.open {
    display:flex; flex-direction:column; align-items:flex-start;
    position:fixed; top:60px; left:0; right:0; bottom:0;
    background:var(--white); z-index:199;
    padding:32px 28px; gap:0; overflow-y:auto;
    border-top:1px solid var(--c1);
  }
  .nav-menu.open li { width:100%; border-bottom:1px solid var(--c1); }
  .nav-menu.open a {
    display:block; padding:16px 0; font-size:0.85rem;
    border-bottom:none; width:100%;
  }
  .nav-hamburger {
    display:flex; flex-direction:column; justify-content:center;
    gap:5px; background:none; border:none; cursor:pointer;
    padding:6px; width:34px; height:34px;
  }
  .nav-hamburger span {
    display:block; width:22px; height:1.5px;
    background:var(--c4); transition:all 0.25s;
  }
  .nav-hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
  .nav-hamburger.open span:nth-child(2) { opacity:0; }
  .nav-hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

  /* HERO — stack: photo behind, text on top */
  .hero {
    flex-direction:column;
    min-height:calc(100vh - 60px);
    position:relative;
  }
  .hero-photo {
    position:absolute; inset:0;
    width:100%; height:100%;
  }
  .hero-photo img {
    width:100%; height:100%;
    object-fit:cover;
    object-position:center top;
  }
  /* dark overlay over the whole hero so text is readable */
  .hero-photo::before {
    background:linear-gradient(
      to bottom,
      rgba(43,49,59,0.92) 0%,
      rgba(43,49,59,0.80) 50%,
      rgba(43,49,59,0.65) 100%
    );
  }
  .hero-text {
    position:relative; z-index:2;
    padding:72px 32px 100px;
    flex:none; width:100%;
    min-height:calc(100vh - 60px);
    display:flex; flex-direction:column; justify-content:center;
  }
  .hero-sub { max-width:100%; }

  /* OTHER SECTIONS */
  .about-inner { grid-template-columns:1fr; gap:40px; }
  .strengths-grid { grid-template-columns:repeat(2,1fr); }
  .service-cards { grid-template-columns:repeat(2,1fr); }
  .areas-dark-grid { grid-template-columns:repeat(2,1fr); }
}

/* ── RESPONSIVE — MOBILE (max 640px) ── */
@media (max-width:640px) {
  .site-nav { padding:0 16px; }
  .hero-text { padding:56px 20px 88px; }
  .hero-title { font-size:clamp(1.8rem,8vw,2.6rem); }
  .hero-name { font-size:1.1rem; }
  .hero-sub { font-size:0.88rem; }
  .hero-btns { flex-direction:column; gap:10px; }
  .hero-btns .btn-primary,
  .hero-btns .btn-outline { width:100%; text-align:center; }

  .blog-grid, .blog-grid-full, .service-cards, .areas-dark-grid { grid-template-columns:1fr; }
  .contact-inner { grid-template-columns:1fr; gap:40px; }
  .icon-grid { gap:24px; }
  .icon-item { width:88px; }
  .icon-circle { width:64px; height:64px; }
  .icon-circle svg { width:24px; height:24px; }
  .promise-items { gap:20px; flex-direction:column; align-items:flex-start; padding:0 20px; }
  .blog-header { flex-direction:column; align-items:flex-start; }
  .form-row { grid-template-columns:1fr; }
  .contact-form-wrap { padding:28px 20px; }
  .strengths-grid { grid-template-columns:1fr; }
  .about-stats { grid-template-columns:1fr 1fr; }
  .footer-cta-row { flex-direction:column; gap:20px; }
  .page-hero { padding:56px 20px 48px; }
  .help-section { padding:60px 20px; }
  .strengths-section { padding:60px 20px; }
  .service-detail-section { padding:56px 20px; }
}

/* ── PRIVACY POLICY ── */
.privacy-page { background:var(--white); padding:72px 24px 96px; }
.privacy-inner { max-width:760px; margin:0 auto; }
.privacy-updated {
  font-family:'Raleway',sans-serif; font-size:0.68rem; font-weight:600;
  font-style:italic; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--c3); margin-bottom:48px; display:block;
}
.privacy-inner h2 {
  font-family:'Libre Baskerville',serif; font-size:1.15rem; font-weight:700;
  color:var(--c4); margin:40px 0 14px; padding-top:8px;
  border-top:1px solid var(--c1);
}
.privacy-inner h2:first-of-type { border-top:none; margin-top:0; }
.privacy-inner p {
  font-size:0.95rem; font-weight:300; line-height:1.9; color:var(--body); margin-bottom:16px;
}
.privacy-inner ul, .privacy-inner ol {
  padding-left:20px; margin-bottom:16px;
}
.privacy-inner li {
  font-size:0.93rem; font-weight:300; line-height:1.8; color:var(--body); margin-bottom:8px;
}
.privacy-inner strong { font-weight:500; color:var(--c4); }
.privacy-inner a { color:var(--c4); border-bottom:1px solid var(--c2); text-decoration:none; transition:color 0.2s; }
.privacy-inner a:hover { color:var(--c3); }
