/* =========================================================================
   Immigration Solutions Law Group, PLLC
   Design system — navy / antique gold / cream, engraved classical serif.
   Signature motif: the fluted column (three founding partners = three pillars)
   ========================================================================= */

:root{
  /* Palette sampled from the firm logo */
  --navy:        #0F1D37;   /* deep pillar navy */
  --navy-700:    #1B2B4B;
  --navy-500:    #2C3F63;
  --gold:        #A67C45;   /* antique gold of the serif "S" */
  --gold-bright: #C2A05A;
  --gold-soft:   #E7D9BE;
  --cream:       #F8F3EF;   /* exact logo background */
  --cream-2:     #F2EAE0;
  --paper:       #FFFFFF;
  --ink:         #14213A;   /* body text */
  --ink-soft:    #4A5468;
  --line:        #E2D8CB;   /* hairline rules */
  --line-strong: #CDBFA9;

  --maxw: 1180px;
  --gutter: clamp(20px, 5vw, 64px);

  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --shadow-sm: 0 1px 2px rgba(15,29,55,.06), 0 2px 8px rgba(15,29,55,.05);
  --shadow-md: 0 12px 40px rgba(15,29,55,.10);
  --radius: 4px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--navy); text-decoration:none; }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; color:var(--navy); margin:0; line-height:1.08; letter-spacing:.005em; }
h1{ font-size:clamp(2.6rem, 6vw, 4.6rem); font-weight:500; }
h2{ font-size:clamp(2rem, 4vw, 3rem); }
h3{ font-size:clamp(1.4rem, 2.2vw, 1.85rem); }
p{ margin:0 0 1.1em; }
strong{ font-weight:600; }

.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 1.1rem;
  display:inline-block;
}
.lede{ font-size:clamp(1.12rem,1.6vw,1.32rem); color:var(--ink-soft); line-height:1.6; }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px, 9vw, 130px); }
.section--tight{ padding-block:clamp(48px,6vw,84px); }
.section--navy{ background:var(--navy); color:#E9EDF4; }
.section--navy h1,.section--navy h2,.section--navy h3{ color:#fff; }
.section--cream2{ background:var(--cream-2); }

/* ---------- The fluted-column motif (signature element) ---------- */
.flutes{ display:inline-flex; gap:5px; height:var(--h,34px); align-items:stretch; }
.flutes i{ width:2px; background:var(--navy); border-radius:2px; opacity:.9; }
.flutes i:nth-child(2){ background:var(--gold); height:auto; }
.flutes--center{ justify-content:center; }
.rule-gold{ height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); border:0; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--navy); --fg:#fff; --bd:var(--navy);
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--sans); font-weight:600; font-size:.93rem;
  letter-spacing:.04em;
  padding:.92em 1.7em; border-radius:var(--radius);
  background:var(--bg); color:var(--fg); border:1.5px solid var(--bd);
  cursor:pointer; transition:transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  text-align:center;
}
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn--gold{ --bg:var(--gold); --bd:var(--gold); --fg:#fff; }
.btn--gold:hover{ --bg:var(--gold-bright); --bd:var(--gold-bright); }
.btn--ghost{ --bg:transparent; --fg:var(--navy); --bd:var(--line-strong); }
.btn--ghost:hover{ --bg:var(--navy); --fg:#fff; --bd:var(--navy); }
.btn--ghost-light{ --bg:transparent; --fg:#fff; --bd:rgba(255,255,255,.4); }
.btn--ghost-light:hover{ --bg:#fff; --fg:var(--navy); --bd:#fff; }
.btn--lg{ padding:1.05em 2em; font-size:1rem; }

.linklike{ color:var(--gold); font-weight:600; font-size:.92rem; letter-spacing:.04em; display:inline-flex; align-items:center; gap:.4em; }
.linklike:hover{ color:var(--navy); }
.linklike .arr{ transition:transform .2s ease; }
.linklike:hover .arr{ transform:translateX(4px); }

/* ============================ HEADER ============================ */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(248,243,239,.92);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; gap:28px; height:84px; }
.brand{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.brand img{ height:54px; width:auto; }
.brand .brand-text{ font-family:var(--serif); line-height:1; }
.brand .brand-text b{ display:block; font-weight:600; font-size:1.06rem; letter-spacing:.04em; color:var(--navy); text-transform:uppercase; }
.brand .brand-text span{ display:block; font-family:var(--sans); font-weight:600; font-size:.6rem; letter-spacing:.32em; color:var(--gold); text-transform:uppercase; margin-top:3px; }
.nav-links{ display:flex; align-items:center; gap:26px; margin-left:auto; }
.nav-links a{ font-family:var(--sans); font-weight:600; font-size:.9rem; color:var(--navy); letter-spacing:.01em; position:relative; padding:6px 0; }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:2px; background:var(--gold); transition:right .25s ease; }
.nav-links a:hover::after, .nav-links a.active::after{ right:0; }
.nav-actions{ display:flex; align-items:center; gap:14px; }

/* language toggle */
.lang-toggle{
  display:inline-flex; border:1.5px solid var(--line-strong); border-radius:999px; overflow:hidden;
  font-family:var(--sans); font-weight:700; font-size:.74rem; letter-spacing:.06em;
}
.lang-toggle button{
  border:0; background:transparent; cursor:pointer; padding:.42em .8em; color:var(--ink-soft);
  transition:background .2s,color .2s;
}
.lang-toggle button[aria-pressed="true"]{ background:var(--navy); color:#fff; }

.hamburger{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.hamburger span{ display:block; width:24px; height:2px; background:var(--navy); margin:5px 0; transition:.25s; }

/* mobile nav drawer */
.mobile-nav{ display:none; }

/* ============================ HERO ============================ */
.hero{ position:relative; overflow:hidden; background:
    radial-gradient(120% 90% at 85% -10%, rgba(166,124,69,.10), transparent 60%),
    var(--cream); }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:center;
  padding-block:clamp(56px,8vw,108px); }
.hero h1{ margin:.1em 0 .35em; }
.hero h1 em{ font-style:italic; color:var(--gold); }
.hero .lede{ max-width:42ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2rem; }
.hero-meta{ margin-top:2.4rem; display:flex; gap:30px; flex-wrap:wrap; }
.hero-meta .stat b{ font-family:var(--serif); font-size:2rem; color:var(--navy); display:block; line-height:1; }
.hero-meta .stat span{ font-size:.82rem; color:var(--ink-soft); letter-spacing:.02em; }

/* Hero column visual */
.hero-column{ position:relative; min-height:420px; display:flex; align-items:center; justify-content:center; }
.col-art{ position:relative; width:min(360px,80%); aspect-ratio:3/4.2; }
.col-art .cap, .col-art .base{ position:absolute; left:50%; transform:translateX(-50%); background:var(--navy); border-radius:3px; }
.col-art .cap{ top:0; width:74%; height:7%; box-shadow:0 6px 0 -2px var(--cream),0 9px 0 -2px var(--navy); }
.col-art .base{ bottom:0; width:84%; height:8%; box-shadow:0 -6px 0 -2px var(--cream),0 -9px 0 -2px var(--navy); }
.col-art .shaft{ position:absolute; left:50%; top:9%; bottom:10%; transform:translateX(-50%); width:62%;
  display:flex; gap:7px; justify-content:center; }
.col-art .shaft i{ flex:1; background:linear-gradient(180deg,var(--navy),var(--navy-700)); border-radius:3px; }
.col-art .shaft i:nth-child(3){ background:linear-gradient(180deg,var(--gold),var(--gold) 60%, #8f6a3a); }
.col-art .scales{ position:absolute; inset:0; margin:auto; width:46%; opacity:.16; }
.hero-portraits{ position:absolute; inset:0; display:none; }

/* ============================ GENERIC SECTION HEAD ============================ */
.sec-head{ max-width:62ch; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head .eyebrow{ }

/* ============================ STORY ============================ */
.story-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.story-grid .body p{ color:var(--ink-soft); }
.pull{ font-family:var(--serif); font-size:clamp(1.5rem,2.4vw,2.1rem); font-style:italic; color:var(--navy); line-height:1.25;
  border-left:3px solid var(--gold); padding-left:1.1em; }

/* ============================ PILLARS (why us) ============================ */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; }
.pillar{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:38px 30px;
  position:relative; transition:transform .2s ease, box-shadow .2s ease; }
.pillar:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.pillar .num{ font-family:var(--serif); font-size:1rem; color:var(--gold); letter-spacing:.1em; }
.pillar h3{ margin:.5rem 0 .5rem; }
.pillar p{ color:var(--ink-soft); font-size:1rem; margin:0; }
.pillar::before{ content:""; position:absolute; left:0; top:30px; bottom:30px; width:3px; background:var(--gold); border-radius:3px; opacity:0; transition:opacity .2s; }
.pillar:hover::before{ opacity:1; }

/* ============================ PRACTICE AREAS ============================ */
.practice-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:54px; }
.pcard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; }
.pcard .pcard-top{ background:var(--navy); color:#fff; padding:26px 28px; }
.pcard .pcard-top .kicker{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-bright); }
.pcard .pcard-top h3{ color:#fff; margin-top:.4rem; }
.pcard ul{ list-style:none; margin:0; padding:24px 28px; }
.pcard li{ padding:9px 0; border-bottom:1px solid var(--line); font-size:1rem; color:var(--ink-soft); display:flex; gap:.6em; }
.pcard li:last-child{ border-bottom:0; }
.pcard li::before{ content:""; flex:0 0 7px; height:7px; margin-top:.55em; background:var(--gold); border-radius:50%; }

/* ============================ ATTORNEYS ============================ */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:54px; }
.tcard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease; }
.tcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.tcard .photo{ aspect-ratio:4/5; background:var(--cream-2); overflow:hidden; }
.tcard .photo img{ width:100%; height:100%; object-fit:cover; object-position:center 22%; }
.tcard .tinfo{ padding:26px 26px 30px; }
.tcard .tinfo h3{ margin-bottom:.1rem; }
.tcard .role{ color:var(--gold); font-weight:700; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; }
.tcard .tags{ display:flex; flex-wrap:wrap; gap:7px; margin:16px 0 18px; }
.tcard .tags span{ font-size:.74rem; background:var(--cream-2); color:var(--navy-700); padding:.32em .7em; border-radius:999px; border:1px solid var(--line); }

/* full bio layout (attorneys page) */
.bio{ display:grid; grid-template-columns:340px 1fr; gap:clamp(32px,5vw,68px); align-items:start; padding-block:clamp(48px,7vw,90px); border-bottom:1px solid var(--line); }
.bio:last-child{ border-bottom:0; }
.bio .bio-photo{ position:sticky; top:108px; }
.bio .bio-photo img{ width:100%; border-radius:var(--radius); border:1px solid var(--line); }
.bio .bio-photo .namecard{ margin-top:18px; }
.bio .role{ color:var(--gold); font-weight:700; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; }
.bio h2{ margin:.1em 0; }
.bio .bio-body p{ color:var(--ink-soft); }
.bio .credlist{ list-style:none; padding:0; margin:18px 0 0; border-top:1px solid var(--line); }
.bio .credlist li{ display:flex; gap:.8em; padding:11px 0; border-bottom:1px solid var(--line); font-size:.98rem; }
.bio .credlist li b{ flex:0 0 120px; color:var(--navy); font-weight:600; }
.bio .tags{ display:flex; flex-wrap:wrap; gap:8px; margin:6px 0 20px; }
.bio .tags span{ font-size:.78rem; background:var(--cream-2); color:var(--navy-700); padding:.4em .8em; border-radius:999px; border:1px solid var(--line); }

/* ============================ CTA BAND ============================ */
.cta-band{ background:var(--navy); color:#fff; text-align:center; }
.cta-band h2{ color:#fff; max-width:20ch; margin-inline:auto; }
.cta-band .lede{ color:#C9D2E0; max-width:54ch; margin:1rem auto 2rem; }
.cta-band .hero-cta{ justify-content:center; }

/* ============================ FORMS ============================ */
.form-shell{ display:grid; grid-template-columns:1fr; gap:0; }
.form-card{ background:var(--paper); border:1px solid var(--line); border-radius:6px; box-shadow:var(--shadow-sm); }
.form-section{ padding:clamp(24px,3vw,40px); border-bottom:1px solid var(--line); }
.form-section:last-child{ border-bottom:0; }
.form-section > .step{ display:flex; align-items:center; gap:14px; margin-bottom:6px; }
.form-section .step .dot{ width:30px; height:30px; flex:0 0 30px; border-radius:50%; background:var(--navy); color:#fff; font-family:var(--serif); font-weight:600; display:grid; place-items:center; font-size:1rem; }
.form-section .step h3{ font-size:1.3rem; }
.form-section .step-sub{ color:var(--ink-soft); font-size:.96rem; margin:0 0 22px 44px; }

.field-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px 20px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field.col-2{ grid-column:span 2; }
.field label{ font-size:.86rem; font-weight:600; color:var(--navy); letter-spacing:.01em; }
.field label .req{ color:var(--gold); }
.field .hint{ font-size:.78rem; color:var(--ink-soft); font-weight:400; }
.field input, .field select, .field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--ink);
  padding:.72em .85em; border:1.5px solid var(--line-strong); border-radius:var(--radius);
  background:var(--cream); transition:border-color .2s, box-shadow .2s; width:100%;
}
.field textarea{ min-height:120px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(166,124,69,.16); background:#fff;
}
.field input.invalid, .field select.invalid, .field textarea.invalid{ border-color:#b3261e; box-shadow:0 0 0 3px rgba(179,38,30,.12); }
.err-msg{ color:#b3261e; font-size:.78rem; display:none; }
.err-msg.show{ display:block; }

.choice-row{ display:flex; flex-wrap:wrap; gap:10px; }
.choice{ position:relative; }
.choice input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.choice span{ display:inline-block; padding:.6em 1.05em; border:1.5px solid var(--line-strong); border-radius:999px; font-size:.9rem; font-weight:600; color:var(--navy-700); cursor:pointer; transition:.18s; background:var(--cream); }
.choice input:checked + span{ background:var(--navy); color:#fff; border-color:var(--navy); }
.choice input:focus-visible + span{ box-shadow:0 0 0 3px rgba(166,124,69,.3); }

.checkrow{ display:flex; gap:12px; align-items:flex-start; margin:12px 0; }
.checkrow input[type=checkbox]{ width:20px; height:20px; flex:0 0 20px; margin-top:3px; accent-color:var(--navy); cursor:pointer; }
.checkrow label{ font-size:.92rem; color:var(--ink-soft); font-weight:400; line-height:1.5; }

.conditional{ display:none; margin-top:18px; padding:20px; background:var(--cream-2); border:1px dashed var(--line-strong); border-radius:var(--radius); }
.conditional.show{ display:block; animation:fade .25s ease; }
@keyframes fade{ from{opacity:0; transform:translateY(-4px);} to{opacity:1; transform:none;} }

.form-foot{ padding:clamp(24px,3vw,40px); display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.disclaimer{ background:var(--cream-2); border:1px solid var(--line); border-radius:var(--radius); padding:18px 22px; font-size:.84rem; color:var(--ink-soft); line-height:1.55; }
.disclaimer b{ color:var(--navy); }

/* form success */
.form-success{ display:none; text-align:center; padding:64px 30px; }
.form-success.show{ display:block; animation:fade .3s ease; }
.form-success .check{ width:64px; height:64px; margin:0 auto 22px; border-radius:50%; background:var(--gold); display:grid; place-items:center; color:#fff; }

/* hubspot embed placeholder */
.embed-frame{ border:1.5px dashed var(--line-strong); border-radius:6px; background:var(--cream-2);
  min-height:560px; display:grid; place-items:center; text-align:center; padding:40px; }
.embed-frame .badge{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); font-weight:700; }

/* signature pad */
.sigwrap{ border:1.5px solid var(--line-strong); border-radius:var(--radius); background:#fff; position:relative; }
.sigwrap canvas{ width:100%; height:170px; display:block; border-radius:var(--radius); cursor:crosshair; touch-action:none; }
.sigwrap .baseline{ position:absolute; left:24px; right:24px; bottom:42px; border-bottom:1px solid var(--line-strong); pointer-events:none; }
.sigwrap .x{ position:absolute; left:24px; bottom:44px; color:var(--ink-soft); font-size:1.1rem; pointer-events:none; }
.sig-actions{ display:flex; justify-content:flex-end; margin-top:8px; }
.sig-clear{ background:none; border:0; color:var(--gold); font-weight:600; font-size:.86rem; cursor:pointer; }

/* steps progress (intake) */
.steps{ display:flex; gap:8px; margin-bottom:28px; flex-wrap:wrap; }
.steps .s{ font-size:.78rem; color:var(--ink-soft); display:flex; align-items:center; gap:7px; }
.steps .s b{ width:22px; height:22px; border-radius:50%; background:var(--cream-2); border:1px solid var(--line-strong); display:grid; place-items:center; font-family:var(--serif); color:var(--navy); }

/* ============================ FOOTER ============================ */
.site-footer{ background:var(--navy); color:#B9C2D4; padding-block:64px 30px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.foot-brand .fmark{ font-family:var(--serif); color:#fff; font-size:1.5rem; letter-spacing:.06em; text-transform:uppercase; line-height:1.1; }
.foot-brand .fmark span{ display:block; font-family:var(--sans); font-size:.62rem; letter-spacing:.34em; color:var(--gold-bright); margin-top:6px; }
.foot-brand p{ font-size:.92rem; margin-top:16px; max-width:34ch; color:#9AA6BD; }
.site-footer h4{ color:#fff; font-family:var(--sans); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; margin:0 0 16px; }
.site-footer ul{ list-style:none; padding:0; margin:0; }
.site-footer ul li{ margin-bottom:10px; }
.site-footer a{ color:#B9C2D4; font-size:.95rem; }
.site-footer a:hover{ color:var(--gold-bright); }
.foot-contact p{ font-size:.95rem; margin:0 0 8px; color:#B9C2D4; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:48px; padding-top:24px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:.8rem; color:#8290AB; }
.foot-bottom .legal{ max-width:70ch; }

/* utility */
.center{ text-align:center; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
[hidden]{ display:none !important; }
:focus-visible{ outline:3px solid var(--gold); outline-offset:2px; border-radius:2px; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 980px){
  .nav-links{ display:none; }
  .hamburger{ display:block; }
  .hero-grid{ grid-template-columns:1fr; gap:28px; }
  .hero-column{ min-height:280px; order:-1; }
  .col-art{ width:230px; }
  .story-grid{ grid-template-columns:1fr; }
  .pillars,.practice-grid,.team-grid{ grid-template-columns:1fr; }
  .bio{ grid-template-columns:1fr; }
  .bio .bio-photo{ position:static; max-width:320px; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .mobile-nav.open{ display:block; position:fixed; inset:84px 0 0; background:var(--cream); z-index:55; padding:24px var(--gutter); overflow:auto; }
  .mobile-nav a{ display:block; font-family:var(--serif); font-size:1.5rem; color:var(--navy); padding:14px 0; border-bottom:1px solid var(--line); }
}
@media (max-width: 560px){
  body{ font-size:17px; }
  .field-grid{ grid-template-columns:1fr; }
  .field.col-2{ grid-column:span 1; }
  .foot-grid{ grid-template-columns:1fr; }
  .brand .brand-text{ display:none; }
  .hero-meta{ gap:20px; }
}
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}

/* =========================================================================
   ADDITIONS — trust strip, process, testimonials, FAQ, fees, resources,
   articles, legal pages, contact, attorney summary cards, disclosures
   ========================================================================= */

/* nav: allow more items to breathe */
.nav-links{ gap:22px; }
.nav-links a{ font-size:.88rem; }
@media (max-width:1080px){ .nav-links{ gap:16px; } .nav-links a{ font-size:.84rem; } }

/* compliance disclosure note (attorney advertising / out-of-state) */
.disclosure{ font-size:.82rem; color:var(--ink-soft); background:var(--cream-2);
  border:1px solid var(--line); border-left:3px solid var(--gold); border-radius:var(--radius);
  padding:12px 16px; margin:14px 0 0; line-height:1.5; }
.disclosure b{ color:var(--navy); }

/* footer legal row */
.foot-legal{ border-top:1px solid rgba(255,255,255,.12); margin-top:24px; padding-top:20px; }
.foot-legal .ad{ font-size:.78rem; color:#9AA6BD; letter-spacing:.04em; }
.foot-legal .ll{ display:flex; gap:18px; flex-wrap:wrap; margin-top:10px; }
.foot-legal .ll a{ font-size:.82rem; color:#B9C2D4; }
.foot-legal .ll a:hover{ color:var(--gold-bright); }

/* trust / credentials strip */
.trust{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.trust .wrap{ display:flex; align-items:center; justify-content:center; gap:clamp(20px,5vw,56px); flex-wrap:wrap; padding-block:26px; }
.trust .badge-i{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:4px; min-width:120px; }
.trust .badge-i b{ font-family:var(--serif); font-size:1.05rem; color:var(--navy); letter-spacing:.02em; }
.trust .badge-i span{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.trust .sep{ width:1px; height:42px; background:var(--line); }
@media (max-width:680px){ .trust .sep{ display:none; } }

/* our process */
.proc{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:54px; counter-reset:step; }
.proc .pstep{ position:relative; padding-top:18px; }
.proc .pstep .n{ font-family:var(--serif); font-size:2.4rem; color:var(--gold); line-height:1; }
.proc .pstep h3{ font-size:1.25rem; margin:.4rem 0 .4rem; }
.proc .pstep p{ color:var(--ink-soft); font-size:.97rem; margin:0; }
.proc .pstep::before{ content:""; position:absolute; top:0; left:0; width:46px; height:3px; background:var(--gold); border-radius:3px; }
@media (max-width:880px){ .proc{ grid-template-columns:1fr 1fr; gap:30px 24px; } }
@media (max-width:520px){ .proc{ grid-template-columns:1fr; } }

/* fees band */
.fees-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.fee{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:32px 28px; text-align:center; }
.fee .ficon{ width:48px;height:48px;margin:0 auto 14px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;color:var(--gold); }
.fee h3{ font-size:1.3rem; margin:0 0 .4rem; }
.fee p{ color:var(--ink-soft); font-size:.97rem; margin:0; }
@media (max-width:880px){ .fees-grid{ grid-template-columns:1fr; } }

/* testimonials (template) */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.quote{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; position:relative; }
.quote .mark{ font-family:var(--serif); font-size:3rem; color:var(--gold-soft); line-height:.6; }
.quote p{ font-family:var(--serif); font-style:italic; font-size:1.18rem; color:var(--navy); line-height:1.4; margin:.4rem 0 1rem; }
.quote .who{ font-size:.84rem; color:var(--ink-soft); font-weight:600; }
.quote.placeholder{ border-style:dashed; border-color:var(--line-strong); background:var(--cream-2); display:grid; place-items:center; text-align:center; min-height:200px; color:var(--ink-soft); }
@media (max-width:880px){ .quotes{ grid-template-columns:1fr; } }

/* FAQ accordion */
.faq{ max-width:820px; margin:42px auto 0; }
.faq details{ border:1px solid var(--line); border-radius:var(--radius); background:var(--paper); margin-bottom:12px; overflow:hidden; }
.faq summary{ list-style:none; cursor:pointer; padding:20px 24px; font-family:var(--serif); font-size:1.2rem; color:var(--navy); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ic{ flex:0 0 auto; width:22px; height:22px; position:relative; transition:transform .2s; }
.faq summary .ic::before,.faq summary .ic::after{ content:""; position:absolute; background:var(--gold); border-radius:2px; }
.faq summary .ic::before{ top:10px; left:2px; right:2px; height:2px; }
.faq summary .ic::after{ left:10px; top:2px; bottom:2px; width:2px; transition:opacity .2s; }
.faq details[open] summary .ic::after{ opacity:0; }
.faq .ans{ padding:0 24px 22px; color:var(--ink-soft); }
.faq .ans p{ margin:0; }

/* resources / blog */
.posts{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; margin-top:48px; }
.post-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:30px 30px 26px; display:flex; flex-direction:column; transition:transform .2s,box-shadow .2s; }
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.post-card .cat{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); font-weight:700; }
.post-card .date{ font-size:.82rem; color:var(--ink-soft); margin-left:auto; }
.post-card .meta{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.post-card h3{ font-size:1.5rem; margin:0 0 .5rem; }
.post-card p{ color:var(--ink-soft); font-size:.98rem; margin:0 0 18px; }
.post-card .linklike{ margin-top:auto; }
@media (max-width:740px){ .posts{ grid-template-columns:1fr; } }

/* long-form article + legal page prose */
.prose{ max-width:760px; margin-inline:auto; }
.prose .meta{ display:flex; gap:12px; align-items:center; color:var(--ink-soft); font-size:.85rem; margin-bottom:8px; }
.prose .cat{ color:var(--gold); font-weight:700; letter-spacing:.16em; text-transform:uppercase; font-size:.72rem; }
.prose h1{ font-size:clamp(2rem,4vw,3rem); margin-bottom:.5rem; }
.prose h2{ font-size:1.6rem; margin:1.8em 0 .5em; }
.prose h3{ font-size:1.25rem; margin:1.4em 0 .4em; }
.prose p, .prose li{ color:var(--ink); line-height:1.7; }
.prose ul{ padding-left:1.2em; } .prose li{ margin-bottom:.5em; }
.prose .lead{ font-size:1.2rem; color:var(--ink-soft); }
.prose hr{ border:0; border-top:1px solid var(--line); margin:2.2em 0; }
.prose .callout{ background:var(--cream-2); border-left:3px solid var(--gold); border-radius:var(--radius); padding:18px 22px; }
.prose .callout p{ margin:0; color:var(--ink-soft); font-size:.95rem; }
.legal-disc{ background:var(--cream-2); border:1px solid var(--line); border-radius:var(--radius); padding:18px 22px; font-size:.86rem; color:var(--ink-soft); margin-top:30px; }
.updated{ font-size:.84rem; color:var(--ink-soft); font-style:italic; }

/* contact */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,60px); align-items:start; }
.info-list{ list-style:none; padding:0; margin:24px 0 0; }
.info-list li{ display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--line); }
.info-list li .ic{ flex:0 0 22px; color:var(--gold); margin-top:2px; }
.info-list li b{ display:block; color:var(--navy); font-size:.92rem; }
.info-list li span{ color:var(--ink-soft); font-size:.95rem; }
.map-frame{ border:1.5px dashed var(--line-strong); border-radius:6px; background:var(--cream-2); min-height:300px; display:grid; place-items:center; text-align:center; padding:30px; margin-top:18px; color:var(--ink-soft); }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }

/* attorney summary cards w/ read more (aggregate page) */
.tcard .role + .disclosure{ margin-top:10px; font-size:.78rem; }
.tcard .readrow{ margin-top:16px; }

/* who-we-help / checklist (practice detail) */
.split{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,5vw,60px); align-items:start; }
@media (max-width:880px){ .split{ grid-template-columns:1fr; } }
.checklist{ list-style:none; padding:0; margin:18px 0 0; }
.checklist li{ display:flex; gap:.7em; padding:10px 0; border-bottom:1px solid var(--line); color:var(--ink-soft); }
.checklist li:last-child{ border-bottom:0; }
.checklist li::before{ content:""; flex:0 0 8px; height:8px; margin-top:.5em; background:var(--gold); border-radius:50%; }
.subnav{ display:flex; gap:10px; flex-wrap:wrap; margin-top:30px; }
.subnav a{ font-size:.85rem; font-weight:600; padding:.5em 1em; border:1.5px solid var(--line-strong); border-radius:999px; color:var(--navy-700); }
.subnav a:hover, .subnav a.active{ background:var(--navy); color:#fff; border-color:var(--navy); }

/* breadcrumb */
.crumb{ font-size:.82rem; color:var(--ink-soft); margin-bottom:8px; }
.crumb a{ color:var(--gold); } .crumb a:hover{ color:var(--navy); }

/* small button */
.btn--sm{ padding:.6em 1.1em; font-size:.84rem; }

/* attorney descriptor line (e.g., practice descriptor under role) */
.role-desc{ font-size:.82rem; font-style:italic; color:var(--ink-soft); margin:-2px 0 8px; }
.bio-body .role-desc{ font-size:.95rem; margin:2px 0 10px; }
