@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600;9..144,700&family=Source+Sans+3:wght@400;500;600;700&family=Courier+Prime:wght@400;700&display=swap');

:root{
  --navy: #10203D;
  --navy-deep: #0A1730;
  --navy-soft: #1B2E52;
  --gold: #C9A227;
  --gold-light: #E4C766;
  --gold-deep: #8C6A1F;
  --cream: #F8F5EE;
  --white: #FFFFFF;
  --ink: #1B2233;
  --ink-soft: #55607A;
  --line: rgba(16,32,61,0.12);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background: var(--cream);
  color: var(--ink);
  font-family:'Source Sans 3', sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:'Fraunces', serif;
  color: var(--navy);
  font-weight:500;
  line-height:1.15;
  letter-spacing:-0.01em;
}
.eyebrow{
  font-family:'Courier Prime', monospace;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color: var(--gold-deep);
  font-weight:700;
  display:block;
  margin-bottom:14px;
}
.eyebrow.on-dark{ color: var(--gold-light); }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.wrap{ max-width:1180px; margin:0 auto; padding:0 32px; }
section{ padding:96px 0; }

.reveal{ opacity:0; transform:translateY(18px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ---------- header ---------- */
header{
  position:sticky; top:0; z-index:50;
  background:rgba(248,245,238,0.94);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--gold);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:4px 32px;
  max-width:1180px; margin:0 auto;
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand img{ height:128px; width:auto; }
nav{ display:flex; align-items:center; gap:32px; }
nav a{
  font-size:0.92rem; font-weight:600; color:var(--ink-soft);
  position:relative; padding:4px 0;
  transition:color 0.18s ease;
}
nav a::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:2px;
  background:var(--gold); transition:width 0.2s ease;
}
nav a:hover{ color:var(--navy); }
nav a:hover::after, nav a.active::after{ width:100%; }
nav a.active{ color:var(--navy); border-bottom:none; }
.header-cta{ display:flex; align-items:center; gap:18px; }
.phone-link{ font-family:'Courier Prime', monospace; font-size:0.86rem; font-weight:700; color:var(--navy); white-space:nowrap; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'Source Sans 3', sans-serif;
  font-weight:700; font-size:0.95rem;
  padding:14px 28px;
  border-radius:2px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
  white-space:nowrap;
}
.btn:active{ transform: scale(0.96); }
.btn-gold{ background:var(--gold); color:var(--navy-deep); box-shadow:0 3px 0 var(--gold-deep); }
.btn-gold:hover{ box-shadow:0 6px 16px rgba(201,162,39,0.4); transform:translateY(-2px); }
.btn-gold:active{ transform: scale(0.96); box-shadow:0 1px 0 var(--gold-deep); }
.btn-navy{ background:var(--navy); color:var(--gold-light); box-shadow:0 3px 0 var(--navy-deep); }
.btn-navy:hover{ box-shadow:0 6px 16px rgba(16,32,61,0.4); transform:translateY(-2px); }
.btn-outline{ background:transparent; border-color:var(--navy); color:var(--navy); }
.btn-outline:hover{ background:var(--navy); color:var(--cream); transform:translateY(-2px); }
.btn-outline.on-dark{ border-color:var(--gold-light); color:var(--gold-light); }
.btn-outline.on-dark:hover{ background:var(--gold-light); color:var(--navy-deep); transform:translateY(-2px); }
.btn-small{ padding:10px 20px; font-size:0.84rem; }

/* ---------- hero (home) ---------- */
.hero{
  padding:140px 0 110px;
  overflow:hidden;
  background-image:
    linear-gradient(to right, var(--cream) 0%, rgba(248,245,238,0.94) 38%, rgba(248,245,238,0.55) 58%, rgba(248,245,238,0.1) 75%),
    url('assets/hero-banner.jpg');
  background-size: cover;
  background-position: center right;
  background-repeat: no-repeat;
}
.hero .wrap{ display:block; }
.hero-content{ max-width:600px; }
.hero h1{ font-size:clamp(2.2rem, 4vw, 3.3rem); margin:0 0 22px; }
.hero p.lede{ font-size:1.1rem; color:var(--ink-soft); max-width:52ch; margin-bottom:34px; }
.hero-actions{ display:flex; align-items:center; gap:28px; flex-wrap:wrap; }
.call-inline{ display:flex; align-items:center; gap:9px; font-weight:700; font-size:0.95rem; border-bottom:1.5px solid var(--navy); padding-bottom:2px; transition:color 0.18s ease, border-color 0.18s ease; }
.call-inline:hover{ color:var(--gold-deep); border-color:var(--gold-deep); }

.hero-medallion{ display:flex; justify-content:center; align-items:center; position:relative; }
.medallion-ring{
  width:100%; max-width:420px; aspect-ratio:1/1;
  border-radius:50%;
  background:var(--navy);
  display:flex; align-items:center; justify-content:center;
  position:relative;
  box-shadow:0 20px 50px rgba(16,32,61,0.25);
  animation:med-in 1s ease;
}
@keyframes med-in{ from{opacity:0; transform:scale(0.85);} to{opacity:1; transform:scale(1);} }
@media (prefers-reduced-motion: reduce){ .medallion-ring{ animation:none; } }
.medallion-ring::before{
  content:""; position:absolute; inset:14px; border-radius:50%;
  border:1.5px dashed var(--gold); opacity:0.6;
}
.medallion-inner{
  width:88%; background:var(--cream); border-radius:50%;
  aspect-ratio:1/1; display:flex; align-items:center; justify-content:center;
  padding:4%;
}
.medallion-inner img{ width:100%; height:100%; object-fit:contain; }
.medallion-caption{
  position:absolute; bottom:-14px; left:50%; transform:translateX(-50%);
  background:var(--gold); color:var(--navy-deep);
  font-family:'Courier Prime', monospace; font-size:0.7rem; letter-spacing:0.1em;
  padding:6px 16px; text-transform:uppercase; white-space:nowrap;
  box-shadow:0 4px 10px rgba(0,0,0,0.15);
}

/* ---------- trust strip ---------- */
.trust{
  background:var(--navy-deep);
  border-top:1px solid var(--gold); border-bottom:1px solid var(--gold);
  background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0px, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 28px);
}
.trust .wrap{ display:grid; grid-template-columns:repeat(2,1fr); padding:48px 32px; }
.trust-item{ text-align:center; border-right:1px solid rgba(228,199,102,0.28); padding:0 20px; }
.trust-item:last-child{ border-right:none; }
.trust-item .num{ font-family:'Fraunces', serif; font-size:2.6rem; color:var(--gold-light); display:block; line-height:1; margin-bottom:8px; }
.trust-item .label{ font-family:'Courier Prime', monospace; font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(248,245,238,0.78); }

/* ---------- section heads ---------- */
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head h2{ font-size:clamp(1.7rem, 3vw, 2.3rem); }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* ---------- icon badges ---------- */
.icon-badge{
  width:52px; height:52px;
  border-radius:50%;
  background:var(--navy);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px;
  flex-shrink:0;
}
.icon-badge svg{ width:24px; height:24px; stroke:var(--gold-light); }
.icon-badge.gold{ background:var(--gold); }
.icon-badge.gold svg{ stroke:var(--navy-deep); }
.icon-inline{ width:18px; height:18px; stroke:currentColor; flex-shrink:0; }
.icon-row{ display:flex; align-items:flex-start; gap:14px; }
.icon-row .icon-badge{ margin-bottom:0; width:44px; height:44px; }
.icon-row .icon-badge svg{ width:20px; height:20px; }

/* ---------- why choose us ---------- */
.why{ background:var(--white); }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.why-card{ background:var(--cream); border:1px solid var(--line); padding:34px 30px; position:relative; box-shadow:0 3px 14px rgba(16,32,61,0.06); transition:box-shadow 0.2s ease, transform 0.2s ease; }
.why-card:hover{ box-shadow:0 8px 22px rgba(16,32,61,0.1); transform:translateY(-3px); }
.why-card::before{ content:""; position:absolute; top:0; left:0; width:34px; height:6px; background:var(--gold); }
.why-card h3{ font-size:1.2rem; margin:10px 0 12px; }
.why-card p{ color:var(--ink-soft); font-size:0.98rem; }

/* ---------- practice ledger ---------- */
.practice{
  background:var(--navy); color:var(--cream);
  background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.025) 0px, rgba(255,255,255,0.025) 1px, transparent 1px, transparent 28px);
}
.practice .section-head h2{ color:var(--cream); }
.practice .section-head p{ color:rgba(248,245,238,0.75); margin-top:12px; }
.ledger{ border-top:1px solid rgba(228,199,102,0.35); }
.ledger-entry{ display:grid; grid-template-columns:56px 90px 1fr auto; gap:20px; padding:32px 0; border-bottom:1px solid rgba(228,199,102,0.35); align-items:center; transition:background 0.2s ease; }
.ledger-entry:hover{ background:rgba(255,255,255,0.02); }
.ledger-entry .icon-badge{ margin-bottom:0; }
.ledger-entry .entry-no{ font-family:'Courier Prime', monospace; font-size:0.85rem; color:var(--gold-light); letter-spacing:0.08em; }
.ledger-entry h3{ color:var(--cream); font-size:1.35rem; margin-bottom:10px; position:relative; display:inline-block; }
.ledger-entry h3::after{ content:""; position:absolute; left:0; bottom:-6px; width:46px; height:2px; background:var(--gold); }
.ledger-entry p{ color:rgba(248,245,238,0.8); max-width:56ch; }
.ledger-entry .entry-link{ font-family:'Courier Prime', monospace; font-size:0.78rem; color:var(--gold-light); border:1px solid var(--gold); padding:8px 14px; white-space:nowrap; transition:background 0.18s ease, color 0.18s ease, transform 0.18s ease; }
.ledger-entry .entry-link:hover{ background:var(--gold); color:var(--navy-deep); transform:translateY(-2px); }
.practice-cta{ text-align:center; margin-top:44px; }

/* ---------- team ---------- */
.team{ background:var(--cream); }
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.avatar{ width:100%; aspect-ratio:1/1; background:var(--white); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; margin-bottom:18px; position:relative; overflow:hidden; }
.avatar img{ transition:transform 0.4s ease; }
.team-card:hover .avatar img{ transform:scale(1.04); }
.avatar .mono{ font-family:'Fraunces', serif; font-size:2.6rem; color:var(--gold-deep); }
.avatar .replace-note{ position:absolute; bottom:0; left:0; right:0; background:rgba(16,32,61,0.82); color:var(--cream); font-family:'Courier Prime', monospace; font-size:0.62rem; letter-spacing:0.05em; text-align:center; padding:5px 4px; }
.team-card h3{ font-size:1.3rem; margin-bottom:4px; }
.team-card .role{ font-family:'Courier Prime', monospace; font-size:0.72rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:10px; display:block; }
.team-card p{ color:var(--ink-soft); font-size:0.94rem; }
.qualifications{ display:flex; flex-wrap:wrap; gap:6px; margin:12px 0; }
.qual-tag{ font-family:'Courier Prime', monospace; font-size:0.68rem; letter-spacing:0.03em; color:var(--navy); background:var(--white); border:1px solid var(--line); padding:4px 9px; }
.credential-note{ font-size:0.88rem; color:var(--ink-soft); margin-top:10px; padding-top:10px; border-top:1px solid var(--line); }
.linkedin-link{ display:inline-flex; align-items:center; gap:6px; margin-top:10px; font-family:'Courier Prime', monospace; font-size:0.78rem; color:var(--navy); border-bottom:1px solid var(--navy); padding-bottom:2px; }
.linkedin-link:hover{ color:var(--gold-deep); border-color:var(--gold-deep); }
.linkedin-link svg{ width:15px; height:15px; }

/* ---------- contact mini / full ---------- */
.contact{ background:var(--white); }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contact-details p{ margin-bottom:14px; }
.contact-details .label{ font-family:'Courier Prime', monospace; font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold-deep); display:block; margin-bottom:3px; }
.contact-details .val{ font-size:1.05rem; }
.contact-actions{ background:var(--cream); border:1px solid var(--line); padding:36px; box-shadow:0 4px 18px rgba(16,32,61,0.07); }
.contact-actions h3{ font-size:1.25rem; margin-bottom:14px; }
.contact-actions p{ color:var(--ink-soft); margin-bottom:24px; }
.contact-actions .btn{ width:100%; justify-content:center; margin-bottom:12px; }
.map-placeholder{ background:var(--cream); border:1.5px dashed var(--line); padding:60px 20px; text-align:center; color:var(--ink-soft); font-family:'Courier Prime', monospace; font-size:0.8rem; margin-top:24px; }

/* ---------- footer ---------- */
footer{ background:var(--navy-deep); color:rgba(248,245,238,0.75); padding:64px 0 28px; border-top:3px solid var(--gold); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; margin-bottom:48px; }
footer h4{ color:var(--cream); font-size:0.85rem; margin-bottom:16px; font-family:'Courier Prime', monospace; letter-spacing:0.06em; text-transform:uppercase; }
.footer-brand img{ height:110px; margin-bottom:14px; }
footer p, footer a{ font-size:0.9rem; line-height:1.9; color:rgba(248,245,238,0.65); }
footer a:hover{ color:var(--gold-light); }
footer ul{ list-style:none; }
.footer-bottom{ border-top:1px solid rgba(248,245,238,0.15); padding-top:24px; font-size:0.8rem; color:rgba(248,245,238,0.5); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }

/* ---------- inner page hero / breadcrumb ---------- */
.page-hero{ background:var(--navy); color:var(--cream); padding:80px 0 72px; }
.page-hero .wrap{ max-width:900px; }
.page-hero h1{ color:var(--cream); font-size:clamp(2rem,3.6vw,2.8rem); margin-top:12px; }
.page-hero p{ color:rgba(248,245,238,0.8); margin-top:16px; max-width:65ch; font-size:1.05rem; }
.breadcrumb{ font-family:'Courier Prime', monospace; font-size:0.75rem; letter-spacing:0.05em; color:rgba(248,245,238,0.6); }
.breadcrumb a:hover{ color:var(--gold-light); }

/* ---------- content pages ---------- */
.content-section{ background:var(--white); }
.content-section .prose{ max-width:760px; }
.prose h2{ margin:44px 0 16px; font-size:1.65rem; }
.prose h2:first-child{ margin-top:0; }
.prose p{ color:var(--ink-soft); margin-bottom:16px; }
.prose ul{ margin:0 0 20px 22px; color:var(--ink-soft); }
.prose li{ margin-bottom:8px; }

.related-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; margin-top:24px; }
.related-card{ background:var(--cream); border:1px solid var(--line); padding:26px; box-shadow:0 3px 14px rgba(16,32,61,0.06); transition:transform 0.2s ease, box-shadow 0.2s ease; }
.related-card:hover{ transform:translateY(-3px); box-shadow:0 8px 22px rgba(16,32,61,0.1); }
.related-card .eyebrow{ margin-bottom:8px; }
.related-card h3{ font-size:1.15rem; margin-bottom:10px; }
.related-card p{ color:var(--ink-soft); font-size:0.92rem; margin-bottom:14px; }

.cta-band{
  background:var(--navy); color:var(--cream); padding:80px 0; text-align:center;
  background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0px, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 28px);
}
.cta-band h2{ color:var(--cream); margin-bottom:14px; }
.cta-band p{ color:rgba(248,245,238,0.75); max-width:52ch; margin:0 auto 30px; }
.cta-band .actions{ display:flex; justify-content:center; gap:18px; flex-wrap:wrap; }

/* ---------- FAQ accordion ---------- */
.faq{ background:var(--white); }
.faq-list{ max-width:780px; }
.faq-item{ border:1px solid var(--line); background:var(--cream); margin-bottom:16px; box-shadow:0 2px 10px rgba(16,32,61,0.05); transition:box-shadow 0.2s ease; }
.faq-item:hover{ box-shadow:0 4px 16px rgba(16,32,61,0.09); }
.faq-item summary{
  cursor:pointer; list-style:none;
  padding:20px 24px;
  font-family:'Fraunces', serif; font-weight:500; font-size:1.05rem;
  color:var(--navy);
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:"+"; font-family:'Source Sans 3',sans-serif; font-size:1.4rem; color:var(--gold-deep); flex-shrink:0;
}
.faq-item[open] summary::after{ content:"−"; }
.faq-item .faq-answer{ padding:0 24px 20px; color:var(--ink-soft); }

/* ---------- map embed ---------- */
.map-embed{ width:100%; height:280px; border:0; margin-top:24px; filter:grayscale(15%); border-radius:4px; }

/* ---------- article date ---------- */
.article-date{ font-family:'Courier Prime', monospace; font-size:0.78rem; color:var(--gold-deep); }

/* ---------- language switcher ---------- */
.lang-switch{ display:flex; gap:0; font-family:'Courier Prime', monospace; font-size:0.78rem; font-weight:700; border:1.5px solid var(--navy); border-radius:20px; overflow:hidden; }
.lang-switch a{ padding:8px 16px; color:var(--navy); transition:background 0.15s ease, color 0.15s ease; }
.lang-switch a.active{ background:var(--navy); color:var(--gold-light); }
.lang-switch a:not(.active):hover{ background:var(--cream); }

.city-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:24px; }
.city-card{ background:var(--cream); border:1px solid var(--line); padding:22px 24px; }
.city-card h3{ font-size:1.05rem; margin-bottom:6px; }
.city-card a{ font-family:'Courier Prime', monospace; font-size:0.78rem; color:var(--gold-deep); }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero{
    padding:64px 0 56px;
    background-image:
      linear-gradient(to bottom, var(--cream) 0%, rgba(248,245,238,0.92) 55%, rgba(248,245,238,0.7) 100%),
      url('assets/hero-banner.jpg');
    background-position: bottom right;
  }
  .hero-content{ max-width:100%; }
  .why-grid, .team-grid, .related-grid, .city-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; gap:36px; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .trust .wrap{ grid-template-columns:1fr; gap:24px; }
  .trust-item{ border-right:none; border-bottom:1px solid rgba(228,199,102,0.28); padding-bottom:20px; }
  .trust-item:last-child{ border-bottom:none; padding-bottom:0; }
  nav{ display:none; }
  .header-cta .phone-link{ display:none; }
  .ledger-entry{ grid-template-columns:1fr; gap:10px; }
  .brand img{ height:64px; }
}
@media (max-width:600px){
  section{ padding:60px 0; }
  .wrap{ padding:0 20px; }
  .footer-grid{ grid-template-columns:1fr; }
}
