/*
Theme Name: Scalp Micro Sweden
Author: Hypermesh
Description: Premium SMP landing page — gold & white system.
Version: 3.0
*/
:root{
--gold:#C9A646;--gold-dark:#B08B2A;--gold-light:#F5E9C4;
--beige:#F3EAD7;--beige-light:#FAF7F2;
--white:#FFFFFF;--dark:#111111;--dark2:#1E1E1E;
--text:#111111;--muted:#6B7280;--border:#E8E2D9;
--shadow-sm:0 2px 8px rgba(0,0,0,.06);
--shadow-md:0 8px 32px rgba(0,0,0,.10);
--shadow-lg:0 20px 60px rgba(0,0,0,.14);
--r-sm:8px;--r-md:14px;--r-lg:24px;--r-xl:40px;
--font-head:'Playfair Display',Georgia,serif;
--font-body:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);color:var(--text);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{
  text-decoration:none;
  color:inherit;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  -webkit-touch-callout:none;
}
ul{list-style:none;}
button{
  font-family:var(--font-body);
  cursor:pointer;
  border:none;
  background:none;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  -webkit-touch-callout:none;
}
/* Remove blue focus box on tap (mobile) — keep for keyboard navigation */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
input:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible){
  outline:none;
}
/* Buttons */
.btn-gold{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:var(--gold);color:#fff;font-size:14px;font-weight:700;letter-spacing:.3px;border-radius:var(--r-sm);transition:all .25s ease;border:none;cursor:pointer;}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-1px);box-shadow:0 8px 24px rgba(201,166,70,.35);}
.btn-outline-dark{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:transparent;color:var(--dark);font-size:14px;font-weight:600;border:1.5px solid var(--dark);border-radius:var(--r-sm);transition:all .25s ease;}
.btn-outline-dark:hover{background:var(--dark);color:#fff;}
.btn-outline-gold{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:transparent;color:var(--gold);font-size:14px;font-weight:600;border:1.5px solid var(--gold);border-radius:var(--r-sm);transition:all .25s ease;}
.btn-outline-gold:hover{background:var(--gold);color:#fff;}
/* Container */
.container{max-width:1160px;margin:0 auto;padding:0 40px;width:100%;}
/* Section labels */
.section-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.section-title{font-family:var(--font-head);font-size:42px;font-weight:800;line-height:1.15;color:var(--text);margin-bottom:16px;}
.section-sub{font-size:17px;color:var(--muted);line-height:1.7;max-width:560px;}
.text-center{text-align:center;}.text-center .section-sub{margin:0 auto;}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .3s,box-shadow .3s;background:rgba(255,255,255,0);}
.site-header.scrolled{background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.08);}
.header-inner{max-width:1280px;margin:0 auto;padding:0 40px;display:flex;justify-content:space-between;align-items:center;height:74px;}
.header-logo img{height:44px;width:auto;}
.main-nav ul{display:flex;gap:36px;}
.main-nav a{font-size:14px;font-weight:500;color:var(--text);transition:color .2s;}
.main-nav a:hover{color:var(--gold);}
.header-right{display:flex;align-items:center;gap:18px;}
/* Lang dropdown */
.lang-dropdown{position:relative;}
.lang-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--border);border-radius:50px;font-size:13px;font-weight:600;color:var(--text);background:#fff;cursor:pointer;transition:border-color .2s;}
.lang-btn:hover{border-color:var(--gold);}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1.5px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--shadow-md);display:none;min-width:130px;overflow:hidden;z-index:200;}
.lang-menu.open{display:block;}
.lang-option{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:13px;font-weight:500;background:none;border:none;cursor:pointer;text-align:left;transition:background .15s;}
.lang-option:hover,.lang-option.active{background:var(--beige-light);}
/* Phone block */
.header-phone{display:flex;flex-direction:column;align-items:flex-end;}
.phone-label{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--muted);line-height:1;}
.phone-number{font-size:15px;font-weight:700;color:var(--text);line-height:1.2;}
.phone-number:hover{color:var(--gold);}
/* Hamburger */
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  padding:8px;
  width:44px;
  height:44px; /* Proper touch target */
  justify-content:center;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  cursor:pointer;
}
.hamburger span{display:block;height:2px;background:var(--dark);border-radius:2px;transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
/* Mobile menu */
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:20px 24px 28px;background:#fff;border-top:1px solid var(--border);}
.mobile-menu.open{display:flex;}
.mobile-cta{margin-bottom:12px;text-align:center;justify-content:center;}
.mobile-link{
  padding:13px 0;
  font-size:16px;
  font-weight:500;
  color:var(--text);
  border-bottom:1px solid var(--border);
  display:block;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  min-height:44px; /* WCAG touch target */
  display:flex;
  align-items:center;
}
.mobile-link:hover{color:var(--gold);}
.mobile-phone{margin-top:16px;font-size:14px;color:var(--muted);}
.mobile-socials{display:flex;gap:12px;justify-content:center;}
.mobile-social-link{
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text);
  transition:all .2s;
  background:#fff;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.mobile-social-link:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
@media(max-width:900px){
.main-nav{display:none;}
.header-right .btn-gold{display:none;}
.hamburger{display:flex;}
.header-phone{display:none;}
}

/* ===== HERO ===== */
.hero-section{position:relative;z-index:1;display:flex;align-items:center;gap:60px;min-height:calc(100vh - 74px);max-width:1280px;margin:0 auto;padding:120px 40px 80px;}
.hero-section::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:100vw;height:100%;z-index:-1;background-image:linear-gradient(to right, rgba(0,0,0,0.05) 1px, transparent 1px),linear-gradient(to bottom, rgba(0,0,0,0.05) 1px, transparent 1px);background-size:50px 50px;mask-image:radial-gradient(ellipse at center, rgba(0,0,0,1) 30%, rgba(0,0,0,0) 80%);-webkit-mask-image:radial-gradient(ellipse at center, rgba(0,0,0,1) 30%, rgba(0,0,0,0) 80%);pointer-events:none;}
.hero-content{flex:1;max-width:580px;}
.hero-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:inline-block;border:1.5px solid var(--gold);padding:6px 14px;border-radius:50px;}
.hero-title{font-family:var(--font-head);font-size:48px;font-weight:800;line-height:1.05;color:var(--text);margin-bottom:20px;}
.hero-sub{font-size:17px;color:var(--muted);line-height:1.6;margin-bottom:24px;}
.hero-desc-link{color:var(--gold);text-decoration:underline;font-weight:600;}
/* CTA row */
.hero-cta-row{display:flex;gap:16px;align-items:center;margin-bottom:28px;}
/* Charity Strip */
.charity-strip{display:flex;flex-direction:column;gap:12px;margin-top:10px;}
.charity-logos{display:flex;gap:16px;align-items:center;}
.charity-logos img{height:40px;width:40px;border-radius:8px;object-fit:contain;background:#fff;border:1px solid var(--border);padding:4px;box-shadow:var(--shadow-sm);transition:all .3s;}
.charity-logos img:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.charity-text{font-size:12px;color:var(--muted);font-style:italic;line-height:1.5;max-width:480px;}
/* Hero visual */
.hero-visual{flex:1;height:560px;position:relative;border-radius:var(--r-xl);overflow:visible;}
.hero-visual > img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:var(--r-xl);box-shadow:var(--shadow-lg);}
.hero-badge{position:absolute;background:#fff;border-radius:var(--r-sm);padding:14px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:var(--text);z-index:10;white-space:nowrap;}
.hero-badge.tr{top:30px;right:-20px;}
.hero-badge.bl{bottom:100px;left:-30px;}
.hero-badge.br{bottom:30px;right:-20px;}
.hero-badge .icon{color:var(--gold);font-size:16px;}
.hero-badge.tr .icon{color:#4285F4;}
@media(max-width:900px){
.hero-section{flex-direction:column-reverse;padding:100px 24px 60px;gap:40px;}
.hero-section::before{display:none;}
.hero-content{max-width:100%;}
.hero-title{font-size:40px;}
.hero-visual{width:100%;height:400px;}
.hero-badge{padding:10px 14px;font-size:12px;}
.hero-badge.tr{top:20px;right:10px;}
.hero-badge.bl{display:none;}
.hero-badge.br{display:none;}
}

@media(max-width:600px){
.hero-cta-row{flex-direction:column;align-items:stretch;}
.hero-cta-row .btn-gold, .hero-cta-row .btn-outline-dark{width:100%;justify-content:center;}
}

/* ===== REVIEW STRIP ===== */
.review-strip-wrap{padding:0 40px;margin-top:-40px;position:relative;z-index:20;margin-bottom:60px;}
.review-strip{max-width:950px;margin:0 auto;background:#fff;border-radius:50px;padding:16px 24px;box-shadow:0 0 24px rgba(0,0,0,0.08);display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);gap:24px;}
.rs-group{display:flex;align-items:center;}
.rs-ratings{gap:16px;}
.rs-platform{display:flex;align-items:center;gap:8px;}
.rs-platform img{width:32px;height:32px;border-radius:50%;object-fit:contain;background:#fff;padding:4px;box-shadow:0 2px 4px rgba(0,0,0,0.1);border:1px solid var(--border);}
.rs-score{font-size:14px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:4px;white-space:nowrap;}
.rs-stars{color:var(--gold);font-size:13px;letter-spacing:1px;}
.rs-divider{width:1px;height:24px;background:var(--border);}
.rs-center-quote{flex:1;justify-content:center;font-size:15px;font-weight:500;color:var(--text);font-style:italic;text-align:center;max-width:400px;margin:0 auto;}
.rs-quote-rotator{height:20px;overflow:hidden;position:relative;width:100%;}
.rs-quote-list{display:flex;flex-direction:column;animation:slideQuote 15s infinite;}
.rs-quote-item{height:20px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
@keyframes slideQuote {
  0%, 16% { transform: translateY(0); }
  20%, 36% { transform: translateY(-20px); }
  40%, 56% { transform: translateY(-40px); }
  60%, 76% { transform: translateY(-60px); }
  80%, 96% { transform: translateY(-80px); }
  100% { transform: translateY(-100px); }
}
.rs-social{gap:12px;}
.rs-avatars{display:flex;}
.rs-avatars img{width:32px;height:32px;border-radius:50%;border:2px solid #fff;margin-left:-12px;object-fit:cover;box-shadow:0 2px 4px rgba(0,0,0,0.1);}
.rs-avatars img:first-child{margin-left:0;}
.rs-count{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;}

@media(max-width:900px){
  .review-strip{flex-direction:column;border-radius:24px;padding:20px;gap:16px;}
  .rs-ratings{width:100%;justify-content:center;}
  .rs-center-quote{max-width:100%;white-space:normal;text-align:center;font-size:14px;}
  .rs-social{width:100%;justify-content:center;margin-top:4px;}
}
@media(max-width:500px){
  .rs-ratings{flex-direction:column;gap:12px;}
  .rs-divider{width:100%;height:1px;max-width:100px;}
}

/* ===== TRUST STRIP ===== */
.trust-strip{background:#fff;padding:30px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;width:100%;}
/* Track: two groups side-by-side; translateX(-50%) seamlessly loops back to start */
.trust-strip-track{
  display:flex;
  width:max-content;
  animation:scrollTrust 28s linear infinite;
  will-change:transform;
}
.trust-strip-track:hover{animation-play-state:paused;}
/* Each group — NO padding-right (it would break the -50% loop math).
   Gap between items only; groups butt up against each other seamlessly. */
.trust-strip-group{display:flex;align-items:center;gap:60px;}
/* Add the inter-group spacing via the last item of each group */
.trust-strip-group::after{
  content:'';
  display:block;
  width:60px;
  flex-shrink:0;
}
.trust-card{display:flex;align-items:center;gap:12px;cursor:default;white-space:nowrap;}
.tc-icon{color:var(--gold);background:var(--beige);width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tc-icon svg{width:22px;height:22px;}
.tc-num{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--text);line-height:1.2;}
.tc-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:600;}
@keyframes scrollTrust {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@media(max-width:900px){
  .trust-strip{padding:20px 0;}
  .trust-strip-track{animation:scrollTrust 18s linear infinite;}
  .trust-strip-group{gap:40px;}
  .trust-strip-group::after{width:40px;}
}


/* ===== PROBLEM SECTION ===== */
.problem-section{padding:100px 0;background:var(--beige-light);}
.problem-intro{font-size:15px;color:var(--muted);margin-bottom:48px;font-style:italic;}
.problem-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;}
.problem-card{width:calc(33.333% - 14px);background:#fff;border-radius:var(--r-md);padding:20px;border:1px solid var(--border);transition:box-shadow .25s,transform .25s;position:relative;display:flex;flex-direction:column;}
.problem-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.problem-badge{position:absolute;top:32px;right:32px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:50px;background:#fff;color:var(--gold-dark);z-index:10;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.problem-image{width:100%;height:200px;margin-bottom:16px;border-radius:10px;overflow:hidden;}
.problem-image img{width:100%;height:100%;object-fit:cover;border-radius:10px;transition:transform .5s;}
.problem-card:hover .problem-image img{transform:scale(1.05);}
.problem-card h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px;}
.problem-card p{font-size:13px;color:var(--muted);line-height:1.6;margin:0;}
@media(max-width:900px){.problem-card{width:calc(50% - 10px);}}
@media(max-width:600px){.problem-card{width:100%;}}

/* ===== SOLUTION SECTION ===== */
.solution-section{padding:100px 0;background:#fff;}
.solution-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.solution-img{width:100%;height:520px;object-fit:cover;border-radius:var(--r-lg) var(--r-xl) var(--r-lg) var(--r-lg);}
.solution-bullets{list-style:none;margin:28px 0 36px;}
.solution-bullets li{display:flex;align-items:flex-start;gap:14px;font-size:16px;color:var(--text);margin-bottom:16px;}
.bullet-check{width:24px;height:24px;background:var(--gold);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px;}
@media(max-width:900px){.solution-wrap{grid-template-columns:1fr;gap:20px;}.solution-img{height:320px;}}

/* ===== AUTHORITY SECTION ===== */
.authority-section{padding:100px 0;background:var(--beige-light);}
.authority-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.authority-img{width:100%;height:560px;object-fit:cover;object-position:top;border-radius:var(--r-xl) var(--r-xl) var(--r-lg) var(--r-lg);box-shadow:var(--shadow-lg);}
.authority-bullets{list-style:none;margin:20px 0 24px;}
.authority-bullets li{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500;color:var(--text);margin-bottom:12px;}
.authority-bullets li::before{content:"✔";color:var(--gold);font-size:14px;font-weight:700;}
.founder-line{font-size:14px;color:var(--muted);font-style:italic;margin-bottom:20px;}
.authority-badges{display:flex;flex-wrap:wrap;gap:10px;}
.auth-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text);background:#fff;border:1px solid var(--border);padding:8px 14px;border-radius:50px;}
@media(max-width:900px){.authority-wrap{grid-template-columns:1fr;}.authority-img{height:360px;}}

/* ===== RESULTS SECTION ===== */
.results-section{padding:100px 0;background:#fff;}
.results-filters{display:flex;justify-content:center;gap:10px;margin:32px 0 48px;flex-wrap:wrap;}
.filter-btn{padding:9px 22px;border-radius:50px;border:1.5px solid var(--border);background:#fff;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;}
.filter-btn.active,.filter-btn:hover{background:var(--dark);color:#fff;border-color:var(--dark);}
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px;}
.result-card{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
.before-after-slider{position:relative;height:260px;overflow:hidden;cursor:ew-resize;user-select:none;touch-action:none;-webkit-user-select:none;}
.before-after-slider img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top center;}
.slider-after{clip-path:inset(0 0 0 25%);}
.slider-handle{position:absolute;top:0;left:50%;transform:translateX(-50%);width:3px;height:100%;background:#fff;z-index:3;cursor:ew-resize;}
.slider-handle::after{content:'◀ ▶';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--dark);box-shadow:var(--shadow-md);}
.result-card-footer{padding:14px 18px;background:#fff;}
.result-card-footer span{font-size:13px;font-weight:600;color:var(--text);}
.results-trust{text-align:center;margin-bottom:40px;font-size:16px;font-weight:600;color:var(--text);}
.results-trust .stars{color:var(--gold);margin-right:8px;}
.results-cta{text-align:center;}
.results-trust-wrap { display:flex; justify-content:center; align-items:center; gap:16px; margin-top: 60px; margin-bottom: 24px; }
.results-trust-wrap .trust-text { text-align:left; }
@media(max-width:900px){.results-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){
  .results-grid{grid-template-columns:1fr;}
  .results-trust-wrap { flex-direction: column; text-align: center; gap: 12px; }
  .results-trust-wrap .trust-text { text-align: center; }
}

/* ===== PROCESS SECTION ===== */
.process-section{padding:100px 0;background:var(--beige-light);}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:60px;position:relative;}
.process-steps::before{content:'';position:absolute;top:40px;left:calc(12.5%);right:calc(12.5%);height:2px;background:var(--gold);opacity:0.3;z-index:0;}
.step-card{text-align:center;padding:0 20px 20px;position:relative;z-index:1;}
.step-num-wrap{width:80px;height:80px;border-radius:50%;background:#fff;border:3px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;box-shadow:0 8px 24px rgba(201,166,70,0.15);position:relative;z-index:2;}
.step-num{font-family:var(--font-head);font-size:32px;font-weight:800;color:var(--gold);line-height:1;transform:translateY(-4px);display:inline-block;}
.step-icon{font-size:22px;}
.step-card h3{font-size:22px;font-weight:700;color:var(--text);margin-bottom:12px;}
.step-card p{font-size:13px;color:var(--muted);line-height:1.6;}
.process-sim-block{margin-top:60px;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:40px 48px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.sim-text h3{font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px;}
.sim-text p{font-size:15px;color:var(--muted);}
.process-cta-block{margin-top:48px;text-align:center;}
.process-cta-block p{font-size:16px;color:var(--muted);margin-bottom:20px;}
.process-cta-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
@media(max-width:768px){.process-steps{grid-template-columns:1fr 1fr;}.process-steps::before{display:none;}.process-sim-block{flex-direction:column;text-align:center;padding:32px 24px;}}
@media(max-width:480px){.process-steps{grid-template-columns:1fr;}}

/* ===== BENEFITS SECTION ===== */
.benefits-section{padding:100px 0;background:#fff;}
.benefits-hint{font-size:15px;color:var(--muted);font-style:italic;margin-top:-4px;margin-bottom:60px;}
.comparison-wrap { max-width: 900px; margin: 60px auto 0; overflow-x: auto; padding-bottom: 24px; }
.comparison-table { width: 100%; min-width: 600px; border-collapse: separate; border-spacing: 0; margin: 0 auto; }
.comparison-table th, .comparison-table td { padding: 24px 16px; border-bottom: 1px solid var(--border); text-align: center; vertical-align: middle; }
.comparison-table th { font-size: 18px; font-weight: 700; color: var(--text); padding-bottom: 32px; border-bottom: none; }
.comparison-table .feature-col { text-align: left; font-weight: 700; color: var(--text); font-size: 16px; width: 34%; }
.comparison-table .smp-col { background: var(--beige-light); position: relative; }
.comparison-table th.smp-col { border-top-left-radius: 12px; border-top-right-radius: 12px; padding-top: 32px; border-top: 4px solid var(--gold); }
.comparison-table tr:last-child td.smp-col { border-bottom-left-radius: 12px; border-bottom-right-radius: 12px; border-bottom: 4px solid var(--beige-light); }
.comparison-table tr:last-child td { border-bottom: none; }
.icon-check { color: #10b981; }
.icon-cross { color: #ef4444; opacity: 0.5; }
.icon-varies { color: #f59e0b; }

/* ===== PRICING SECTION ===== */
.pricing-section { padding: 100px 0; background: var(--beige-light); }
.pricing-group { margin-bottom: 60px; }
.pricing-group-title { font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 28px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }

/* Hair Treatments — 2 col */
.pricing-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; max-width: 920px; margin-left: auto; margin-right: auto; }
/* Specialized Treatments — 3 col */
.pricing-grid-sm { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* Card base */
.price-card {
  background: #fff;
  border-radius: 16px;
  border: 1.5px solid var(--border);
  position: relative;
  transition: transform .28s, box-shadow .28s;
  display: flex;
  flex-direction: column;
  overflow: hidden; /* critical: clips image to card corners */
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.price-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.13); }
.price-card.popular { border-color: var(--gold); box-shadow: 0 4px 20px rgba(201,166,70,0.18); }
.popular-badge {
  position: absolute; top: 16px; left: 16px; z-index: 10;
  background: var(--gold); color: #fff;
  font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  padding: 5px 14px; border-radius: 50px; white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  display: inline-flex; align-items: center; gap: 4px;
}

/* Image area — edge-to-edge, full bleed */
.price-img-wrap {
  position: relative;
  width: 100%;
  height: 260px;
  overflow: hidden;
  flex-shrink: 0;
  background: #f0ece4;
}
.price-img-wrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  opacity: 0;
  transition: opacity 0.8s ease;
  z-index: 1;
}
.price-img-wrap img.active { opacity: 1; z-index: 2; }

/* Pagination dots overlay */
.price-img-dots {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
  background: rgba(0,0,0,0.28);
  padding: 6px 12px;
  border-radius: 50px;
  backdrop-filter: blur(4px);
}
.price-img-dot {
  width: 20px; height: 4px;
  background: rgba(255,255,255,0.45);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.3s;
}
.price-img-dot.active { background: var(--gold); width: 28px; }

/* Content area */
.price-content {
  padding: 22px 22px 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.price-name { font-size: 17px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.price-desc { font-size: 13px; color: var(--muted); margin-bottom: 14px; line-height: 1.55; }
.price-details-list {
  list-style: none; padding: 0; margin: 0 0 18px;
  display: flex; flex-direction: column; gap: 6px;
}
.price-details-list li {
  font-size: 12.5px; color: var(--text);
  padding-left: 18px;
  position: relative;
  line-height: 1.4;
}
.price-details-list li::before {
  content: '';
  position: absolute; left: 0; top: 6px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
}
.price-divider { height: 1px; background: var(--border); margin: 0 0 16px; }
.price-old { font-size: 13px; color: var(--muted); text-decoration: line-through; margin-bottom: 2px; }
.price-new { font-size: 26px; font-weight: 800; color: var(--text); margin-bottom: 18px; }
.price-new span { font-size: 14px; font-weight: 500; color: var(--muted); }
.price-card .btn-gold { width: 100%; justify-content: center; font-size: 13px; padding: 12px 20px; margin-top: auto; }
.pricing-note { text-align: center; margin-top: 40px; font-size: 14px; color: var(--muted); }
.pricing-note strong { color: var(--gold-dark); }

/* ===== Pricing Card WhatsApp Button ===== */
.price-card-actions { display: flex; flex-direction: column; gap: 10px; margin-top: auto; }
.btn-wa-card {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  width: 100%;
  padding: 13px 20px;
  border-radius: 10px;
  background: linear-gradient(135deg, #25d366 0%, #1aad52 100%);
  color: #fff;
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-decoration: none;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(37,211,102,0.35);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s;
  position: relative;
  overflow: hidden;
}
.btn-wa-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.08);
  opacity: 0;
  transition: opacity 0.2s;
}
.btn-wa-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(37,211,102,0.50); }
.btn-wa-card:hover::before { opacity: 1; }
.btn-wa-card:active { transform: translateY(0); }
.btn-wa-card svg { flex-shrink: 0; }
.btn-wa-secondary {
  display: block; text-align: center;
  font-size: 12px; color: var(--muted);
  text-decoration: none;
  padding: 4px 0;
  transition: color 0.2s;
}
.btn-wa-secondary:hover { color: var(--gold); }

/* Responsive */
@media(max-width:1100px) { .pricing-grid { grid-template-columns: repeat(2,1fr); } .pricing-grid-sm { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px) { .pricing-grid, .pricing-grid-sm { grid-template-columns: 1fr; } .price-img-wrap { height: 220px; } }

/* ===== TESTIMONIALS ===== */
.testimonials-section{padding:100px 0;background:#fff;}
.testimonials-header{display:flex;align-items:center;gap:14px;margin-bottom:8px;}
.testi-avatars{display:flex;}
.testi-avatars{display:flex;align-items:center;}
.testi-avatars img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid #fff;margin-left:-12px;z-index:2;box-shadow:0 2px 6px rgba(0,0,0,0.1);}
.testi-avatars img:first-child{margin-left:0;z-index:3;}
.testi-avatars img:nth-child(2){z-index:2;}
.testi-avatars img:nth-child(3){z-index:1;}
.testi-avatars img:nth-child(4){z-index:0;}
.testi-happy{font-size:15px;font-weight:700;color:var(--text);}
.testimonials-track-wrap{overflow:hidden;margin-top:48px;}
.testimonials-track{display:flex;gap:24px;transition:transform .5s cubic-bezier(.25,.8,.25,1);}
.review-card{flex:0 0 calc(33.333% - 16px);background:var(--beige-light);border:1px solid var(--border);border-radius:var(--r-md);padding:32px 28px;display:flex;flex-direction:column;position:relative;}
.review-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.review-user-info{display:flex;align-items:center;gap:12px;}
.reviewer-avatar{width:46px;height:46px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0;}
.reviewer-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.2;}
.reviewer-city{font-size:12px;color:var(--muted);margin-top:2px;}
.review-platform{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,0.08);border:1px solid var(--border);}
.review-platform img{width:18px;height:18px;object-fit:contain;}
.review-stars{color:var(--gold);font-size:16px;letter-spacing:1.5px;margin-bottom:14px;}
.review-text{font-size:14px;color:var(--text);line-height:1.7;font-style:italic;flex:1;}
.testi-footer{display:flex;flex-direction:column;align-items:center;gap:24px;margin-top:40px;}
.testi-nav{display:flex;justify-content:center;gap:12px;}
.testi-nav button{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--gold);background:transparent;color:var(--gold);font-size:16px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;}
.testi-nav button:hover{background:var(--gold);color:#fff;}
.testi-pagination-wrapper{overflow:hidden;width:88px;margin:0 auto;}
.testi-pagination{display:flex;gap:8px;transition:transform 0.3s ease;width:-moz-max-content;width:max-content;}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:all .3s ease;}
.testi-dot.active{background:var(--gold);width:24px;border-radius:4px;}
.read-more-btn{color:var(--gold);background:none;border:none;font-size:13px;font-weight:700;padding:0;margin-left:4px;cursor:pointer;text-decoration:underline;display:inline;}
.mobile-break{display:none;}
@media(max-width:900px){
  .review-card{flex:0 0 calc(50% - 12px);}
  .testimonials-header{flex-direction:column;align-items:center;text-align:center;}
  .mobile-break{display:block;}
  .section-title{font-size:32px;}
}
@media(max-width:580px){
  .review-card{flex:0 0 calc(85%);}
  .section-title{font-size:28px;}
}

/* ===== FAQ ===== */
.faq-section{padding:100px 0;background:var(--beige-light);}
.faq-list{max-width:760px;margin:48px auto 0;}
.faq-item{
  background:#fff;
  border-radius:var(--r-sm);
  margin-bottom:12px;
  border:1px solid var(--border);
  overflow:hidden;
}
.faq-item summary{
  padding:20px 24px;
  font-size:16px;
  font-weight:600;
  color:var(--text);
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:color .2s;
  /* Touch fixes — critical for mobile */
  min-height:56px;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
  -webkit-user-select:none;
  /* Ensure it's always interactive */
  position:relative;
  z-index:1;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";font-size:22px;color:var(--muted);transition:transform .3s,color .2s;flex-shrink:0;}
.faq-item[open] summary{color:var(--gold);}
.faq-item[open] summary::after{content:"−";color:var(--gold);}
.faq-item p{padding:0 24px 20px;font-size:15px;color:var(--muted);line-height:1.7;}
.faq-item[open] p{animation:faq-open 0.3s ease;}
@keyframes faq-open{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:translateY(0);}}
.faq-cta{text-align:center;margin-top:52px;}
.faq-cta p{font-size:16px;color:var(--muted);margin-bottom:20px;}
.faq-cta-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}

/* ===== FINAL CTA ===== */
.final-cta-section{padding:100px 0;background:#fff;}
.final-cta-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.final-cta-urgency{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--gold-dark);background:var(--gold-light);padding:8px 16px;border-radius:50px;margin-bottom:20px;}
.final-cta-title{font-family:var(--font-head);font-size:40px;font-weight:800;line-height:1.15;color:var(--text);margin-bottom:14px;}
.final-cta-sub{font-size:16px;color:var(--muted);margin-bottom:32px;line-height:1.7;}
.final-contact-list{display:flex;flex-direction:column;gap:12px;margin-bottom:28px;}
.final-contact-item{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text);}
.final-contact-item svg{color:var(--gold);}
.final-pet{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);}
/* Form card */
.form-card{background:var(--beige-light);border:1px solid var(--border);border-radius:var(--r-lg);padding:44px 40px;box-shadow:var(--shadow-sm);}
.form-card h3{font-size:20px;font-weight:700;color:var(--text);margin-bottom:28px;}
.form-group{margin-bottom:16px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px 18px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:16px;/* min 16px prevents iOS auto-zoom */color:var(--text);background:#fff;transition:border-color .2s;-webkit-appearance:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--gold);}
.form-group textarea{resize:none;}
.form-submit{width:100%;padding:16px;font-size:16px;font-weight:700;margin-top:4px;}
.form-note{text-align:center;font-size:12px;color:var(--muted);margin-top:12px;}
@media(max-width:900px){.final-cta-wrap{grid-template-columns:1fr;gap:48px;}.final-cta-title{font-size:32px;}.form-card{padding:32px 24px;}}

/* ===== FOOTER ===== */
.site-footer{background:var(--dark);color:#fff;}
.footer-top{padding:72px 0 48px;}
.footer-inner{max-width:1160px;margin:0 auto;padding:0 40px;}
.footer-top .footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;}
.footer-logo{height:104px;width:auto;margin-bottom:14px;}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:24px;line-height:1.6;}
.footer-contact-list{display:flex;flex-direction:column;gap:10px;}
.footer-contact-item{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,.6);transition:color .2s;}
.footer-contact-item:hover{color:var(--gold);}
.footer-col-title{font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px;}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:14px;color:rgba(255,255,255,.65);transition:color .2s;}
.footer-links a:hover{color:var(--gold);}
.footer-newsletter-sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:14px;line-height:1.5;}
.footer-newsletter{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.footer-newsletter input{padding:12px 16px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.07);color:#fff;font-size:14px;font-family:var(--font-body);}
.footer-newsletter input::placeholder{color:rgba(255,255,255,.4);}
.footer-newsletter input:focus{outline:none;border-color:var(--gold);}
.footer-newsletter button{padding:12px 20px;background:var(--gold);color:#fff;font-size:14px;font-weight:700;border-radius:var(--r-sm);transition:background .2s;}
.footer-newsletter button:hover{background:var(--gold-dark);}
.footer-socials{display:flex;gap:12px;}
.footer-social-link{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all .2s;}
.footer-social-link:hover{border-color:var(--gold);color:var(--gold);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.4);flex-wrap:wrap;gap:10px;}
.footer-hypermesh{color:var(--gold);font-weight:600;transition:color .2s;}
.footer-hypermesh:hover{color:var(--gold-dark);}
@media(max-width:900px){.footer-top .footer-inner{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.footer-top .footer-inner{grid-template-columns:1fr;}}

/* Mobile Spacing Fixes */
@media(max-width:768px){
  .container, .header-inner, .footer-inner { padding: 0 24px; }
}
@media(max-width:480px){
  .container, .header-inner, .footer-inner { padding: 0 20px; }
  .form-card { padding: 24px 20px; }
  .form-group input,
  .form-group select,
  .form-group textarea { font-size: 16px; } /* Prevent iOS zoom */
}

/* ===== COMPREHENSIVE MOBILE TOUCH FIX =====
   Ensures every interactive element receives touches on mobile/tablet.
   Root cause was wa-widget blocking — fixed in footer.php.
   These rules are belt-and-suspenders safety. */
@media(max-width:1024px){
  /* --- Global: no invisible blocks --- */
  *, *::before, *::after { box-sizing: border-box; }

  /* All interactive elements: instant tap, no blue flash */
  a, button, summary,
  input, select, textarea,
  [role="button"], [tabindex] {
    -webkit-tap-highlight-color: transparent !important;
    touch-action: manipulation;
  }

  /* Ensure nothing blocks touches accidentally */
  a, button, summary {
    pointer-events: auto !important;
    position: relative;
    z-index: auto;
  }

  /* --- Mobile menu links & social --- */
  .mobile-menu {
    position: relative;
    z-index: 1100;
  }
  .mobile-link {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 12px 0;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    pointer-events: auto !important;
    cursor: pointer;
  }
  .mobile-socials {
    position: relative;
    z-index: 1100;
  }
  .mobile-social-link {
    width: 48px;
    height: 48px;
    pointer-events: auto !important;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    cursor: pointer;
  }

  /* --- Testimonial nav buttons --- */
  #testi-prev, #testi-next,
  .testi-nav button {
    min-width: 48px;
    min-height: 48px;
    pointer-events: auto !important;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    cursor: pointer;
    position: relative;
    z-index: 5;
  }

  /* --- FAQ: ensure summary always interactive --- */
  .faq-item {
    position: relative;
    z-index: 1;
    pointer-events: auto;
  }
  .faq-item summary {
    min-height: 56px;
    pointer-events: auto !important;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    cursor: pointer;
  }

  /* --- Pricing card buttons --- */
  .btn-wa-card, .btn-wa-secondary {
    pointer-events: auto !important;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
  }

  /* --- Before/after slider --- */
  .before-after-slider {
    touch-action: none;
    pointer-events: auto;
  }

  /* --- Filter buttons --- */
  .filter-btn {
    min-height: 44px;
    pointer-events: auto;
    touch-action: manipulation;
  }

  /* --- Smooth scroll on overflow containers --- */
  /* --- Smooth scroll on overflow containers --- */
  .testimonials-track-wrap {
    -webkit-overflow-scrolling: touch;
    overflow-x: hidden;
  }

  /* --- Make comparison table fit without dragging --- */
  .comparison-wrap {
    overflow-x: visible;
  }
  .comparison-table {
    min-width: 0;
  }
  .comparison-table th, .comparison-table td {
    padding: 12px 4px;
    font-size: 11px;
  }
  .comparison-table th {
    font-size: 12px;
    padding-bottom: 12px;
  }
  .comparison-table .feature-col {
    font-size: 11px;
    width: 28%;
  }
  .comparison-table th.smp-col {
    padding-top: 12px;
  }
  .comparison-table svg {
    width: 20px;
    height: 20px;
  }

  /* --- Pagination & Dots Mobile Touch Targets --- */
  .price-img-dot, .sol-dot, .testi-dot, .swiper-pagination-bullet {
    pointer-events: auto !important;
    cursor: pointer;
    touch-action: manipulation;
    position: relative;
  }
  .price-img-dot::after, .sol-dot::after, .testi-dot::after, .swiper-pagination-bullet::after {
    content: '';
    position: absolute;
    top: -12px;
    left: -12px;
    right: -12px;
    bottom: -12px;
  }

  /* --- Footer links & social touch targets (mobile only) --- */
  .footer-social-link {
    width: 44px;
    height: 44px;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    pointer-events: auto !important;
  }
  .footer-links a {
    display: block;
    padding: 6px 0; /* increases tap area without changing visual width */
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    pointer-events: auto !important;
  }
  .footer-contact-item {
    min-height: 44px;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    pointer-events: auto !important;
  }

  /* --- Footer bottom links --- */
  .footer-bottom-inner a {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    padding: 8px 4px;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    pointer-events: auto !important;
  }

  /* --- Read more buttons --- */
  .read-more-btn {
    min-height: 32px;
    padding: 4px 8px;
    pointer-events: auto !important;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }
}

/* ============================================================
   LEGAL PAGES — page.php template
   ============================================================ */
.legal-main { min-height: 100vh; background: #f8f7f4; }

/* Hero */
.legal-hero {
  position: relative;
  background: var(--dark2);
  padding: 140px 0 90px;
  overflow: hidden;
}
.legal-hero-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 60%, rgba(201,166,70,0.12) 0%, transparent 65%),
              radial-gradient(ellipse at 80% 20%, rgba(201,166,70,0.07) 0%, transparent 55%);
  pointer-events: none;
}
.legal-hero::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.legal-hero-inner {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 32px;
  position: relative;
  z-index: 1;
}
.legal-back-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--gold);
  font-size: 13px; font-weight: 600; letter-spacing: .3px;
  text-transform: uppercase;
  margin-bottom: 28px;
  opacity: .85;
  transition: opacity .2s;
}
.legal-back-link:hover { opacity: 1; }
.legal-hero-title {
  font-family: var(--font-head);
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 18px;
}
.legal-hero-meta {
  color: rgba(255,255,255,.45);
  font-size: 13.5px;
  letter-spacing: .2px;
}
.legal-hero-meta time { color: var(--gold); font-weight: 600; }
.legal-hero-wave {
  position: absolute; bottom: 0; left: 0; right: 0; line-height: 0;
}
.legal-hero-wave svg { width: 100%; height: 60px; }

/* Content Section */
.legal-content-section {
  padding: 72px 32px 100px;
}
.legal-content-wrap {
  max-width: 860px;
  margin: 0 auto;
}

/* Content Card */
.legal-content-body {
  background: #fff;
  border-radius: 18px;
  padding: 56px 64px;
  box-shadow: 0 4px 40px rgba(0,0,0,.07);
  border: 1px solid var(--border);
  margin-bottom: 40px;
}

/* Prose typography for WP content */
.legal-content-body h2 {
  font-family: var(--font-head);
  font-size: 1.55rem;
  font-weight: 700;
  color: var(--dark);
  margin: 44px 0 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--gold-light);
}
.legal-content-body h2:first-child { margin-top: 0; }
.legal-content-body h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--dark);
  margin: 28px 0 10px;
}
.legal-content-body p {
  font-size: 15.5px;
  line-height: 1.78;
  color: #374151;
  margin-bottom: 16px;
}
.legal-content-body ul, .legal-content-body ol {
  padding-left: 24px;
  margin-bottom: 18px;
}
.legal-content-body ul { list-style: disc; }
.legal-content-body ol { list-style: decimal; }
.legal-content-body li {
  font-size: 15.5px;
  line-height: 1.75;
  color: #374151;
  margin-bottom: 8px;
}
.legal-content-body strong { color: var(--dark); font-weight: 700; }
.legal-content-body a { color: var(--gold-dark); text-decoration: underline; }
.legal-content-body a:hover { color: var(--gold); }

/* Highlight boxes inside content */
.legal-highlight {
  background: var(--beige-light);
  border-left: 4px solid var(--gold);
  border-radius: 0 10px 10px 0;
  padding: 16px 20px;
  margin: 24px 0;
  font-size: 14.5px;
  color: #4b5563;
  line-height: 1.7;
}

/* Contact CTA box */
.legal-contact-box {
  background: var(--dark2);
  border-radius: 18px;
  padding: 44px 56px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.legal-contact-box::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.legal-contact-box h3 {
  font-family: var(--font-head);
  font-size: 1.6rem;
  color: #fff;
  margin-bottom: 12px;
}
.legal-contact-box p {
  color: rgba(255,255,255,.6);
  font-size: 15px;
  max-width: 480px;
  margin: 0 auto 28px;
  line-height: 1.7;
}
.legal-contact-btn {
  display: inline-block;
  background: var(--gold);
  color: #fff;
  font-weight: 700;
  font-size: 14.5px;
  padding: 14px 36px;
  border-radius: 8px;
  transition: background .2s, transform .2s;
  letter-spacing: .3px;
}
.legal-contact-btn:hover {
  background: var(--gold-dark);
  transform: translateY(-2px);
}

/* Responsive */
@media(max-width: 768px) {
  .legal-hero { padding: 120px 0 70px; }
  .legal-content-body { padding: 36px 28px; }
  .legal-contact-box { padding: 36px 28px; }
  .legal-content-section { padding: 48px 20px 72px; }
}
@media(max-width: 480px) {
  .legal-hero { padding: 110px 0 60px; }
  .legal-hero-inner { padding: 0 20px; }
  .legal-content-body { padding: 28px 20px; }
  .legal-contact-box { padding: 28px 20px; }
  .legal-content-body h2 { font-size: 1.25rem; }
}
