/* =====================================================================
   Avantrix Business Coaching — Main Stylesheet
   Company: Avantrix Business Coaching
   Palette: Navy #1F2A44 · Gold #D4A63A · White · Light Grey #F5F6F8
   Build: Static · Zero frameworks · System fonts · WCAG 2.1 AA
   ===================================================================== */

/* Design Tokens ------------------------------------------------------- */
:root{
  --color-primary:#1F2A44;
  --color-primary-dark:#141B2E;
  --color-secondary:#D4A63A;
  --color-secondary-dark:#B88B24;
  --color-bg:#FFFFFF;
  --color-bg-alt:#F5F6F8;
  --color-text:#2E2E2E;
  --color-text-muted:#6B7280;
  --color-border:#E5E7EB;

  --space-1:8px;--space-2:16px;--space-3:24px;--space-4:32px;
  --space-6:48px;--space-8:64px;--space-12:96px;--space-16:128px;

  --font-body:system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  --text-xs:clamp(.75rem,1.5vw,.875rem);
  --text-sm:clamp(.875rem,1.8vw,1rem);
  --text-base:clamp(1rem,2vw,1.125rem);
  --text-lg:clamp(1.125rem,2.5vw,1.25rem);
  --text-xl:clamp(1.25rem,3vw,1.5rem);
  --text-2xl:clamp(1.5rem,4vw,2rem);
  --text-3xl:clamp(2rem,5vw,2.75rem);
  --text-4xl:clamp(2.5rem,6vw,3.5rem);

  --container-max:1200px;
  --radius:8px;--radius-lg:16px;--radius-pill:999px;
  --shadow-sm:0 1px 3px rgba(31,42,68,.08);
  --shadow-md:0 4px 16px rgba(31,42,68,.10);
  --shadow-lg:0 12px 32px rgba(31,42,68,.14);
  --transition:200ms ease;
  --transition-slow:400ms ease;
  --header-h:80px;
}

/* Reset --------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,picture,svg,video{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{font-family:var(--font-body);font-weight:800;line-height:1.2;letter-spacing:-0.02em;margin:0 0 var(--space-2)}
p{margin:0 0 var(--space-2)}
a{color:var(--color-primary);text-decoration:none;transition:color var(--transition)}
a:hover,a:focus-visible{color:var(--color-secondary)}
button{font:inherit;cursor:pointer;border:0;background:none}
ul,ol{padding-left:0}
:focus-visible{outline:2px solid var(--color-secondary);outline-offset:3px;border-radius:4px}

/* Utilities ----------------------------------------------------------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-3)}
.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:var(--space-2);z-index:200;transition:top var(--transition)}
.skip-link:focus{top:0;color:#fff}
.accent{color:var(--color-secondary)}

/* Buttons ------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);padding:14px 28px;border-radius:var(--radius-pill);font-weight:700;font-size:var(--text-base);line-height:1;min-height:48px;transition:all var(--transition);white-space:nowrap;text-align:center;cursor:pointer;border:2px solid transparent}
.btn--primary{background:var(--color-secondary);color:var(--color-primary);border-color:var(--color-secondary)}
.btn--primary:hover,.btn--primary:focus-visible{background:var(--color-secondary-dark);border-color:var(--color-secondary-dark);color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--secondary{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn--secondary:hover,.btn--secondary:focus-visible{background:var(--color-primary);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn--ghost:hover,.btn--ghost:focus-visible{background:#fff;color:var(--color-primary)}
.btn--lg{padding:18px 36px;font-size:var(--text-lg);min-height:56px}

/* Header / Nav -------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);min-height:var(--header-h);padding:0 var(--space-3)}

/* Logo — image-based */
.site-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;line-height:0}
.site-logo img{height:52px;width:auto;display:block;object-fit:contain}
/* Footer logo */
.footer-logo{display:inline-flex;align-items:center;line-height:0}
.footer-logo img{height:60px;width:auto;display:block;object-fit:contain}

/* Desktop nav — hidden on mobile */
.primary-nav{display:flex;align-items:center;gap:4px}
.primary-nav>ul{list-style:none;margin:0;padding:0;display:flex;gap:2px;align-items:center}
.primary-nav a:not(.btn){display:inline-block;padding:10px 13px;color:var(--color-primary);font-weight:600;font-size:var(--text-sm);border-radius:var(--radius);transition:background var(--transition),color var(--transition);white-space:nowrap}
.primary-nav a:not(.btn):hover,
.primary-nav a:not(.btn):focus-visible,
.primary-nav a.is-active{background:var(--color-bg-alt);color:var(--color-primary)}

/* Desktop dropdown — bridge gap prevents disappearing on hover */
.has-dropdown{position:relative}
.has-dropdown>a::after{content:"▾";margin-left:4px;font-size:.7em;display:inline-block;transition:transform var(--transition)}
.dropdown{
  position:absolute;
  top:100%;           /* flush to parent bottom — no gap */
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid var(--color-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  padding:6px;
  padding-top:14px;   /* push links down, covers the bridge */
  display:none;
  flex-direction:column;
  gap:2px;
  z-index:200;
}
/* Transparent bridge — fills the gap between trigger and dropdown */
.dropdown::before{
  content:"";
  position:absolute;
  top:-12px;
  left:0;
  right:0;
  height:12px;
  background:transparent;
}
.dropdown a{display:block;padding:9px 14px;border-radius:var(--radius);color:var(--color-primary);font-weight:500;font-size:var(--text-sm);transition:background var(--transition)}
.dropdown a:hover,.dropdown a:focus-visible{background:var(--color-bg-alt)}
/* Open states — hover on desktop, .is-open class for keyboard/mobile */
.has-dropdown:hover>.dropdown,
.has-dropdown:focus-within>.dropdown,
.has-dropdown.is-open>.dropdown{display:flex}
.has-dropdown.is-open>a::after{transform:rotate(180deg)}

/* Mobile toggle button */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:var(--radius);
  align-items:center;justify-content:center;
  color:var(--color-primary);
  flex-shrink:0;
  cursor:pointer;
  transition:background var(--transition);
}
.nav-toggle:hover{background:var(--color-bg-alt)}
.nav-toggle svg{width:24px;height:24px;display:block}
/* Animated hamburger → X */
.nav-toggle .bar{transform-origin:center;transition:transform .3s ease, opacity .3s ease}
.nav-toggle[aria-expanded="true"] .bar-top{transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar-mid{opacity:0;transform:scaleX(0)}
.nav-toggle[aria-expanded="true"] .bar-bot{transform:translateY(-6px) rotate(-45deg)}

/* ── MOBILE / TABLET breakpoint ──────────────────────────────────── */
@media (max-width:1024px){
  .nav-toggle{display:inline-flex}

  /* Slide-in panel */
  .primary-nav{
    position:fixed;
    top:var(--header-h);
    left:0;right:0;bottom:0;
    background:#fff;
    overflow-y:auto;
    transform:translateX(110%);
    transition:transform var(--transition-slow);
    z-index:99;
    flex-direction:column;
    align-items:stretch;
    padding:16px;
    border-top:1px solid var(--color-border);
    gap:0;
  }
  .primary-nav.is-open{transform:translateX(0)}

  /* Top-level list */
  .primary-nav>ul{
    flex-direction:column;
    align-items:stretch;
    gap:4px;
    width:100%;
  }
  .primary-nav a:not(.btn){
    padding:14px 16px;
    font-size:1rem;
    border-radius:var(--radius);
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:center;
  }
  .primary-nav .btn{
    margin-top:12px;
    width:100%;
    justify-content:center;
  }

  /* Mobile dropdown — always static, toggled by .is-open */
  .has-dropdown{position:relative}
  .has-dropdown>a{cursor:pointer}
  .dropdown{
    position:static;
    display:none;        /* hidden by default */
    flex-direction:column;
    box-shadow:none;
    border:0;
    border-left:3px solid var(--color-secondary);
    border-radius:0;
    background:var(--color-bg-alt);
    padding:6px 6px 6px 16px;
    margin:4px 0 4px 16px;
    gap:2px;
    padding-top:6px;    /* reset desktop padding-top */
  }
  .dropdown::before{display:none} /* no bridge needed on mobile */
  .has-dropdown.is-open>.dropdown{display:flex}
  .has-dropdown.is-open>a::after{transform:rotate(180deg)}
  .dropdown a{padding:10px 12px;font-size:.95rem}
}

/* Breadcrumb ---------------------------------------------------------- */
.breadcrumb{background:var(--color-bg-alt);padding:14px 0;font-size:var(--text-sm);border-bottom:1px solid var(--color-border)}
.breadcrumb ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.breadcrumb li+li::before{content:"›";margin:0 6px;color:var(--color-text-muted)}
.breadcrumb a{color:var(--color-primary);font-weight:500}
.breadcrumb [aria-current="page"]{color:var(--color-text-muted)}

/* Hero ---------------------------------------------------------------- */
.hero{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:var(--space-12) 0 var(--space-8);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(600px circle at 80% 20%,rgba(212,166,58,.18),transparent 60%);pointer-events:none}
.hero__inner{position:relative;z-index:2;max-width:900px}
.hero__eyebrow{display:inline-block;padding:6px 16px;border-radius:var(--radius-pill);background:rgba(212,166,58,.15);color:var(--color-secondary);font-size:var(--text-sm);font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin:0 0 var(--space-3)}
.hero h1{font-size:var(--text-4xl);line-height:1.1;margin:0 0 var(--space-3);font-weight:900;letter-spacing:-.03em;color:#fff}
.hero h1 .accent{color:var(--color-secondary)}
.hero__subheading{font-size:var(--text-lg);color:rgba(255,255,255,.88);margin:0 0 var(--space-4);max-width:65ch;line-height:1.7}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}
.hero__trust{display:flex;flex-wrap:wrap;gap:var(--space-3);color:rgba(255,255,255,.8);font-size:var(--text-sm);padding-top:var(--space-2);border-top:1px solid rgba(255,255,255,.12)}
.hero__trust span{display:inline-flex;align-items:center;gap:6px}

@media (max-width:768px){
  .hero{padding:var(--space-8) 0 var(--space-6)}
  .hero h1{font-size:clamp(2rem,7vw,3rem)}
}

/* Trust Strip --------------------------------------------------------- */
.trust-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);background:#fff;padding:var(--space-4) var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:-50px auto 0;position:relative;z-index:3;max-width:var(--container-max);border-bottom:3px solid var(--color-secondary)}
.trust-strip>div{text-align:center;padding:var(--space-2) var(--space-1)}
.trust-strip strong{display:block;font-size:var(--text-3xl);color:var(--color-primary);font-weight:900;line-height:1}
.trust-strip span{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:6px;display:inline-block;font-weight:500}
@media (max-width:700px){.trust-strip{grid-template-columns:repeat(2,1fr);margin-top:-30px}}
@media (max-width:400px){.trust-strip{grid-template-columns:1fr 1fr}}

/* Sections ------------------------------------------------------------ */
.section{padding:var(--space-12) 0}
.section--alt{background:var(--color-bg-alt)}
.section--dark{background:var(--color-primary);color:#fff}
.section--dark h2,.section--dark h3{color:#fff}
.section--dark p{color:rgba(255,255,255,.85)}
.section__head{text-align:center;max-width:760px;margin:0 auto var(--space-6)}
.section__eyebrow{color:var(--color-secondary);font-weight:700;font-size:var(--text-sm);letter-spacing:.1em;text-transform:uppercase;margin:0 0 var(--space-1);display:block}
.section h2{font-size:var(--text-3xl);margin:0 0 var(--space-2);color:var(--color-primary);font-weight:800;letter-spacing:-.02em;line-height:1.2}
.section--dark h2{color:#fff}
.section p.section__lead{font-size:var(--text-lg);color:var(--color-text-muted);margin:0;line-height:1.7}
.section--dark p.section__lead{color:rgba(255,255,255,.8)}

/* Cards --------------------------------------------------------------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}
@media (max-width:960px){.cards{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.cards{grid-template-columns:1fr}}
.cards--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1024px){.cards--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.cards--4{grid-template-columns:1fr}}
.cards--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:700px){.cards--2{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-secondary)}
.card__icon{width:56px;height:56px;border-radius:var(--radius);background:var(--color-bg-alt);color:var(--color-primary);display:grid;place-items:center;margin-bottom:var(--space-2);flex-shrink:0}
.card__icon svg{width:28px;height:28px}
.card h3{margin:0 0 var(--space-1);color:var(--color-primary);font-size:var(--text-xl);font-weight:700}
.card p{margin:0;color:var(--color-text-muted);font-size:var(--text-base);line-height:1.6}
.card--gold{background:var(--color-primary);border:none}
.card--gold h3{color:var(--color-secondary)}
.card--gold p{color:rgba(255,255,255,.85)}
.card--gold .card__icon{background:rgba(212,166,58,.12);color:var(--color-secondary)}

/* Process Steps ------------------------------------------------------- */
.process__steps{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-3);grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.process__steps{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.process__steps{grid-template-columns:1fr}}
.process__step{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--color-border);position:relative}
.section--dark .process__step{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}
.section--dark .process__step h3{color:#fff}
.section--dark .process__step p{color:rgba(255,255,255,.75)}
.step__number{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--color-secondary);color:var(--color-primary);font-weight:900;font-size:var(--text-lg);margin-bottom:var(--space-2)}
.process__step h3{margin:0 0 8px;color:var(--color-primary);font-size:var(--text-lg);font-weight:700}
.process__step p{margin:0;color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.6}

/* Feature Split ------------------------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:center}
@media (max-width:900px){.split{grid-template-columns:1fr}}
.split__media{aspect-ratio:4/3;background:linear-gradient(135deg,var(--color-primary),#2d3a5a);border-radius:var(--radius-lg);display:grid;place-items:center;overflow:hidden;padding:var(--space-4)}
.split h2{margin-top:0}

.feature-list{list-style:none;padding:0;margin:var(--space-3) 0 var(--space-4);display:grid;gap:12px}
.feature-list li{display:flex;gap:var(--space-2);align-items:flex-start;font-size:var(--text-base);color:var(--color-text);line-height:1.5}
.feature-list li::before{content:"";flex:0 0 22px;height:22px;border-radius:50%;background-color:var(--color-secondary);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231F2A44' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:14px;background-position:center;background-repeat:no-repeat;margin-top:2px}

/* Testimonials -------------------------------------------------------- */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}
@media (max-width:960px){.testimonials{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.testimonials{grid-template-columns:1fr}}
.testimonial{background:#fff;padding:var(--space-4);border-radius:var(--radius-lg);border-top:4px solid var(--color-secondary);margin:0;box-shadow:var(--shadow-sm)}
.testimonial::before{content:"\201C";display:block;font-size:3.5rem;color:var(--color-secondary);line-height:.7;margin-bottom:12px;font-family:Georgia,serif}
.testimonial p{font-size:var(--text-base);color:var(--color-text);font-style:italic;margin:0 0 var(--space-2);line-height:1.7}
.testimonial footer{font-style:normal}
.testimonial cite{font-style:normal;color:var(--color-text-muted);font-size:var(--text-sm);display:block}
.testimonial cite strong{color:var(--color-primary);display:block;font-weight:700;font-size:var(--text-base)}

/* FAQ ----------------------------------------------------------------- */
.faq__list{max-width:860px;margin:0 auto;display:grid;gap:8px}
.faq__item details{background:#fff;border:1.5px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition)}
.faq__item details[open]{border-color:var(--color-secondary);box-shadow:var(--shadow-sm)}
.faq__item summary{padding:var(--space-2) var(--space-3);font-weight:600;color:var(--color-primary);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);min-height:56px;font-size:var(--text-base)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-size:1.8rem;font-weight:300;color:var(--color-secondary);line-height:1;transition:transform var(--transition);flex-shrink:0}
.faq__item details[open] summary::after{transform:rotate(45deg)}
.faq__item summary:hover{background:var(--color-bg-alt)}
.faq__item [itemprop="acceptedAnswer"]{padding:0 var(--space-3) var(--space-3)}
.faq__item [itemprop="acceptedAnswer"] p{margin:0;color:var(--color-text);line-height:1.7}

/* CTA Banner ---------------------------------------------------------- */
.cta-banner{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(600px circle at 20% 0%,rgba(212,166,58,.2),transparent 60%);pointer-events:none}
.cta-banner>*{position:relative;z-index:1}
.cta-banner h2{color:#fff;margin:0 0 var(--space-2);font-size:var(--text-3xl)}
.cta-banner p{color:rgba(255,255,255,.9);font-size:var(--text-lg);max-width:58ch;margin:0 auto var(--space-4)}

/* Footer -------------------------------------------------------------- */
.site-footer{background:var(--color-primary);color:rgba(255,255,255,.82);padding:var(--space-8) 0 var(--space-3)}
.site-footer a{color:rgba(255,255,255,.82);transition:color var(--transition)}
.site-footer a:hover,.site-footer a:focus-visible{color:var(--color-secondary)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:var(--space-4);margin-bottom:var(--space-6)}
@media (max-width:900px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer__grid{grid-template-columns:1fr}}
.footer__col h4{color:#fff;margin:0 0 var(--space-2);font-size:var(--text-base);font-weight:700;letter-spacing:.02em}
.footer__col ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer__col ul a{font-size:var(--text-sm)}
.footer__brand p{color:rgba(255,255,255,.72);font-size:var(--text-sm);line-height:1.7;margin:var(--space-2) 0}
.footer__contact address{font-style:normal;color:rgba(255,255,255,.82);font-size:var(--text-sm);line-height:1.9}
.footer__contact a{color:rgba(255,255,255,.9)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:var(--space-3);display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--space-2);color:rgba(255,255,255,.55);font-size:var(--text-xs)}
.footer__bottom nav{display:flex;gap:var(--space-3);flex-wrap:wrap}

/* Floating Buttons ---------------------------------------------------- */
.whatsapp-fab{position:fixed;right:24px;bottom:24px;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:90;transition:transform var(--transition)}
.whatsapp-fab:hover,.whatsapp-fab:focus-visible{transform:scale(1.1);color:#fff}
.whatsapp-fab svg{width:32px;height:32px}

.back-to-top{position:fixed;right:24px;bottom:96px;width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-md);z-index:89;transition:opacity var(--transition),transform var(--transition);opacity:0;pointer-events:none;transform:translateY(10px)}
.back-to-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-to-top svg{width:22px;height:22px}

.contact-strip{position:fixed;left:24px;bottom:24px;z-index:88;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:8px 16px;display:flex;gap:var(--space-1);align-items:center;box-shadow:var(--shadow-md);font-size:var(--text-sm)}
.contact-strip a{color:var(--color-primary);font-weight:600;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--radius-pill);transition:background var(--transition)}
.contact-strip a:hover,.contact-strip a:focus-visible{background:var(--color-bg-alt)}
.contact-strip .divider{width:1px;height:20px;background:var(--color-border)}

@media (max-width:600px){
  .contact-strip{left:50%;transform:translateX(-50%);bottom:96px;font-size:var(--text-xs)}
  .back-to-top{bottom:96px}
}

/* Forms --------------------------------------------------------------- */
.form-wrap{background:#fff;padding:var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}
.form-group{margin-bottom:var(--space-3)}
.form-group label{display:block;font-weight:600;margin-bottom:8px;color:var(--color-primary);font-size:var(--text-sm)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius);font:inherit;color:var(--color-text);background:#fff;transition:border-color var(--transition),box-shadow var(--transition);min-height:48px;font-size:var(--text-base)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(212,166,58,.18)}
.form-group textarea{min-height:130px;resize:vertical}
.form-error{color:#B91C1C;font-size:var(--text-sm);margin-top:4px;display:block}

/* Contact grid -------------------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:start}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-methods{display:grid;gap:var(--space-2);margin-bottom:var(--space-4)}
.contact-method{display:flex;gap:var(--space-2);align-items:center;background:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius);border:1px solid var(--color-border);transition:border-color var(--transition),box-shadow var(--transition)}
.contact-method:hover{border-color:var(--color-secondary);box-shadow:var(--shadow-sm)}
.contact-method__icon{width:44px;height:44px;border-radius:var(--radius);background:var(--color-bg-alt);color:var(--color-primary);display:grid;place-items:center;flex:0 0 44px}
.contact-method__icon svg{width:22px;height:22px}
.contact-method strong{color:var(--color-primary);display:block;font-size:var(--text-base);font-weight:700}
.contact-method a,.contact-method span{color:var(--color-text-muted);font-size:var(--text-sm)}
.contact-method a:hover{color:var(--color-primary)}

/* Map */
.map-embed{aspect-ratio:16/9;background:var(--color-bg-alt);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border)}
.map-embed iframe{width:100%;height:100%;border:0;display:block}

/* Not found ----------------------------------------------------------- */
.not-found{text-align:center;padding:var(--space-12) var(--space-3)}
.not-found h1{font-size:clamp(4rem,15vw,8rem);color:var(--color-secondary);margin:0;line-height:1;font-weight:900}
.not-found p{max-width:55ch;margin:var(--space-2) auto var(--space-4);color:var(--color-text-muted)}

/* Legal / Prose ------------------------------------------------------- */
.prose{max-width:760px;margin:0 auto;padding:var(--space-4) 0}
.prose h1{font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:var(--space-3)}
.prose h2{margin-top:var(--space-6);color:var(--color-primary);font-size:var(--text-2xl)}
.prose h3{margin-top:var(--space-4);color:var(--color-primary)}
.prose p,.prose li{line-height:1.8;margin-bottom:var(--space-1)}
.prose ul,.prose ol{padding-left:var(--space-3)}
.prose a{color:var(--color-secondary);text-decoration:underline}

/* Print --------------------------------------------------------------- */
@media print{
  .site-header,.whatsapp-fab,.back-to-top,.contact-strip,.nav-toggle,.cta-banner,.site-footer{display:none!important}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
}

/* Reduced motion ------------------------------------------------------ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
