*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Serif 4',Georgia,serif;background:#FAF8FF;color:#1E1033;line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:inherit}

/* ═══ COLOUR TOKENS ═══ */
:root{
  --p900:#1A0D3B;
  --p800:#2A1654;
  --p700:#3D2278;
  --p600:#5438A0;
  --p500:#6B50BE;
  --p400:#8E76D1;
  --p300:#B8A4E5;
  --p200:#D9CFF2;
  --p100:#EDE5F7;
  --p050:#FAF8FF;
  --gold:#C9A84C;
  --gold-lt:#E8C97A;
  --gold-bg:#FDF6E8;
  --cream:#F7F4EF;
  --white:#FFFFFF;
  --muted:#7A6D9A;
  --border:#DDD5EF;
  --ff-d:'Cormorant Garamond',Georgia,serif;
  --ff-s:'Source Serif 4',Georgia,serif;
  --ff-u:'DM Sans',sans-serif;
}

/* ═══ ANIMATIONS ═══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulseGold{0%,100%{opacity:1}50%{opacity:.55}}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes scaleIn{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.reveal-d2{transition-delay:.1s}
.reveal-d3{transition-delay:.18s}
.reveal-d4{transition-delay:.26s}
.reveal-d5{transition-delay:.34s}
.reveal-d6{transition-delay:.42s}

/* ═══════════════════════════════════════
   DISCLAIMER OVERLAY
═══════════════════════════════════════ */
#disclaimer-overlay{
  position:fixed;inset:0;z-index:9999;
  background:var(--p900);
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
  animation:fadeIn 0.45s ease;
}
#disclaimer-overlay.hidden{display:none}
.disc-box{
  background:var(--white);border-radius:12px;
  max-width:680px;width:100%;
  max-height:92vh;overflow-y:auto;
  animation:scaleIn .45s ease;
  border-top:5px solid var(--p600);
}
.disc-header{
  background:var(--p800);
  padding:2rem 2.5rem 1.75rem;
  border-radius:7px 7px 0 0;
}
.disc-seal{
  width:56px;height:56px;border-radius:100%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1rem;

}
.disc-title{
  font-family:var(--ff-d);font-size:3rem;font-weight:600;
  color:var(--white);margin-bottom:.35rem;
}
.disc-sub{
  font-family:var(--ff-u);font-size:.75rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--p300);
  
}
.disc-sub1{
  font-family:var(--ff-u);font-size:1.4rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--p300);
  
}

.aligntextcenter{text-align:center}

.disc-body{padding:2rem 2.5rem}
.disc-section-title{
  font-family:var(--ff-u);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--p600);margin:1.5rem 0 .6rem;
}
.disc-section-title:first-child{margin-top:0}
.disc-text{
  font-family:var(--ff-u);font-size:.84rem;color:#444;
  line-height:1.75;margin-bottom:.75rem;
}
.disc-list{
  list-style:none;display:flex;flex-direction:column;gap:.45rem;
  margin-bottom:.75rem;
}
.disc-list li{
  font-family:var(--ff-u);font-size:.82rem;color:#444;
  padding-left:1.25rem;position:relative;line-height:1.6;
}
.disc-list li::before{
  content:'';position:absolute;left:0;top:.55em;
  width:5px;height:5px;border-radius:50%;
  background:var(--p400);
}
.disc-checkbox-row{
  display:flex;align-items:flex-start;gap:.75rem;
  background:var(--p100);border-radius:8px;
  padding:1rem 1.25rem;margin:1.5rem 0 1rem;
  border:1px solid var(--p200);
}
.disc-checkbox-row input{
  width:18px;height:18px;accent-color:var(--p600);
  margin-top:.15rem;flex-shrink:0;cursor:pointer;
}
.disc-checkbox-label{
  font-family:var(--ff-u);font-size:.82rem;color:var(--p800);
  line-height:1.6;cursor:pointer;
}
.disc-actions{
  display:flex;gap:.75rem;flex-wrap:wrap;
  padding:0 2.5rem 2rem;
}
.disc-accept{
  flex:1;background:var(--p600);color:var(--white);
  border:none;border-radius:6px;
  padding:.85rem 1.5rem;
  font-family:var(--ff-u);font-size:.88rem;font-weight:500;
  opacity:.4;cursor:not-allowed;transition:all .25s;
}
.disc-accept.active{opacity:1;cursor:pointer}
.disc-accept.active:hover{background:var(--p700)}
.disc-decline{
  background:transparent;border:1px solid var(--border);
  border-radius:6px;padding:.85rem 1.5rem;
  font-family:var(--ff-u);font-size:.85rem;color:var(--muted);
  transition:all .2s;
}
.disc-decline:hover{border-color:var(--p300);color:var(--p600)}

/* ═══════════════════════════════════════
   NAVBAR
═══════════════════════════════════════ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:500;
  background:rgba(26,13,59,.95);
  -webkit-backdrop-filter:blur(14px);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.07);
  transition:box-shadow .3s;
}
#navbar.scrolled{box-shadow:0 4px 28px rgba(0,0,0,.3)}
.nav-inner{
  max-width:1240px;margin:0 auto;padding:1rem;
  height:66px;display:flex;align-items:center;gap:1.5rem;
}
.nav-brand{display:flex;flex-direction:column;line-height:1.15;margin-right:0rem }
.nav-firm{
  font-family:var(--ff-d);font-size:1.2rem;font-weight:600;
  color:var(--white);letter-spacing:.02em;
}
.nav-tagline{
  font-family:var(--ff-u);font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--p300);margin-top:1px;
}
.nav-links{display:flex;align-items:center;gap:.1rem}
.nav-links a{
  font-family:var(--ff-u);font-size:.78rem;
  color:rgba(255,255,255,.72);padding:.45rem .82rem;
  border-radius:4px;transition:all .2s;white-space:nowrap;
}
.nav-links a:hover{color:var(--white);background:rgba(255,255,255,.08)}
.nav-wa{
  display:flex;align-items:center;gap:.45rem;
  background:var(--gold);color:var(--p900);
  font-family:var(--ff-u);font-size:.78rem;font-weight:500;
  padding:.48rem 1.1rem;border-radius:4px;border:none;
  white-space:nowrap;transition:background:2s;
}
.nav-wa:hover{background:var(--gold-lt)}
.hamburger{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:.5rem;background:none;border:none;
}
.hamburger span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.8);transition:.3s}
.mob-menu{
  display:none;position:fixed;inset:0;z-index:499;
  background:var(--p900);padding:5.5rem 2rem 2rem;
  flex-direction:column;overflow-y:auto;
}
.mob-menu.open{display:flex}
.mob-menu a{
  font-family:var(--ff-d);font-size:1.4rem;font-weight:500;
  color:var(--white);padding:.8rem 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.mob-menu .mob-wa{
  margin-top:1.5rem;background:var(--gold);color:var(--p900);
  text-align:center;padding:.9rem;border-radius:6px;
  font-family:var(--ff-u);font-weight:500;border:none;display:block;
}

/* ═══════════════════════════════════════
   SHARED
═══════════════════════════════════════ */
section{padding:5rem 0}
.container{max-width:1240px;margin:0 auto;padding:0 2rem}
.eyebrow{
  font-family:var(--ff-u);font-size:.7rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--p500);
  margin-bottom:.7rem;display:block;
}
.section-title{
  font-family:var(--ff-d);font-size:clamp(1.9rem,3.2vw,2.8rem);
  font-weight:600;line-height:1.12;color:var(--p900);
}
.section-title em{font-style:italic;color:var(--p600)}
.rule{
  width:44px;height:2px;
  background:linear-gradient(to right,var(--p500),var(--gold));
  border-radius:1px;margin:1.1rem 0 2.25rem;
}
.rule.center{margin-left:auto;margin-right:auto}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
.hero{
  min-height:100vh;position:relative;
  background:var(--p900);
  display:flex;align-items:center;overflow:hidden;
}
.hero-geo{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-geo::before{
  content:'';position:absolute;
  top:-220px;right:-220px;
  width:780px;height:780px;
  border:1px solid rgba(255,255,255,.04);border-radius:50%;
}
.hero-geo::after{
  content:'';position:absolute;
  top:-80px;right:-80px;
  width:520px;height:520px;
  border:1px solid rgba(180,140,230,.08);border-radius:50%;
}
.hero-geo2{
  position:absolute;bottom:-180px;left:-140px;
  width:480px;height:480px;
  border:1px solid rgba(255,255,255,.03);border-radius:50%;
  pointer-events:none;
}
.hero-left-bar{
  position:absolute;top:0;left:0;width:5px;height:100%;
  background:linear-gradient(to bottom,var(--p500),var(--gold));
}
.hero-inner{
  max-width:1240px;margin:0 auto;padding:2rem 2rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;
  align-items:center;position:relative;z-index:1;
  width:100%;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--ff-u);font-size:.7rem;font-weight:500;
  color:var(--gold);letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:1.3rem;
  animation:fadeIn .8s ease .1s both;
}
.hero-badge::before{content:'';display:block;width:28px;height:1px;background:var(--gold)}
.hero-h1{
  font-family:var(--ff-d);
  font-size:clamp(2.6rem,5vw,4.1rem);
  font-weight:600;line-height:1.08;
  color:var(--white);margin-bottom:1.4rem;
  animation:fadeUp .8s ease .2s both;
}
.hero-h1 em{color:var(--p300);font-style:italic}
.hero-since{
  display:inline-block;
  background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);
  color:var(--gold-lt);
  font-family:var(--ff-u);font-size:.75rem;letter-spacing:.1em;
  padding:.35rem .9rem;border-radius:20px;margin-bottom:1.5rem;
  animation:fadeUp .8s ease .3s both;
}
.hero-desc{
  font-family:var(--ff-s);font-size:.98rem;font-weight:300;
  color:rgba(255,255,255,.6);line-height:1.85;
  max-width:500px;margin-bottom:2.5rem;
  animation:fadeUp .8s ease .4s both;
}
.hero-btns{
  display:flex;gap:1rem;flex-wrap:wrap;
  animation:fadeUp .8s ease .55s both;
}
.btn-primary{
  font-family:var(--ff-u);font-size:.85rem;font-weight:500;
  background:var(--p500);color:var(--white);
  padding:.8rem 1.75rem;border-radius:4px;
  border:1.5px solid var(--p500);transition:all .2s;
}
.btn-primary:hover{background:var(--p600);border-color:var(--p600)}
.btn-gold{
  font-family:var(--ff-u);font-size:.85rem;font-weight:500;
  background:var(--gold);color:var(--p900);
  padding:.8rem 1.75rem;border-radius:4px;
  border:1.5px solid var(--gold);transition:all .2s;
}
.btn-gold:hover{background:var(--gold-lt)}
.btn-ghost{
  font-family:var(--ff-u);font-size:.85rem;
  background:transparent;color:rgba(255,255,255,.75);
  padding:.8rem 1.75rem;border-radius:4px;
  border:1px solid rgba(255,255,255,.22);transition:all .2s;
}
.btn-ghost:hover{border-color:rgba(255,255,255,.5);color:var(--white)}
.hero-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:2.25rem;
  animation:fadeIn .9s ease .65s both;
}
.hero-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
  margin-bottom:1.75rem;
}
.hero-stat{
  text-align:center;padding:.9rem .5rem;
  background:rgba(255,255,255,.04);border-radius:7px;
}
.stat-n{
  display:block;
  font-family:var(--ff-d);font-size:2.3rem;font-weight:700;
  color:var(--white);line-height:1;
}
.stat-l{
  font-family:var(--ff-u);font-size:.66rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-top:.4rem;
}
.hero-pills{display:flex;flex-wrap:wrap;gap:.5rem}
.pill{
  font-family:var(--ff-u);font-size:.68rem;
  padding:.28rem .8rem;border-radius:20px;
}
.pill-p{background:rgba(107,80,190,.25);color:var(--p300);border:1px solid rgba(107,80,190,.35)}
.pill-g{background:rgba(113, 76, 223, 0.375);color:var(--gold-lt);border:1px solid rgba(201,168,76,.25)}
.pill-w{background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.12)}
.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.45rem;
  font-family:var(--ff-u);font-size:.63rem;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.25);
}
.hero-scroll-line{width:1px;height:38px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);animation:pulseGold 2s infinite}

/* ═══════════════════════════════════════
   PRINCIPAL SECTION
═══════════════════════════════════════ */
.principal{background:var(--white)}
.principal-inner{
  display:grid;grid-template-columns:.85fr 1.15fr;
  gap:5rem;align-items:center;
}
.principal-card{
  background:var(--p900);border-radius:12px;
  padding:2.5rem;text-align:center;
  position:relative;overflow:hidden;
}
.principal-card::before{
  content:'';position:absolute;
  top:-80px;right:-80px;
  width:240px;height:240px;
  border:1px solid rgba(255,255,255,.06);border-radius:50%;
}
.principal-card::after{
  content:'';position:absolute;
  bottom:-60px;left:-60px;
  width:180px;height:180px;
  border:1px solid rgba(201,168,76,.1);border-radius:50%;
}
.principal-avatar{
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(135deg,var(--p600),var(--p400));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-d);font-size:2.8rem;font-weight:600;
  color:var(--white);margin:0 auto 1.25rem;
  border:3px solid rgba(255,255,255,.15);
  position:relative;z-index:1;
}
.principal-name{
  font-family:var(--ff-d);font-size:1.6rem;font-weight:600;
  color:var(--white);margin-bottom:.2rem;
  position:relative;z-index:1;
}
.principal-role{
  font-family:var(--ff-u);font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.3rem;
  position:relative;z-index:1;
}
.principal-since{
  font-family:var(--ff-u);font-size:.75rem;
  color:rgba(255,255,255,.45);margin-bottom:1.4rem;
  position:relative;z-index:1;
}
.principal-divider{
  width:40px;height:1px;background:rgba(255,255,255,.2);
  margin:.9rem auto 1.25rem;
}
.principal-creds{
  font-family:var(--ff-u);font-size:.76rem;
  color:rgba(255,255,255,.5);line-height:1.75;
  position:relative;z-index:1;
}
.notary-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(201,168,76,.18);border:1px solid rgba(201,168,76,.35);
  border-radius:6px;padding:.5rem 1rem;margin-top:1.25rem;
  position:relative;z-index:1;
}
.notary-badge-text{
  font-family:var(--ff-u);font-size:.72rem;font-weight:500;
  color:var(--gold);
}
.principal-content .eyebrow{color:var(--p500)}
.principal-content .section-title{color:var(--p900)}
.principal-text{
  font-family:var(--ff-s);font-size:.95rem;font-weight:300;
  color:#4A4060;line-height:1.9;margin-bottom:1.25rem;
}
.principal-highlights{
  display:grid;grid-template-columns:1fr 1fr;
  gap:.75rem;margin-top:1.75rem;
}
.highlight-item{
  background:var(--p100);border-radius:7px;
  padding:.9rem 1rem;border-left:3px solid var(--p500);
}
.hi-title{
  font-family:var(--ff-u);font-size:.78rem;font-weight:500;
  color:var(--p800);margin-bottom:.2rem;
}
.hi-desc{
  font-family:var(--ff-u);font-size:.7rem;
  color:var(--muted);line-height:1.5;
}

/* ═══════════════════════════════════════
   PRACTICE AREAS
═══════════════════════════════════════ */
.practice{background:var(--cream)}
.practice-head{
  text-align:center;margin-bottom:3.5rem;
}
.practice-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.pa-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:10px;padding:2rem 1.75rem;
  transition:all .25s;position:relative;overflow:hidden;
}
.pa-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:3px;
  background:linear-gradient(to right,var(--p500),var(--p400));
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.pa-card:hover{
  transform:translateY(-5px);
  box-shadow:0 14px 44px rgba(84,56,160,.12);
  border-color:var(--p200);
}
.pa-card:hover::before{transform:scaleX(1)}
.pa-card.featured{
  background:var(--p800);border-color:var(--p700);
}
.pa-card.featured::before{
  background:linear-gradient(to right,var(--gold),var(--gold-lt));
  transform:scaleX(1);
}
.pa-card.featured .pa-name{color:var(--white)}
.pa-card.featured .pa-desc{color:rgba(255,255,255,.6)}
.pa-card.featured .pa-icon-wrap{background:rgba(255,255,255,.1)}
.pa-card.featured .pa-tag{
  background:rgba(201,168,76,.2);color:var(--gold);
  border-color:rgba(201,168,76,.3);
}
.pa-icon-wrap{
  width:46px;height:46px;border-radius:8px;
  background:var(--p100);
  display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;margin-bottom:1.25rem;
}
.pa-name{
  font-family:var(--ff-d);font-size:1.2rem;font-weight:600;
  color:var(--p900);margin-bottom:.5rem;
}
.pa-desc{
  font-family:var(--ff-u);font-size:.78rem;
  color:var(--muted);line-height:1.65;margin-bottom:.9rem;
}
.pa-tag{
  display:inline-block;
  font-family:var(--ff-u);font-size:.65rem;
  padding:.22rem .7rem;border-radius:20px;
  background:var(--p100);color:var(--p600);
  border:1px solid var(--p200);
}
.pa-arrow{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--ff-u);font-size:.76rem;font-weight:500;
  color:var(--p500);margin-top:.75rem;
  transition:gap .2s;
}
.pa-card:hover .pa-arrow,.pa-card.featured .pa-arrow{gap:.7rem;color:var(--gold)}

/* ═══════════════════════════════════════
   NOTARY SECTION
═══════════════════════════════════════ */
.notary{
  background:var(--p800);position:relative;overflow:hidden;
}
.notary::before{
  content:'';position:absolute;
  top:-100px;right:-100px;
  width:400px;height:400px;
  border:1px solid rgba(255,255,255,.05);border-radius:50%;
  pointer-events:none;
}
.notary::after{
  content:'';position:absolute;
  bottom:-80px;left:-80px;
  width:300px;height:300px;
  border:1px solid rgba(201,168,76,.07);border-radius:50%;
  pointer-events:none;
}
.notary-inner{
  display:grid;grid-template-columns:1.2fr .8fr;
  gap:4rem;align-items:center;
  position:relative;z-index:1;
}
.notary .eyebrow{color:var(--gold)}
.notary .section-title{color:var(--white)}
.notary .section-title em{color:var(--p300)}
.notary-text{
  font-family:var(--ff-s);font-size:.95rem;font-weight:300;
  color:rgba(255,255,255,.62);line-height:1.85;margin-bottom:1.5rem;
}
.notary-services{
  list-style:none;display:flex;flex-direction:column;gap:.55rem;
}
.notary-services li{
  display:flex;align-items:center;gap:.75rem;
  font-family:var(--ff-u);font-size:.82rem;
  color:rgba(255,255,255,.72);
}
.notary-services li::before{
  content:'';display:block;width:6px;height:6px;
  border-radius:50%;background:var(--gold);flex-shrink:0;
}
.notary-stamp{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:2.5rem;text-align:center;
}
.notary-stamp-icon{
  font-size:3.5rem;margin-bottom:1rem;
  animation:pulseGold 3s infinite;
  display:block;
}
.notary-stamp-title{
  font-family:var(--ff-d);font-size:1.6rem;font-weight:600;
  color:var(--white);margin-bottom:.35rem;
}
.notary-stamp-sub{
  font-family:var(--ff-u);font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--gold);margin-bottom:0.25rem;
  
}
.notary-stamp-line{width:40px;height:1px;background:rgba(255,255,255,.2);margin:.75rem auto}
.notary-stamp-detail{
  font-family:var(--ff-u);font-size:.78rem;margin-bottom:1.25rem;
  color:rgba(255,255,255,.45);line-height:1.7;
}

/* ═══════════════════════════════════════
   PROPERTY SERVICES
═══════════════════════════════════════ */
.property{background:var(--white)}
.property-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:3rem;flex-wrap:wrap;gap:1rem;
}
.property-flow{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:0;margin-bottom:2.5rem;position:relative;
}
.property-flow::before{
  content:'';position:absolute;
  top:28px;left:10%;right:10%;height:2px;
  background:linear-gradient(to right,var(--p300),var(--p500),var(--gold),var(--p500),var(--p300));
  z-index:0;
}
.flow-step{
  display:flex;flex-direction:column;align-items:center;
  padding:0 .5rem;position:relative;z-index:1;
}
.flow-dot{
  width:56px;height:56px;border-radius:50%;
  background:var(--white);border:2.5px solid var(--p400);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:.9rem;
  transition:all .25s;
}
.flow-step:hover .flow-dot{background:var(--p600);border-color:var(--p600)}
.flow-label{
  font-family:var(--ff-u);font-size:.7rem;font-weight:500;
  color:var(--p800);text-align:center;line-height:1.4;
}
.property-services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;
}
.prop-service{
  background:var(--p100);border-radius:8px;
  padding:1.25rem;display:flex;gap:.85rem;
  align-items:flex-start;border:1px solid var(--p200);
  transition:all .2s;
}
.prop-service:hover{background:var(--white);border-color:var(--p400);box-shadow:0 4px 20px rgba(84,56,160,.08)}
.prop-service-icon{font-size:1.25rem;margin-top:.1rem;flex-shrink:0}
.prop-service-title{
  font-family:var(--ff-u);font-size:.82rem;font-weight:500;
  color:var(--p800);margin-bottom:.25rem;
}
.prop-service-desc{
  font-family:var(--ff-u);font-size:.73rem;
  color:var(--muted);line-height:1.55;
}

/* ═══════════════════════════════════════
   LEGAL TOOLS
═══════════════════════════════════════ */
.tools{background:var(--cream)}
.tools-head{text-align:center;margin-bottom:3rem}
.tools-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem;
  margin-bottom:2rem;
}
.tool-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:10px;padding:1.5rem 1.1rem;text-align:center;
  transition:all .25s;cursor:pointer;
}
.tool-card:hover{
  border-color:var(--p400);
  transform:translateY(-4px);
  box-shadow:0 10px 30px rgba(84,56,160,.1);
}
.tool-emoji{font-size:1.7rem;display:block;margin-bottom:.75rem}
.tool-name{
  font-family:var(--ff-d);font-size:1rem;font-weight:600;
  color:var(--p900);margin-bottom:.35rem;
}
.tool-desc{
  font-family:var(--ff-u);font-size:.69rem;
  color:var(--muted);line-height:1.5;
}
.tools-note{
  text-align:center;
  font-family:var(--ff-u);font-size:.78rem;
  color:var(--muted);
  background:var(--p100);border-radius:7px;
  padding:.75rem 1.5rem;border:1px solid var(--p200);
  display:inline-block;
}

/* ═══════════════════════════════════════
   TEAM
═══════════════════════════════════════ */
.team{background:var(--white)}
.team-head{text-align:center;margin-bottom:3.5rem}
.team-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.75rem;
}
.team-card{
  border-radius:10px;overflow:hidden;
  border:1px solid var(--border);
  transition:all .25s;
}
.team-card:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 44px rgba(84,56,160,.14);
  border-color:var(--p300);
}
.team-card.principal-card-team{border-top:3px solid var(--gold)}
.team-avatar-wrap{
  background:linear-gradient(145deg,var(--p800),var(--p600));
  padding:2.25rem 1.5rem;
  display:flex;flex-direction:column;align-items:center;gap:.9rem;
}
.team-avatar{
  width:80px;height:80px;border-radius:50%;
  background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-d);font-size:1.75rem;font-weight:600;
  color:var(--white);
}
.team-card.principal-card-team .team-avatar{
  background:rgba(201,168,76,.2);border-color:rgba(201,168,76,.4);
}
.team-body{padding:1.25rem}
.team-name{
  font-family:var(--ff-d);font-size:1.15rem;font-weight:600;
  color:var(--p900);margin-bottom:.2rem;
}
.team-role{
  font-family:var(--ff-u);font-size:.72rem;
  color:var(--p500);font-weight:500;margin-bottom:.35rem;
}
.team-since{
  font-family:var(--ff-u);font-size:.7rem;
  color:var(--muted);margin-bottom:.75rem;
}
.team-specs{
  list-style:none;display:flex;flex-direction:column;gap:.35rem;
  margin-bottom:.85rem;
}
.team-specs li{
  font-family:var(--ff-u);font-size:.7rem;color:var(--muted);
  display:flex;align-items:center;gap:.5rem;
}
.team-specs li::before{
  content:'';width:4px;height:4px;border-radius:50%;
  background:var(--p400);flex-shrink:0;
}
.team-email{
  display:flex;align-items:center;gap:.45rem;
  font-family:var(--ff-u);font-size:.7rem;color:var(--p500);
  word-break:break-all;
}

/* ═══════════════════════════════════════
   CONTACT
═══════════════════════════════════════ */
.contact{
  background:var(--p900);position:relative;overflow:hidden;
}
.contact::before{
  content:'';position:absolute;
  top:-120px;right:-120px;width:450px;height:450px;
  border:1px solid rgba(255,255,255,.04);border-radius:50%;
}
.contact-inner{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:4rem;align-items:start;
  position:relative;z-index:1;
}
.contact .eyebrow{color:var(--gold)}
.contact .section-title{color:var(--white)}
.contact .section-title em{color:var(--p300)}
.contact-desc{
  font-family:var(--ff-s);font-size:.92rem;font-weight:300;
  color:rgba(255,255,255,.55);line-height:1.85;margin-bottom:2rem;
}
.contact-items{
  display:flex;flex-direction:column;gap:1rem;
  margin-bottom:2rem;
}
.contact-item{
  display:flex;align-items:flex-start;gap:.9rem;
}
.c-icon{
  width:40px;height:40px;border-radius:7px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;margin-top:.1rem;
}
.c-label{
  font-family:var(--ff-u);font-size:.68rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:.2rem;
}
.c-val{
  font-family:var(--ff-u);font-size:.84rem;
  color:rgba(255,255,255,.8);line-height:1.55;
}
.c-val a:hover{color:var(--gold)}
.wa-btn{
  display:flex;align-items:center;gap:.75rem;
  background:var(--gold);color:var(--p900);
  border:none;border-radius:6px;
  padding:.9rem 1.75rem;
  font-family:var(--ff-u);font-size:.88rem;font-weight:500;
  transition:background .2s;width:fit-content;
}
.wa-btn:hover{background:var(--gold-lt)}
.contact-form-wrap{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:2rem;
}
.form-title{
  font-family:var(--ff-d);font-size:1.4rem;font-weight:600;
  color:var(--white);margin-bottom:1.5rem;
}
.form-group{margin-bottom:1rem}
.form-label{
  display:block;font-family:var(--ff-u);font-size:.73rem;
  font-weight:500;letter-spacing:.08em;
  color:rgba(255,255,255,.5);margin-bottom:.45rem;
}
.form-input,.form-select,.form-textarea{
  width:100%;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.15);
  border-radius:5px;padding:.7rem .9rem;
  font-family:var(--ff-u);font-size:.84rem;
  color:var(--white);outline:none;
  transition:border-color .2s;
}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(255,255,255,.25)}
.form-select option{background:var(--p800);color:var(--white)}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--p400);
  background:rgba(255,255,255,.09);
}
.form-textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.form-submit{
  width:100%;background:var(--p500);color:var(--white);
  border:none;border-radius:5px;padding:.85rem;
  font-family:var(--ff-u);font-size:.88rem;font-weight:500;
  transition:background .2s;margin-top:.25rem;
}
.form-submit:hover{background:var(--p600)}
.form-success{
  display:none;text-align:center;padding:2rem;
  font-family:var(--ff-u);font-size:.9rem;color:rgba(255,255,255,.75);
}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
footer{background:var(--p900);border-top:1px solid rgba(255,255,255,.06);padding:3.5rem 0 2rem}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;margin-bottom:2.5rem;
}
.footer-firm{
  font-family:var(--ff-d);font-size:1.3rem;font-weight:600;
  color:var(--white);margin-bottom:.25rem;
}
.footer-firm-sub{
  font-family:var(--ff-u);font-size:.63rem;letter-spacing:.13em;
  text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem;
}
.footer-about{
  font-family:var(--ff-u);font-size:.77rem;
  color:rgba(255,255,255,.38);line-height:1.7;
  max-width:290px;margin-bottom:1.1rem;
}
.footer-addr{
  font-family:var(--ff-u);font-size:.74rem;
  color:rgba(255,255,255,.32);line-height:1.7;
}
.footer-col-title{
  font-family:var(--ff-u);font-size:.68rem;font-weight:500;
  letter-spacing:.13em;text-transform:uppercase;
  color:rgba(255,255,255,.38);margin-bottom:1rem;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:.45rem}
.footer-links li a{
  font-family:var(--ff-u);font-size:.78rem;
  color:rgba(255,255,255,.45);transition:color .2s;
}
.footer-links li a:hover{color:var(--p300)}
.footer-divider{border:none;border-top:1px solid rgba(255,255,255,.07);margin-bottom:1.5rem}
.footer-bottom{
  display:flex;
}
.footer-copy{
  font-family:var(--ff-u);font-size:.7rem;
  color:rgba(255,255,255,.22);
}
.footer-disc{
  font-family:var(--ff-u);font-size:.67rem;
  color:rgba(255,255,255,.18);
  max-width:520px;line-height:1.6;
}

/* ═══════════════════════════════════════
   WHATSAPP FLOAT
═══════════════════════════════════════ */
.wa-float{
  position:fixed;bottom:2rem;right:2rem;z-index:400;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;border:none;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:transform .2s,box-shadow .2s;
  text-decoration:none;
}
.wa-float:hover{
  transform:scale(1.1);
  box-shadow:0 6px 28px rgba(37,211,102,.5);
}
.wa-tooltip{
  position:absolute;right:68px;top:50%;transform:translateY(-50%);
  background:var(--p900);color:var(--white);
  font-family:var(--ff-u);font-size:.75rem;
  padding:.4rem .85rem;border-radius:5px;
  white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.wa-float:hover .wa-tooltip{opacity:1}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr;padding: top 3px;rem}
  .hero-card{max-width:460px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .tools-grid{grid-template-columns:repeat(3,1fr)}
  .property-flow{grid-template-columns:repeat(3,1fr)}
  .property-flow::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links,.nav-wa{display:none}
  .hamburger{display:flex}
  .principal-inner,.notary-inner,.contact-inner{grid-template-columns:1fr;gap:2.5rem}
  .practice-grid{grid-template-columns:1fr 1fr}
  .property-services-grid{grid-template-columns:1fr}
  .tools-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-disc{text-align:left}
  .form-row{grid-template-columns:1fr}
  .property-flow{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .practice-grid,.team-grid{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:1fr 1fr}
  .hero-btns{flex-direction:column}
  .principal-highlights{grid-template-columns:1fr}
  .tools-grid{grid-template-columns:1fr 1fr}
}