/*
Theme Name: Kamer Web Studio
Theme URI: https://kamerwebstudio.com
Author: Kamer Web Studio
Author URI: https://kamerwebstudio.com
Description: Official theme for Kamer Web Studio — Become a Digital Landlord. Built for Cameroonian businesses. Fully customizable via WordPress Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kamerwebstudio
Tags: business, dark, gold, agency, cameroon, one-page
*/

/* ─── CSS CUSTOM PROPERTIES (controlled by Customizer) ─── */
:root {
  --kws-black:       #08080a;
  --kws-deep:        #0e0e12;
  --kws-card:        #13131a;
  --kws-gold:        #c9a84c;
  --kws-gold-light:  #e6c96e;
  --kws-cream:       #f4ede0;
  --kws-muted:       rgba(244,237,224,0.5);
  --kws-dim:         rgba(244,237,224,0.25);
  --kws-green:       #2d6a4f;
  --kws-green2:      #40916c;
  --kws-red:         #c44b2a;
  --kws-border:      rgba(201,168,76,0.18);
  --kws-nav-h:       70px;
  --kws-font-heading:'Syne', sans-serif;
  --kws-font-display:'Fraunces', serif;
  --kws-font-body:   'DM Sans', sans-serif;
  --kws-radius:      8px;
}

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--kws-black);
  color: var(--kws-cream);
  font-family: var(--kws-font-body);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
ul { list-style:none; }

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background: var(--kws-black); }
::-webkit-scrollbar-thumb { background: var(--kws-gold); border-radius:2px; }

/* ─── NOISE TEXTURE ─── */
body::before {
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none; z-index:1000; opacity:0.35;
}

/* ─── NAV ─── */
#kws-nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  height: var(--kws-nav-h);
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 5%;
  border-bottom: 1px solid transparent;
  transition: background 0.4s, border-color 0.4s;
}
#kws-nav.scrolled {
  background: rgba(8,8,10,0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-color: var(--kws-border);
}
.kws-logo {
  font-family: var(--kws-font-heading);
  font-weight: 800;
  font-size: 1.1rem;
  letter-spacing: -0.02em;
  display:flex; align-items:center; gap:0.5rem;
}
.kws-logo .logo-key {
  width:28px; height:28px;
  background: var(--kws-gold);
  border-radius:4px;
  display:grid; place-items:center;
  font-size:0.85rem;
  color: var(--kws-black);
}
.kws-logo .logo-accent { color: var(--kws-gold); }
.kws-nav-links { display:flex; align-items:center; gap:2rem; }
.kws-nav-links a {
  font-size:0.8rem; letter-spacing:0.05em;
  color: var(--kws-muted); transition: color 0.2s;
}
.kws-nav-links a:hover { color: var(--kws-cream); }
.kws-btn-nav {
  background: var(--kws-gold);
  color: var(--kws-black);
  font-family: var(--kws-font-heading);
  font-weight:700; font-size:0.75rem;
  letter-spacing:0.05em;
  padding: 0.55rem 1.2rem;
  border-radius: var(--kws-radius);
  transition: background 0.2s, transform 0.2s;
}
.kws-btn-nav:hover { background: var(--kws-gold-light); transform: translateY(-1px); }
.kws-burger { display:none; flex-direction:column; gap:5px; padding:4px; }
.kws-burger span { display:block; width:22px; height:2px; background: var(--kws-cream); border-radius:2px; transition:0.3s; }
.kws-mobile-menu {
  display:none; position:fixed;
  top: var(--kws-nav-h); left:0; right:0;
  background: rgba(8,8,10,0.98);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--kws-border);
  padding: 2rem 5%;
  flex-direction:column; gap:1.5rem;
  z-index:899;
}
.kws-mobile-menu.open { display:flex; }
.kws-mobile-menu a {
  font-size:1rem; color: var(--kws-muted);
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--kws-border);
}

/* ─── BUTTONS ─── */
.kws-btn-primary {
  display:inline-block;
  background: var(--kws-gold);
  color: var(--kws-black);
  font-family: var(--kws-font-heading);
  font-weight:700; font-size:0.85rem;
  letter-spacing:0.04em;
  padding: 0.9rem 2rem;
  border-radius: var(--kws-radius);
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  cursor: pointer;
}
.kws-btn-primary:hover {
  background: var(--kws-gold-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(201,168,76,0.25);
}
.kws-btn-ghost {
  display:inline-block;
  border: 1px solid var(--kws-border);
  color: var(--kws-cream);
  font-size:0.85rem;
  padding: 0.9rem 2rem;
  border-radius: var(--kws-radius);
  transition: border-color 0.2s, background 0.2s;
}
.kws-btn-ghost:hover { border-color: var(--kws-gold); background: rgba(201,168,76,0.05); }

/* ─── SECTION SHARED ─── */
.kws-section { padding: 7rem 5%; }
.kws-wrap { max-width:1100px; margin:0 auto; }
.kws-label {
  font-size:0.6rem; letter-spacing:0.25em; text-transform:uppercase;
  color: var(--kws-gold); margin-bottom:1rem;
  display:flex; align-items:center; gap:1rem;
}
.kws-label::after { content:''; flex:1; height:1px; background: var(--kws-border); }
.kws-title {
  font-family: var(--kws-font-heading);
  font-size: clamp(2rem,4vw,3.2rem);
  font-weight:800; line-height:1.05;
  letter-spacing:-0.025em;
  margin-bottom:1.2rem;
}
.kws-title em {
  font-family: var(--kws-font-display);
  font-style:italic; font-weight:300;
  color: var(--kws-gold);
}
.kws-sub { font-size:0.95rem; color: var(--kws-muted); line-height:1.75; max-width:520px; }

/* ─── HERO ─── */
.kws-hero {
  min-height:100vh;
  display:flex; align-items:center;
  padding: calc(var(--kws-nav-h) + 4rem) 5% 5rem;
  position:relative; overflow:hidden;
}
.kws-hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 70% at 70% 50%, rgba(201,168,76,0.07) 0%,transparent 60%),
    radial-gradient(ellipse 40% 50% at 10% 80%, rgba(45,106,79,0.08) 0%,transparent 50%),
    radial-gradient(ellipse 50% 40% at 90% 10%, rgba(196,75,42,0.05) 0%,transparent 50%);
}
.kws-hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(201,168,76,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,0.04) 1px,transparent 1px);
  background-size: 80px 80px;
}
.kws-hero-inner {
  position:relative; z-index:2;
  max-width:1100px; margin:0 auto; width:100%;
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center;
}
.kws-hero-badge {
  display:inline-flex; align-items:center; gap:0.5rem;
  border: 1px solid var(--kws-border);
  background: rgba(201,168,76,0.06);
  font-size:0.65rem; letter-spacing:0.2em; text-transform:uppercase;
  color: var(--kws-gold); padding: 0.35rem 0.9rem;
  border-radius:100px; margin-bottom:2rem;
}
.kws-hero-title {
  font-family: var(--kws-font-heading);
  font-size: clamp(2.8rem,5.5vw,5.2rem);
  font-weight:800; line-height:0.95;
  letter-spacing:-0.03em; margin-bottom:1.5rem;
}
.kws-hero-title .accent {
  font-family: var(--kws-font-display);
  font-style:italic; font-weight:300;
  color: var(--kws-gold);
}
.kws-hero-sub {
  font-size:1rem; color: var(--kws-muted);
  line-height:1.75; max-width:420px; margin-bottom:2.5rem;
}
.kws-hero-actions { display:flex; gap:1rem; align-items:center; flex-wrap:wrap; }
.kws-hero-stats {
  display:flex; gap:2.5rem; margin-top:3rem;
  padding-top:2rem; border-top:1px solid var(--kws-border);
}
.kws-stat-num {
  font-family: var(--kws-font-heading);
  font-size:2rem; font-weight:800;
  color: var(--kws-gold); line-height:1;
}
.kws-stat-label { font-size:0.7rem; color: var(--kws-muted); letter-spacing:0.05em; margin-top:0.3rem; }

/* hero right card */
.kws-hero-card {
  background: var(--kws-card);
  border: 1px solid var(--kws-border);
  border-radius:16px; padding:2.5rem;
  position:relative; overflow:hidden;
}
.kws-hero-card::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:200px; height:200px;
  background: radial-gradient(circle,rgba(201,168,76,0.15),transparent 70%);
  border-radius:50%;
}
.kws-card-tag {
  font-size:0.6rem; letter-spacing:0.2em; text-transform:uppercase;
  color: var(--kws-gold); margin-bottom:1.2rem; display:block;
}
.kws-card-title {
  font-family: var(--kws-font-heading);
  font-size:1.4rem; font-weight:700;
  margin-bottom:1.5rem; line-height:1.2;
}
.kws-service-list { display:flex; flex-direction:column; gap:0.8rem; }
.kws-service-item {
  display:flex; align-items:center; gap:0.9rem;
  padding: 0.8rem 1rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: var(--kws-radius);
  transition: border-color 0.2s, background 0.2s;
}
.kws-service-item:hover { border-color: var(--kws-border); background: rgba(201,168,76,0.04); }
.kws-service-icon {
  width:36px; height:36px; border-radius: var(--kws-radius);
  display:grid; place-items:center;
  font-size:1rem; flex-shrink:0;
}
.kws-service-name { font-size:0.82rem; font-weight:500; }
.kws-service-sub { font-size:0.65rem; color: var(--kws-muted); }
.kws-floating-badge {
  position:absolute; bottom:-20px; left:-20px;
  background: var(--kws-green);
  border: 1px solid rgba(64,145,108,0.4);
  border-radius:12px; padding:1rem 1.2rem;
  display:flex; align-items:center; gap:0.7rem;
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}
.kws-fb-dot { width:8px; height:8px; border-radius:50%; background:#4ade80; box-shadow:0 0 8px #4ade80; }
.kws-fb-text { font-size:0.72rem; font-weight:500; }
.kws-fb-sub { font-size:0.58rem; color:rgba(244,237,224,0.6); }

/* ─── MARQUEE ─── */
.kws-marquee { background: var(--kws-gold); padding:0.9rem 0; overflow:hidden; }
.kws-marquee-track {
  display:flex; gap:3rem;
  animation: kwsMarquee 22s linear infinite;
  white-space:nowrap; width:max-content;
}
.kws-marquee-item {
  font-family: var(--kws-font-heading);
  font-weight:700; font-size:0.75rem;
  letter-spacing:0.1em; text-transform:uppercase;
  color: var(--kws-black);
  display:flex; align-items:center; gap:1rem;
}
.kws-marquee-item::after { content:'◆'; font-size:0.5rem; opacity:0.5; }
@keyframes kwsMarquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ─── SERVICES ─── */
.kws-services { background: var(--kws-deep); }
.kws-services-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.5rem; margin-top:4rem;
}
.kws-srv-card {
  background: var(--kws-card);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius:12px; padding:2rem;
  position:relative; overflow:hidden;
  transition: border-color 0.3s, transform 0.3s;
}
.kws-srv-card:hover { border-color: var(--kws-border); transform: translateY(-4px); }
.kws-srv-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background: linear-gradient(to right,var(--kws-gold),transparent);
  transform: scaleX(0); transform-origin:left;
  transition: transform 0.4s;
}
.kws-srv-card:hover::after { transform: scaleX(1); }
.kws-srv-num { font-size:0.6rem; letter-spacing:0.2em; color: var(--kws-gold); margin-bottom:1.2rem; }
.kws-srv-icon { font-size:2rem; margin-bottom:1rem; }
.kws-srv-name { font-family: var(--kws-font-heading); font-size:1.1rem; font-weight:700; margin-bottom:0.6rem; }
.kws-srv-desc { font-size:0.8rem; color: var(--kws-muted); line-height:1.7; }
.kws-srv-tags { display:flex; flex-wrap:wrap; gap:0.4rem; margin-top:1.2rem; }
.kws-srv-tag {
  font-size:0.58rem; letter-spacing:0.08em; text-transform:uppercase;
  border: 1px solid var(--kws-border); color: var(--kws-gold);
  padding: 0.2rem 0.5rem; border-radius:3px;
}

/* ─── WHY ─── */
.kws-why-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center; margin-top:4rem;
}
.kws-why-points { display:flex; flex-direction:column; gap:1.5rem; }
.kws-why-point {
  display:flex; gap:1.2rem; align-items:flex-start;
  padding:1.5rem; border: 1px solid rgba(255,255,255,0.04);
  border-radius:10px; background: var(--kws-card);
  transition: border-color 0.3s;
}
.kws-why-point:hover { border-color: var(--kws-border); }
.kws-why-icon {
  width:44px; height:44px; border-radius:10px;
  background: rgba(201,168,76,0.1);
  display:grid; place-items:center; font-size:1.2rem; flex-shrink:0;
}
.kws-why-title { font-family: var(--kws-font-heading); font-size:0.9rem; font-weight:700; margin-bottom:0.3rem; }
.kws-why-desc { font-size:0.78rem; color: var(--kws-muted); line-height:1.7; }
.kws-why-visual {
  background: var(--kws-card); border: 1px solid var(--kws-border);
  border-radius:16px; padding:2.5rem;
}
.kws-why-visual-label { font-size:0.6rem; letter-spacing:0.2em; text-transform:uppercase; color: var(--kws-gold); margin-bottom:0.8rem; }
.kws-why-visual-title {
  font-family: var(--kws-font-heading); font-size:1.5rem; font-weight:800;
  line-height:1.2; margin-bottom:1.5rem;
}
.kws-why-visual-title em { font-family: var(--kws-font-display); font-style:italic; font-weight:300; color: var(--kws-gold); }
.kws-comparison { display:flex; flex-direction:column; gap:0.7rem; }
.kws-cmp-row {
  display:flex; align-items:center; gap:0.8rem;
  padding: 0.8rem 1rem; border-radius: var(--kws-radius);
  font-size:0.78rem;
}
.kws-cmp-bad { background:rgba(196,75,42,0.08); border:1px solid rgba(196,75,42,0.2); }
.kws-cmp-good { background:rgba(45,106,79,0.1); border:1px solid rgba(64,145,108,0.25); }
.kws-cmp-bad .kws-cmp-icon { color: var(--kws-red); }
.kws-cmp-good .kws-cmp-icon { color:#4ade80; }
.kws-cmp-text { color: var(--kws-muted); }
.kws-cmp-text strong { color: var(--kws-cream); font-weight:500; }

/* ─── PROCESS ─── */
.kws-process { background: var(--kws-deep); }
.kws-process-steps {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1px; background: var(--kws-border);
  border: 1px solid var(--kws-border);
  border-radius:12px; overflow:hidden; margin-top:4rem;
}
.kws-step { background: var(--kws-card); padding:2.5rem 2rem; transition: background 0.3s; }
.kws-step:hover { background:#1a1a22; }
.kws-step-num { font-family: var(--kws-font-heading); font-size:3rem; font-weight:800; color:rgba(201,168,76,0.12); line-height:1; margin-bottom:1rem; }
.kws-step-icon { font-size:1.5rem; margin-bottom:0.8rem; }
.kws-step-title { font-family: var(--kws-font-heading); font-size:1rem; font-weight:700; margin-bottom:0.5rem; }
.kws-step-desc { font-size:0.78rem; color: var(--kws-muted); line-height:1.7; }

/* ─── TESTIMONIALS ─── */
.kws-testi-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem; margin-top:4rem;
}
.kws-testi-card {
  background: var(--kws-card); border: 1px solid rgba(255,255,255,0.05);
  border-radius:12px; padding:2rem; transition: border-color 0.3s;
}
.kws-testi-card:hover { border-color: var(--kws-border); }
.kws-testi-stars { color: var(--kws-gold); font-size:0.8rem; margin-bottom:1rem; letter-spacing:0.1em; }
.kws-testi-quote { font-family: var(--kws-font-display); font-style:italic; font-size:1rem; line-height:1.7; color:rgba(244,237,224,0.85); margin-bottom:1.5rem; }
.kws-testi-author { display:flex; align-items:center; gap:0.8rem; }
.kws-testi-avatar {
  width:40px; height:40px; border-radius:50%;
  display:grid; place-items:center;
  font-family: var(--kws-font-heading); font-weight:700; font-size:0.9rem;
  background: rgba(201,168,76,0.15); color: var(--kws-gold); flex-shrink:0;
}
.kws-testi-name { font-size:0.82rem; font-weight:500; }
.kws-testi-biz { font-size:0.68rem; color: var(--kws-muted); }

/* ─── LOCAL SECTION ─── */
.kws-local { background: var(--kws-deep); }
.kws-local-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-top:4rem; }
.kws-local-map { background: var(--kws-card); border: 1px solid var(--kws-border); border-radius:16px; padding:2.5rem; }
.kws-map-title { font-family: var(--kws-font-heading); font-size:1rem; font-weight:700; margin-bottom:1rem; }
.kws-location-items { display:flex; flex-direction:column; gap:0.7rem; }
.kws-loc-item {
  display:flex; align-items:center; gap:0.8rem;
  padding: 0.7rem 1rem;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: var(--kws-radius); font-size:0.8rem;
}
.kws-loc-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.kws-loc-note {
  margin-top:1.5rem; padding:1rem;
  background: rgba(201,168,76,0.06);
  border: 1px solid var(--kws-border);
  border-radius: var(--kws-radius);
  font-size:0.75rem; color: var(--kws-muted); line-height:1.7;
}
.kws-local-points { display:flex; flex-direction:column; gap:1.2rem; }
.kws-lp-item { display:flex; gap:1rem; padding:1.2rem; border-left:2px solid var(--kws-border); transition: border-color 0.3s; }
.kws-lp-item:hover { border-color: var(--kws-gold); }
.kws-lp-icon { font-size:1.3rem; flex-shrink:0; margin-top:0.1rem; }
.kws-lp-title { font-family: var(--kws-font-heading); font-size:0.88rem; font-weight:700; margin-bottom:0.3rem; }
.kws-lp-desc { font-size:0.75rem; color: var(--kws-muted); line-height:1.7; }

/* ─── CTA ─── */
.kws-cta {
  background: linear-gradient(135deg,var(--kws-deep) 0%,rgba(45,106,79,0.08) 50%,var(--kws-deep) 100%);
  text-align:center; position:relative; overflow:hidden;
}
.kws-cta::before {
  content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:600px; height:600px;
  background: radial-gradient(circle,rgba(201,168,76,0.06) 0%,transparent 70%);
  border-radius:50%;
}
.kws-cta-inner { position:relative; z-index:2; max-width:700px; margin:0 auto; }
.kws-cta-title {
  font-family: var(--kws-font-heading);
  font-size: clamp(2.2rem,5vw,4rem);
  font-weight:800; line-height:1.05;
  letter-spacing:-0.03em; margin-bottom:1.5rem;
}
.kws-cta-title em { font-family: var(--kws-font-display); font-style:italic; font-weight:300; color: var(--kws-gold); }
.kws-cta-sub { font-size:1rem; color: var(--kws-muted); line-height:1.75; margin-bottom:3rem; }
.kws-cta-form { display:flex; gap:0.8rem; max-width:480px; margin:0 auto; }
.kws-cta-input {
  flex:1; background: rgba(255,255,255,0.05);
  border: 1px solid var(--kws-border); border-radius: var(--kws-radius);
  padding: 0.9rem 1.2rem; color: var(--kws-cream);
  font-family: var(--kws-font-body); font-size:0.9rem;
  outline:none; transition: border-color 0.2s;
}
.kws-cta-input::placeholder { color: var(--kws-muted); }
.kws-cta-input:focus { border-color: var(--kws-gold); }
.kws-cta-note { font-size:0.7rem; color: var(--kws-dim); margin-top:1rem; }
.kws-cta-channels { display:flex; justify-content:center; gap:1.5rem; margin-top:2.5rem; flex-wrap:wrap; }
.kws-chan {
  display:flex; align-items:center; gap:0.5rem;
  font-size:0.75rem; color: var(--kws-muted);
  padding: 0.5rem 1rem;
  border: 1px solid var(--kws-border);
  border-radius:100px; transition: border-color 0.2s, color 0.2s;
}
.kws-chan:hover { border-color: var(--kws-gold); color: var(--kws-cream); }

/* ─── FOOTER ─── */
.kws-footer {
  background: var(--kws-black);
  border-top: 1px solid var(--kws-border);
  padding: 4rem 5% 2rem;
}
.kws-footer-grid {
  max-width:1100px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem; margin-bottom:3rem;
}
.kws-footer-brand p { font-size:0.8rem; color: var(--kws-muted); line-height:1.7; margin-top:0.8rem; max-width:280px; }
.kws-footer-col h4 {
  font-family: var(--kws-font-heading);
  font-size:0.75rem; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  color: var(--kws-gold); margin-bottom:1.2rem;
}
.kws-footer-col ul { display:flex; flex-direction:column; gap:0.6rem; }
.kws-footer-col ul a { font-size:0.78rem; color: var(--kws-muted); transition: color 0.2s; }
.kws-footer-col ul a:hover { color: var(--kws-cream); }
.kws-footer-bottom {
  max-width:1100px; margin:0 auto;
  padding-top:2rem; border-top:1px solid rgba(255,255,255,0.05);
  display:flex; justify-content:space-between; align-items:center;
  font-size:0.7rem; color: var(--kws-dim); flex-wrap:wrap; gap:1rem;
}
.kws-footer-bottom span { color: var(--kws-gold); }

/* ─── SCROLL REVEAL ─── */
.kws-reveal { opacity:0; transform:translateY(28px); transition: opacity 0.7s ease, transform 0.7s ease; }
.kws-reveal.in { opacity:1; transform:translateY(0); }

/* ─── RESPONSIVE ─── */
@media(max-width:1024px) {
  .kws-hero-inner { grid-template-columns:1fr; gap:3rem; }
  .kws-hero-card-wrap { display:none; }
  .kws-why-grid, .kws-local-grid { grid-template-columns:1fr; gap:2.5rem; }
  .kws-footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .kws-nav-links, .kws-btn-nav { display:none; }
  .kws-burger { display:flex; }
}
@media(max-width:600px) {
  .kws-section { padding:5rem 5%; }
  .kws-hero { padding:calc(var(--kws-nav-h) + 3rem) 5% 3rem; }
  .kws-hero-stats { flex-wrap:wrap; gap:1.5rem; }
  .kws-cta-form { flex-direction:column; }
  .kws-footer-grid { grid-template-columns:1fr; }
  .kws-process-steps { grid-template-columns:1fr; }
}

/* ─── WORDPRESS ADMIN BAR OFFSET ─── */
.admin-bar #kws-nav { top:32px; }
@media screen and (max-width:782px) {
  .admin-bar #kws-nav { top:46px; }
}
