/* ═══════════════════════════════════════════════════════════
   Lothian Ear Care — Theme CSS
   Scope: global tokens, header, footer, cookie banner, WhatsApp
   Page content is handled by Elementor
   ═══════════════════════════════════════════════════════════ */

/* ── Design Tokens — available as custom CSS vars in Elementor ── */
:root {
  --c-navy:        #1a3a5c;
  --c-blue-deep:   #003f8a;
  --c-blue:        #005eb8;
  --c-amber:       #e8a020;
  --c-amber-dark:  #c8780a;
  --c-white:       #ffffff;
  --c-surface-1:   #f4f8fc;
  --c-surface-2:   #f0f5f9;
  --c-surface-warm:#f8f9fa;
  --c-border:      rgba(26, 58, 92, .10);
  --c-text:        #2a435a;
  --c-text-head:   #1a3a5c;
  --c-text-muted:  #5c7a92;
  --f-serif:       'Libre Baskerville', Georgia, serif;
  --f-sans:        'Barlow', system-ui, sans-serif;
  --sp-1: 8px;  --sp-2: 16px; --sp-3: 24px; --sp-4: 32px;
  --sp-5: 40px; --sp-6: 48px; --sp-8: 64px; --sp-11: 88px; --sp-14: 112px;
  --r-sm: 6px;  --r-md: 10px; --r-lg: 14px; --r-pill: 999px;
  --sh-sm:    0 1px 3px rgba(26,58,92,.07), 0 1px 2px rgba(26,58,92,.05);
  --sh-md:    0 4px 14px rgba(26,58,92,.09), 0 2px 5px rgba(26,58,92,.06);
  --sh-lg:    0 10px 32px rgba(26,58,92,.12), 0 3px 8px rgba(26,58,92,.07);
  --sh-amber: 0 4px 20px rgba(232,160,32,.38);
  --sh-amber-hover: 0 8px 28px rgba(232,160,32,.55);
  --ease-out:    cubic-bezier(.25, .46, .45, .94);
  --ease-spring: cubic-bezier(.22, 1, .36, 1);
}

/* ════════════════════════════════════════
   RESET & BASE
   ════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--f-sans);
  font-size: 16px;
  line-height: 1.65;
  color: var(--c-text);
  background: var(--c-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  border-left: 16px solid #fff;
  border-right: 16px solid #fff;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

:focus-visible {
  outline: 3px solid var(--c-amber);
  outline-offset: 3px;
  border-radius: var(--r-sm);
}

.hidden { display: none !important; }

/* ════════════════════════════════════════
   NAVIGATION
   ════════════════════════════════════════ */
.site-header {
  position: fixed;
  top: 0; left: 16px; right: 16px;
  border-top: 16px solid #ffffff;
  z-index: 1000;
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--c-border);
  transition: box-shadow 200ms var(--ease-out);
}
.site-header.scrolled {
  box-shadow: 0 2px 20px rgba(26, 58, 92, .10);
}

.nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--sp-4);
  height: 66px;
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.site-logo { display: flex; align-items: center; flex-shrink: 0; }
.site-logo img { height: 36px; width: auto; display: block; }

.nav-links { display: flex; gap: var(--sp-4); margin-left: auto; }
.nav-links a {
  font-size: 14px;
  font-weight: 500;
  color: var(--c-text);
  padding: 4px 0;
  border-bottom: 2px solid transparent;
  transition: color 160ms var(--ease-out), border-color 160ms var(--ease-out);
}
.nav-links a:hover { color: var(--c-navy); border-bottom-color: var(--c-amber); }

.nav-cta {
  display: inline-block;
  background: var(--c-amber);
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  padding: 9px 20px;
  border-radius: var(--r-md);
  margin-left: var(--sp-2);
  transition: background 160ms var(--ease-out), transform 160ms var(--ease-out);
}
.nav-cta:hover { background: var(--c-amber-dark); transform: translateY(-1px); color: #fff; }

.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 4px;
  margin-left: auto;
}
.nav-hamburger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--c-navy);
  border-radius: 2px;
  transition: transform 220ms var(--ease-out), opacity 220ms var(--ease-out);
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.nav-mobile-drawer {
  display: none;
  flex-direction: column;
  background: var(--c-white);
  border-top: 1px solid var(--c-border);
  padding: var(--sp-2) var(--sp-4) var(--sp-4);
}
.nav-mobile-drawer.open { display: flex; }
.nav-mobile-drawer a {
  font-size: 16px;
  font-weight: 500;
  color: var(--c-text);
  padding: 14px 0;
  border-bottom: 1px solid var(--c-border);
}
.nav-mobile-drawer .nav-cta { margin-top: var(--sp-3); width: 100%; text-align: center; display: block; }

/* Elementor page content offset — clears sticky nav */
.elementor-page-main { padding-top: 82px; }

/* ════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════ */
.site-footer {
  background: var(--c-surface-warm);
  color: var(--c-text-muted);
  padding: var(--sp-8) 0 0;
  font-family: var(--f-sans);
  border-top: 1px solid var(--c-border);
  border-bottom: 16px solid #ffffff;
}

.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--sp-4) var(--sp-6);
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--sp-5);
}

.footer-col { display: flex; flex-direction: column; gap: 7px; font-size: 13.5px; }
.footer-col strong {
  color: var(--c-navy);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.footer-logo-img { height: 30px; width: auto; margin-bottom: var(--sp-2); }
.footer-col span { color: var(--c-text-muted); }
.footer-col a { color: var(--c-text-muted); transition: color 150ms var(--ease-out); }
.footer-col a:hover { color: var(--c-navy); }
.footer-cta {
  display: inline-block;
  background: var(--c-amber);
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  padding: 9px 18px;
  border-radius: var(--r-md);
  margin-top: var(--sp-1);
  align-self: flex-start;
  transition: background 160ms var(--ease-out);
}
.footer-cta:hover { background: var(--c-amber-dark); color: #fff; }

.footer-base {
  border-top: 1px solid var(--c-border);
  padding: var(--sp-2) var(--sp-4);
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--c-text-muted);
  flex-wrap: wrap;
  gap: var(--sp-1);
}
.footer-base a { color: var(--c-text-muted); }
.footer-base a:hover { color: var(--c-navy); }

/* ════════════════════════════════════════
   COOKIE CONSENT BANNER
   ════════════════════════════════════════ */
#cookie-banner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9999;
  background: #fff;
  border-top: 3px solid var(--c-amber);
  box-shadow: 0 -4px 24px rgba(26,58,92,.12);
  transform: translateY(100%);
  transition: transform 340ms var(--ease-spring);
  font-family: var(--f-sans);
}
#cookie-banner.cb-visible { transform: translateY(0); }

.cb-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.cb-text { flex: 1; font-size: 14px; color: var(--c-text); line-height: 1.6; min-width: 240px; }
.cb-text strong { color: var(--c-navy); }
.cb-link { color: var(--c-blue); text-decoration: underline; }
.cb-actions { display: flex; gap: var(--sp-1); flex-shrink: 0; }
.cb-btn {
  border: none; border-radius: var(--r-md); padding: 10px 20px;
  font-family: var(--f-sans); font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background 150ms var(--ease-out), transform 150ms var(--ease-out);
}
.cb-btn:hover { transform: translateY(-1px); }
.cb-accept  { background: var(--c-amber); color: #fff; }
.cb-accept:hover { background: var(--c-amber-dark); }
.cb-decline { background: var(--c-surface-2); color: var(--c-text); }

/* ════════════════════════════════════════
   WHATSAPP FLOAT
   ════════════════════════════════════════ */
.whatsapp-float {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 900;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #25d366;
  color: #fff;
  border-radius: var(--r-pill);
  padding: 13px 20px 13px 16px;
  box-shadow: 0 4px 20px rgba(37,211,102,.40);
  font-size: 14px;
  font-weight: 600;
  font-family: var(--f-sans);
  transition: transform 180ms var(--ease-spring), box-shadow 180ms var(--ease-out);
}
.whatsapp-float:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(37,211,102,.55); color: #fff; }
.whatsapp-label { white-space: nowrap; }

/* ════════════════════════════════════════
   PRIVACY POLICY PAGE
   ════════════════════════════════════════ */
.policy-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: var(--sp-14) var(--sp-4) var(--sp-11);
}
.policy-wrap h1 { font-family: var(--f-serif); font-size: clamp(24px, 3vw, 34px); margin-bottom: var(--sp-2); color: var(--c-navy); }
.policy-wrap .policy-updated { font-size: 13px; color: var(--c-text-muted); margin-bottom: var(--sp-6); }
.policy-wrap h2 { font-family: var(--f-serif); font-size: 18px; margin: var(--sp-5) 0 var(--sp-2); color: var(--c-navy); }
.policy-wrap p, .policy-wrap li { font-size: 15px; line-height: 1.8; color: var(--c-text); margin-bottom: var(--sp-2); }
.policy-wrap ul { padding-left: var(--sp-3); list-style: disc; }
.policy-wrap a { color: var(--c-blue); text-decoration: underline; }

/* ════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════ */
@media (max-width: 900px) {
  .footer-inner { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .nav-links, .nav-cta { display: none; }
  .nav-hamburger { display: flex; }
  .whatsapp-float { bottom: 20px; right: 20px; padding: 13px 16px; }
  .whatsapp-label { display: none; }
  .footer-inner { grid-template-columns: 1fr; padding-bottom: var(--sp-4); }
  .footer-base { flex-direction: column; text-align: center; }
  .cb-inner { flex-direction: column; align-items: flex-start; gap: var(--sp-2); }
  .cb-actions { width: 100%; }
  .cb-btn { flex: 1; text-align: center; }
}
