/* ============================================================
   ANUMBA DORCAS ADAEZE — REAL ESTATE CONSULTANT
   Design tokens: Ink Navy / Champagne Gold / Ivory
   Display: Fraunces  ·  Body: Manrope
   Signature motif: surveyor's corner brackets (verified-mark)
   ============================================================ */

:root{
  /* -- colour tokens -- */
  --ink:        #0B1B2B;   /* primary deep navy background */
  --ink-2:      #102338;   /* secondary navy panel */
  --black:      #070F18;   /* near-black, deepest sections */
  --ivory:      #F7F4EC;   /* warm off-white */
  --ivory-dim:  #E8E2D2;   /* muted ivory for secondary text on dark */
  --gold:       #C9A227;   /* champagne gold, primary accent */
  --gold-light: #E8D9A8;   /* pale gold for highlights/gradients */
  --gold-dim:   #8A752A;   /* deep gold for borders on light bg */
  --line:       rgba(201,162,39,0.22); /* hairline rule on dark */
  --line-soft:  rgba(11,27,43,0.12);   /* hairline rule on light */

  /* -- type -- */
  --display: 'Fraunces', 'Iowan Old Style', Georgia, serif;
  --body: 'Manrope', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* -- scale -- */
  --container: 1180px;
  --radius: 2px;

  /* -- motion -- */
  --ease: cubic-bezier(.22,1,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--body);
  background:var(--ivory);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
.container{max-width:var(--container);margin:0 auto;padding:0 28px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important;}
}

/* ---------- typography helpers ---------- */
.eyebrow{
  font-family:var(--body);
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex;
  align-items:center;
  gap:12px;
}
.eyebrow::before{
  content:'';
  width:26px;height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.center{justify-content:center;}
.eyebrow.center::before{display:none;}
.eyebrow.dark{color:var(--gold-dim);}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.12;letter-spacing:-0.01em;}
.section-title{
  font-size:clamp(1.9rem,3.2vw,2.7rem);
  margin:14px 0 0;
  color:var(--ink);
}
.section-title.on-dark{color:var(--ivory);}
.section-title em{font-style:italic;color:var(--gold);}
.section-head{max-width:640px;margin-bottom:56px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-sub{
  margin-top:16px;
  font-size:1.02rem;
  color:#52606d;
  max-width:560px;
}
.section-sub.on-dark{color:var(--ivory-dim);}
.section-head.center .section-sub{margin-left:auto;margin-right:auto;}

.section{padding:108px 0;}
@media (max-width:780px){.section{padding:76px 0;}}

.section.navy{background:var(--ink);color:var(--ivory);}
.section.black{background:var(--black);color:var(--ivory);}

/* subtle survey-grid texture for dark sections */
.section.navy, .section.black{position:relative;}
.section.navy::before, .section.black::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:.18;
  pointer-events:none;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 30px;
  font-family:var(--body);
  font-weight:700;
  font-size:.92rem;
  letter-spacing:.02em;
  border-radius:var(--radius);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease), color .35s var(--ease);
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;flex:none;}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-light),var(--gold) 60%);
  color:var(--ink);
  box-shadow:0 10px 30px -10px rgba(201,162,39,.55);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(201,162,39,.7);}
.btn-outline{
  border:1px solid var(--gold);
  color:var(--ivory);
  background:transparent;
}
.btn-outline:hover{background:var(--gold);color:var(--ink);}
.btn-outline.dark{border:1px solid var(--ink);color:var(--ink);}
.btn-outline.dark:hover{background:var(--ink);color:var(--ivory);}
.btn-ghost{
  color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding:4px 0;
  border-radius:0;
}
.btn-block{width:100%;}

/* ---------- signature motif: surveyor corner brackets ---------- */
.bracket-frame{position:relative;padding:18px;}
.bracket-frame::before,
.bracket-frame::after,
.bracket-frame .bk-tr,
.bracket-frame .bk-bl{
  content:'';
  position:absolute;
  width:26px;height:26px;
  border:1px solid var(--gold);
  z-index:2;
}
.bracket-frame::before{top:0;left:0;border-right:none;border-bottom:none;}
.bracket-frame::after{bottom:0;right:0;border-left:none;border-top:none;}
.bracket-frame .bk-tr{top:0;right:0;border-left:none;border-bottom:none;}
.bracket-frame .bk-bl{bottom:0;left:0;border-right:none;border-top:none;}

/* ---------- reveal-on-scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease), transform .8s var(--ease);}
.reveal.is-visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.08s;}
.reveal-delay-2{transition-delay:.16s;}
.reveal-delay-3{transition-delay:.24s;}
.reveal-delay-4{transition-delay:.32s;}

/* ============================================================
   NAVBAR
   ============================================================ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(11,27,43,0);
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding:22px 0;
}
.navbar.scrolled{
  background:rgba(11,27,43,.96);
  backdrop-filter:blur(10px);
  box-shadow:0 8px 30px -10px rgba(0,0,0,.4);
  padding:12px 0;
}
.nav-inner{display:flex;align-items:center;gap:28px;}
.logo{display:flex;align-items:center;gap:12px;margin-right:auto;}
.logo-mark{
  width:42px;height:42px;border:1px solid var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:.92rem;letter-spacing:.04em;
  color:var(--gold);flex:none;
}
.logo-text{font-family:var(--display);color:var(--ivory);font-size:1.02rem;letter-spacing:.01em;}
.logo-text em{font-style:italic;color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-link{
  color:var(--ivory-dim);font-size:.86rem;font-weight:600;letter-spacing:.01em;
  position:relative;padding:4px 0;transition:color .25s var(--ease);
}
.nav-link::after{
  content:'';position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);
  transition:width .3s var(--ease);
}
.nav-link:hover{color:var(--ivory);}
.nav-link:hover::after{width:100%;}
.nav-cta-link{display:none;}
.nav-cta{padding:11px 22px;font-size:.84rem;}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:28px;}
.nav-toggle span{display:block;width:100%;height:2px;background:var(--ivory);transition:transform .3s var(--ease), opacity .3s var(--ease);}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.active span:nth-child(2){opacity:0;}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media (max-width:900px){
  .nav-links{
    position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);
    background:var(--ink);flex-direction:column;justify-content:center;align-items:flex-start;
    gap:26px;padding:0 40px;transform:translateX(100%);transition:transform .45s var(--ease);
    box-shadow:-10px 0 40px rgba(0,0,0,.35);
  }
  .nav-links.open{transform:translateX(0);}
  .nav-cta-link{display:block;color:var(--gold);}
  .nav-cta{display:none;}
  .nav-toggle{display:flex;}
  .logo-text{display:none;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  background:linear-gradient(180deg,var(--ink) 0%, var(--ink-2) 100%);
  padding-top:150px;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:70px 70px;opacity:.16;pointer-events:none;
}
.hero-inner{
  display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;
  position:relative;z-index:1;padding-bottom:80px;
}
.hero-title{
  font-size:clamp(2.3rem,4.6vw,3.55rem);
  color:var(--ivory);margin-top:18px;
}
.hero-title em{font-style:italic;color:var(--gold);font-weight:500;}
.hero-sub{margin-top:22px;color:var(--ivory-dim);font-size:1.06rem;max-width:520px;}
.hero-trust{margin-top:14px;color:var(--gold-light);font-weight:600;font-size:.95rem;}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;}
.hero-ctas .btn-ghost{color:var(--ivory);border-color:var(--ivory-dim);}
.hero-badges{display:flex;flex-wrap:wrap;gap:26px;margin-top:38px;}
.hero-badges li{
  display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--ivory-dim);font-weight:600;
}
.hero-badges svg{width:18px;height:18px;color:var(--gold);flex:none;}

.hero-portrait{position:relative;display:flex;flex-direction:column;align-items:center;}
.portrait-frame{max-width:380px;}
.portrait-frame img{aspect-ratio:4/5;object-fit:cover;border-radius:1px;}
.portrait-tag{
  margin-top:-26px;background:var(--gold);color:var(--ink);padding:14px 26px;
  text-align:center;min-width:240px;box-shadow:0 14px 30px -10px rgba(0,0,0,.4);
}
.portrait-tag-name{font-family:var(--display);font-weight:600;font-size:1rem;}
.portrait-tag-role{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin-top:2px;}

.hero-strip{
  position:relative;z-index:1;border-top:1px solid var(--line);
  background:rgba(7,15,24,.5);
  overflow:hidden;white-space:nowrap;
}
.hero-strip-inner{
  display:inline-flex;gap:18px;padding:16px 0;
  font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ivory-dim);
  animation:scrollStrip 28s linear infinite;
}
.hero-strip-inner span:nth-child(odd){color:var(--gold);}
@keyframes scrollStrip{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;text-align:center;}
  .hero-copy{order:2;}
  .hero-portrait{order:1;margin-bottom:8px;}
  .hero-sub{margin-left:auto;margin-right:auto;}
  .hero-ctas{justify-content:center;}
  .hero-badges{justify-content:center;}
  .portrait-frame{max-width:280px;}
}

/* ============================================================
   ABOUT
   ============================================================ */
.about-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center;}
.about-frame{max-width:420px;margin:0 auto;}
.about-frame img{aspect-ratio:3/4;object-fit:cover;filter:grayscale(.06);}
.about-quote{
  margin-top:24px;border-left:2px solid var(--gold);padding-left:18px;max-width:380px;margin-inline:auto;
}
.about-quote p{font-family:var(--display);font-style:italic;font-size:1.06rem;color:var(--ink);}
.about-quote span{display:block;margin-top:10px;font-size:.82rem;color:var(--gold-dim);font-weight:700;letter-spacing:.04em;}
.about-lead{font-family:var(--display);font-size:1.18rem;margin-top:18px;color:var(--ink);}
.about-copy p{margin-top:16px;color:#3d4a55;max-width:560px;}
.about-pillars{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:36px 0 34px;max-width:580px;}
.about-pillar h4{font-size:1rem;color:var(--ink);margin-bottom:6px;}
.about-pillar p{margin-top:0;font-size:.9rem;}
.about-pillar::before{
  content:'';display:block;width:30px;height:1px;background:var(--gold);margin-bottom:12px;
}

@media (max-width:900px){
  .about-inner{grid-template-columns:1fr;}
  .about-pillars{grid-template-columns:1fr;}
}

/* ============================================================
   SERVICES
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.service-card{
  background:var(--ink);padding:38px 30px;transition:background .35s var(--ease), transform .35s var(--ease);
}
.service-card:hover{background:var(--ink-2);transform:translateY(-4px);}
.service-icon{
  width:48px;height:48px;border:1px solid var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin-bottom:22px;color:var(--gold);
}
.service-icon svg{width:22px;height:22px;}
.service-card h3{font-size:1.06rem;color:var(--ivory);margin-bottom:10px;}
.service-card p{font-size:.88rem;color:var(--ivory-dim);}

@media (max-width:980px){.services-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.services-grid{grid-template-columns:1fr;}}

/* ============================================================
   WHY WORK WITH ME
   ============================================================ */
.why{background:var(--ivory);}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.why-card{
  background:#fff;border:1px solid var(--line-soft);padding:34px 28px;position:relative;
  transition:border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.why-card:hover{border-color:var(--gold);transform:translateY(-5px);box-shadow:0 18px 36px -16px rgba(11,27,43,.18);}
.why-num{
  font-family:var(--display);font-size:1rem;color:var(--gold-dim);display:block;margin-bottom:14px;letter-spacing:.04em;
}
.why-card h4{font-size:1.04rem;margin-bottom:10px;color:var(--ink);}
.why-card p{font-size:.9rem;color:#52606d;}
.why-card-wide{
  grid-column:1/-1;max-width:380px;margin:0 auto;text-align:center;
}
.why-card-wide .why-num{margin-left:auto;margin-right:auto;}

@media (max-width:980px){.why-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.why-grid{grid-template-columns:1fr;}}

/* ============================================================
   PROPERTIES
   ============================================================ */
.properties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.property-card{
  background:#fff;border:1px solid var(--line-soft);transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.property-card:hover{transform:translateY(-6px);box-shadow:0 22px 44px -20px rgba(11,27,43,.22);}
.property-media{
  position:relative;background:linear-gradient(135deg,var(--ink) 0%, var(--ink-2) 100%);
  height:200px;display:flex;align-items:center;justify-content:center;color:var(--gold-light);overflow:hidden;
}
.property-illustration{width:62%;opacity:.85;}
.property-tag{
  position:absolute;top:14px;left:14px;background:var(--gold);color:var(--ink);
  font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 12px;z-index:3;
}
.property-body{padding:26px 26px 28px;}
.property-type{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dim);font-weight:700;}
.property-body h3{font-size:1.1rem;margin-top:8px;color:var(--ink);}
.property-location{font-size:.85rem;color:#52606d;margin-top:8px;}
.property-desc{font-size:.88rem;color:#52606d;margin-top:10px;}
.property-foot{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-top:22px;padding-top:18px;border-top:1px solid var(--line-soft);
}
.property-price{font-family:var(--display);font-weight:600;color:var(--ink);font-size:.98rem;}
.btn-sm{padding:10px 18px;font-size:.78rem;}

.property-card-cta{
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);border:1px dashed var(--gold);min-height:260px;
}
.property-cta-inner{padding:36px;text-align:center;}
.property-cta-inner h3{color:var(--ivory);font-size:1.14rem;margin-bottom:10px;}
.property-cta-inner p{color:var(--ivory-dim);font-size:.9rem;margin-bottom:22px;}

@media (max-width:980px){.properties-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:640px){.properties-grid{grid-template-columns:1fr;}}

/* ============================================================
   INVESTMENT OPPORTUNITIES
   ============================================================ */
.invest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;}
.invest-card{
  border:1px solid var(--line);padding:32px 26px;transition:border-color .3s var(--ease), background .3s var(--ease);
}
.invest-card:hover{border-color:var(--gold);background:rgba(201,162,39,.05);}
.invest-icon{
  width:46px;height:46px;border-radius:50%;border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:20px;
}
.invest-icon svg{width:21px;height:21px;}
.invest-card h4{color:var(--ivory);font-size:1rem;margin-bottom:10px;}
.invest-card p{font-size:.87rem;color:var(--ivory-dim);}
.invest-cta{
  margin-top:54px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:38px;
}
.invest-cta p{color:var(--ivory-dim);font-size:1.02rem;max-width:520px;font-family:var(--display);font-style:italic;}

@media (max-width:980px){.invest-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.invest-grid{grid-template-columns:1fr;}.invest-cta{flex-direction:column;align-items:flex-start;}}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials{background:var(--ivory);}
.testimonial-track{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.testimonial-card{background:#fff;padding:32px 26px;}
.testimonial-quote{font-family:var(--display);font-style:italic;color:var(--ink);font-size:.98rem;line-height:1.5;}
.testimonial-meta{margin-top:20px;padding-top:16px;border-top:1px solid var(--line-soft);}
.testimonial-name{display:block;font-weight:700;font-size:.88rem;color:var(--ink);}
.testimonial-role{display:block;font-size:.78rem;color:#52606d;margin-top:2px;}
.testimonial-note{text-align:center;margin-top:36px;font-size:.78rem;color:#8a96a0;font-style:italic;}

@media (max-width:980px){.testimonial-track{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.testimonial-track{grid-template-columns:1fr;}}

/* ============================================================
   PROCESS
   ============================================================ */
.process{background:#fff;}
.process-track{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;
}
.process-track::before{
  content:'';position:absolute;top:24px;left:6%;right:6%;height:1px;background:var(--line-soft);z-index:0;
}
.process-step{position:relative;z-index:1;padding:0 18px;text-align:center;}
.process-num{
  display:flex;align-items:center;justify-content:center;margin:0 auto 22px;
  width:48px;height:48px;border-radius:50%;background:var(--ink);color:var(--gold);
  font-family:var(--display);font-size:.96rem;border:1px solid var(--gold);
}
.process-step h4{font-size:1rem;margin-bottom:10px;color:var(--ink);}
.process-step p{font-size:.86rem;color:#52606d;}

@media (max-width:900px){
  .process-track{grid-template-columns:1fr;gap:36px;}
  .process-track::before{display:none;}
  .process-step{text-align:center;max-width:340px;margin:0 auto;}
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-inner{max-width:820px;}
.faq-list{margin-top:20px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:24px 0;text-align:left;color:var(--ivory);font-family:var(--display);font-size:1.04rem;
}
.faq-icon{font-size:1.3rem;color:var(--gold);transition:transform .3s var(--ease);flex:none;}
.faq-item.open .faq-icon{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);}
.faq-a p{padding:0 0 26px;color:var(--ivory-dim);font-size:.92rem;max-width:680px;}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final-cta{
  position:relative;
  background:linear-gradient(135deg,var(--ink) 0%, var(--black) 100%);
  padding:120px 0;text-align:center;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(201,162,39,.18), transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);
}
.final-cta-inner{position:relative;z-index:1;max-width:680px;margin:0 auto;}
.final-cta-title{font-size:clamp(2rem,4vw,3rem);color:var(--ivory);margin-top:16px;}
.final-cta-title em{font-style:italic;color:var(--gold);}
.final-cta-sub{color:var(--ivory-dim);margin:22px 0 38px;font-size:1.04rem;}
.btn-lg{padding:19px 38px;font-size:1rem;}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:var(--ivory);}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
.contact-card{
  margin-top:30px;background:var(--ink);color:var(--ivory);padding:32px;max-width:420px;position:relative;
}
.contact-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gold);}
.contact-name{font-family:var(--display);font-size:1.2rem;}
.contact-role{font-size:.8rem;color:var(--ivory-dim);letter-spacing:.05em;text-transform:uppercase;margin-top:4px;}
.contact-phone{
  display:flex;align-items:center;gap:10px;margin-top:22px;font-family:var(--display);font-size:1.3rem;color:var(--gold-light);
}
.contact-phone svg{width:22px;height:22px;}
.contact-hint{font-size:.78rem;color:var(--ivory-dim);margin-top:10px;}
.contact-points{margin-top:28px;}
.contact-points li{
  display:flex;gap:10px;font-size:.9rem;color:#3d4a55;margin-bottom:10px;padding-left:18px;position:relative;
}
.contact-points li::before{content:'—';position:absolute;left:0;color:var(--gold-dim);}

.contact-form{
  background:#fff;border:1px solid var(--line-soft);padding:38px;
}
.contact-form h3{font-size:1.2rem;color:var(--ink);}
.contact-form-sub{font-size:.86rem;color:#52606d;margin-top:8px;margin-bottom:24px;}
.contact-form label{display:block;font-size:.82rem;font-weight:700;color:var(--ink);margin-bottom:16px;}
.contact-form input, .contact-form select, .contact-form textarea{
  display:block;width:100%;margin-top:8px;padding:13px 14px;border:1px solid var(--line-soft);
  background:var(--ivory);font-family:var(--body);font-size:.92rem;color:var(--ink);
  transition:border-color .25s var(--ease);
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{
  outline:none;border-color:var(--gold);
}
.contact-form textarea{resize:vertical;}
.contact-form button{margin-top:6px;}

@media (max-width:900px){.contact-inner{grid-template-columns:1fr;}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--black);color:var(--ivory-dim);}
.footer-inner{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:72px 0 48px;
}
.footer-tagline{margin-top:16px;font-size:.88rem;max-width:260px;}
.footer-social{display:flex;gap:14px;margin-top:24px;}
.footer-social a{
  width:36px;height:36px;border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--ivory-dim);
  transition:border-color .25s var(--ease), color .25s var(--ease);
}
.footer-social a:hover{border-color:var(--gold);color:var(--gold);}
.footer-social svg{width:16px;height:16px;}
.footer-links h5, .footer-contact h5{color:var(--ivory);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;}
.footer-links a, .footer-contact a{display:block;font-size:.88rem;margin-bottom:12px;color:var(--ivory-dim);transition:color .2s var(--ease);}
.footer-links a:hover, .footer-contact a:hover{color:var(--gold);}
.footer-contact p{font-size:.88rem;margin-bottom:12px;}
.footer-bottom{border-top:1px solid var(--line);}
.footer-bottom-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:22px 0;font-size:.78rem;}

@media (max-width:900px){
  .footer-inner{grid-template-columns:1fr 1fr;}
}
@media (max-width:560px){
  .footer-inner{grid-template-columns:1fr;}
}

/* ============================================================
   FLOATING WHATSAPP BUTTON
   ============================================================ */
.whatsapp-float{
  position:fixed;bottom:24px;right:24px;z-index:999;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px -8px rgba(0,0,0,.4);
  opacity:0;transform:scale(.7);pointer-events:none;
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.whatsapp-float.visible{opacity:1;transform:scale(1);pointer-events:auto;}
.whatsapp-float svg{width:30px;height:30px;}
.whatsapp-float.visible:hover{transform:scale(1.08);}
.whatsapp-pulse{
  position:absolute;inset:0;border-radius:50%;background:#25D366;
  animation:pulse 2.2s ease-out infinite;z-index:-1;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:.6;}
  100%{transform:scale(1.9);opacity:0;}
}
@media (max-width:600px){
  .whatsapp-float{width:54px;height:54px;bottom:18px;right:18px;}
  .whatsapp-float svg{width:26px;height:26px;}
}
