/* BRISAMO — base + shared components. Import after tokens.css. */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:radial-gradient(1100px 620px at 88% -6%,var(--em-tint),transparent 58%),radial-gradient(900px 500px at -8% 4%,rgba(240,169,59,.07),transparent 55%),var(--wash);-webkit-font-smoothing:antialiased;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.disp{font-family:var(--font-disp)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.muted{color:var(--muted)}

/* nav */
.site-nav{position:sticky;top:0;z-index:40;background:rgba(241,250,246,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-nav .row{display:flex;align-items:center;justify-content:space-between;padding:15px 26px}
.brand{font-family:var(--font-disp);font-weight:800;font-size:23px;letter-spacing:-.6px;display:flex;align-items:center;gap:8px;color:var(--em-deep)}
.brand .mk{width:27px;height:27px;border-radius:9px;background:var(--em);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-family:var(--font-disp);font-weight:700}
.nav-links{display:flex;align-items:center;gap:24px;font-size:15px;font-weight:500}
.nav-links a:not(.pill){opacity:.78;transition:.2s}
.nav-links a:not(.pill):hover{opacity:1;color:var(--em)}

/* buttons */
.pill{background:var(--em-grad-deep);color:#fff;padding:11px 22px;border-radius:var(--r-sm);font-weight:600;font-size:14.5px;transition:transform .18s,box-shadow .18s,background .2s;box-shadow:var(--sh-pill);display:inline-block;border:none;cursor:pointer}
.pill:hover{background:var(--em-deep);transform:translateY(-2px);box-shadow:0 14px 26px -10px rgba(14,124,102,.75)}
.pill:active{transform:translateY(0)}
.pill.ghost{background:#fff;color:var(--em-deep);box-shadow:none;border:1px solid var(--line)}
.pill.ghost:hover{border-color:var(--em);color:var(--em);background:#fff}
.pill.amber{background:#fff;color:var(--em-deep);box-shadow:none}
.pill.amber:hover{background:var(--amber);color:#2a1d05}

/* eyebrow + section heading */
.eyebrow{color:var(--em);font-weight:700;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px}
.section-h{font-family:var(--font-disp);font-weight:800;font-size:clamp(28px,3.4vw,38px);letter-spacing:-1px;line-height:1.1}
.section-sub{color:var(--muted);font-size:16.5px;margin-top:10px;max-width:560px}
.section{padding:64px 0}
.center{text-align:center}
.center .section-sub{margin-left:auto;margin-right:auto}

/* hero search card */
.badge{display:inline-flex;align-items:center;gap:7px;background:var(--white);color:var(--em-deep);font-weight:600;font-size:13px;padding:7px 14px;border-radius:var(--pill);border:1px solid var(--line)}
.badge .ping{width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 0 rgba(240,169,59,.5);animation:ping-pulse 2.2s ease-out infinite}
@keyframes ping-pulse{0%{box-shadow:0 0 0 0 rgba(240,169,59,.5)}70%{box-shadow:0 0 0 7px rgba(240,169,59,0)}100%{box-shadow:0 0 0 0 rgba(240,169,59,0)}}
@media (prefers-reduced-motion:reduce){.badge .ping{animation:none}}
.search{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-pop);padding:14px}
.seg{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:13px}
.seg+.seg{margin-top:6px;border-top:1px solid var(--line);border-radius:0;padding-top:14px}
.seg svg{flex-shrink:0;color:var(--em)}
.seg .col{display:flex;flex-direction:column;width:100%}
.seg label{font-size:11.5px;font-weight:600;color:var(--em-deep);margin-bottom:1px}
.seg select,.seg input{border:none;outline:none;background:transparent;font-family:inherit;font-size:15px;font-weight:500;color:var(--ink);width:100%}
.gobtn{margin-top:12px;width:100%;background:var(--em-grad-deep);color:#fff;border:none;padding:15px;border-radius:13px;font-family:inherit;font-weight:700;font-size:15.5px;cursor:pointer;transition:transform .18s,box-shadow .18s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 10px 22px -10px rgba(14,124,102,.6)}
.gobtn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(14,124,102,.75)}
.gobtn:active{transform:translateY(0)}
.microtrust{margin-top:14px;font-size:13px;color:var(--muted);display:flex;gap:16px;flex-wrap:wrap}
.microtrust span{display:flex;align-items:center;gap:5px}
.microtrust svg{color:var(--em-deep)}

/* match panel */
.panel{background:var(--white);border:1px solid var(--line);border-radius:var(--r-xl);padding:18px;box-shadow:var(--sh-pop)}
.panel .ph{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 14px}
.panel .ph b{font-family:var(--font-disp);font-weight:700;font-size:15px}
.panel .ph .chip{font-size:11.5px;font-weight:600;color:var(--em-deep);background:var(--wash);border:1px solid var(--line);padding:5px 11px;border-radius:30px;display:flex;align-items:center;gap:5px}
.panel .ph .chip{color:#8a5e10;background:var(--amber-tint);border-color:#f0d49a}
.panel .ph .chip i{width:7px;height:7px;border-radius:50%;background:var(--amber);font-style:normal}
.firm{display:flex;align-items:center;gap:13px;padding:13px;border:1px solid var(--line);border-radius:var(--r);transition:.2s}
.firm+.firm{margin-top:9px}
.firm:hover{border-color:var(--em-soft);transform:translateY(-2px)}
.firm .lg{width:42px;height:42px;border-radius:11px;flex-shrink:0;color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp)}
.firm:nth-of-type(1) .lg{background:var(--lg1)}
.firm:nth-of-type(2) .lg{background:var(--lg2)}
.firm:nth-of-type(3) .lg{background:var(--lg3)}
.firm .info{flex:1;min-width:0}
.firm .info .nm{font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:6px}
.firm .info .vf{color:var(--em);font-size:13px}
.firm .info .mt{font-size:12.5px;color:var(--muted);margin-top:1px}
.firm .info .tg{margin-top:7px;display:flex;gap:5px;flex-wrap:wrap}
.firm .info .tg span{font-size:10.5px;font-weight:600;color:var(--em-deep);background:var(--wash);padding:3px 8px;border-radius:20px}
.firm .rt{text-align:right;flex-shrink:0}
.firm .rt .st{color:var(--star);font-size:12.5px;letter-spacing:.5px}
.firm .rt .sc{font-size:12px;color:var(--muted)}
.firm .rt .vw{margin-top:8px;font-size:12px;font-weight:600;color:var(--em);border:1px solid var(--line);padding:5px 10px;border-radius:8px;display:inline-block}
.panel .more{text-align:center;font-size:13px;color:var(--em);font-weight:600;padding:12px 0 4px}

/* chips */
.chips{text-align:center}
.chips .lbl{font-size:13px;color:var(--muted);margin-right:6px}
.chips a{display:inline-block;margin:5px;padding:8px 16px;background:var(--white);border:1px solid var(--line);border-radius:var(--pill);font-size:14px;font-weight:500;color:var(--ink);transition:.2s}
.chips a:hover{border-color:var(--em);color:var(--em);transform:translateY(-2px)}

/* generic cards + grids */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;transition:transform .25s,box-shadow .25s,border-color .25s;box-shadow:var(--sh-soft)}
.card.hov:hover{transform:translateY(-4px);box-shadow:var(--sh-card);border-color:var(--em-soft)}
.card .ic{width:48px;height:48px;border-radius:14px;background:var(--em-grad);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:var(--icon-glow);transition:transform .25s}
.card.hov:hover .ic{transform:scale(1.07) rotate(-3deg)}
.card h3{font-family:var(--font-disp);font-weight:700;font-size:18px;margin-bottom:6px}
.card p{color:var(--muted);font-size:14.5px}

/* area / jurisdiction tile */
.tile{display:flex;align-items:center;gap:13px;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:var(--sh-soft)}
.tile:hover{border-color:var(--em);transform:translateY(-3px);box-shadow:var(--sh-lift)}
.tile .ic{width:42px;height:42px;border-radius:12px;background:var(--em-grad);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--icon-glow);transition:transform .2s}
.tile:hover .ic{transform:scale(1.06) rotate(-3deg)}
.tile b{font-family:var(--font-disp);font-weight:600;font-size:15px;display:block}
.tile span{font-size:12.5px;color:var(--muted)}

/* firm result card (richer) */
.firmcard{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;transition:transform .25s,box-shadow .25s,border-color .25s;box-shadow:var(--sh-soft)}
.firmcard:hover{transform:translateY(-4px);box-shadow:var(--sh-card);border-color:var(--em-soft)}
.firmcard .top{display:flex;align-items:center;gap:13px;margin-bottom:13px}
.firmcard .lg{width:50px;height:50px;border-radius:13px;color:#fff;font-weight:700;font-size:17px;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);flex-shrink:0;background:var(--em-grad);box-shadow:var(--icon-glow)}
.firmcard .nm{font-family:var(--font-disp);font-weight:700;font-size:16.5px;display:flex;align-items:center;gap:6px}
.firmcard .loc{font-size:13px;color:var(--muted)}
.firmcard .rate{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);margin-bottom:12px}
.firmcard .rate .st{color:var(--star);letter-spacing:.5px}
.firmcard .rate b{color:var(--ink)}
.firmcard .tg{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.firmcard .tg span{font-size:11.5px;font-weight:600;color:var(--em-deep);background:var(--em-tint);padding:4px 10px;border-radius:20px}
.firmcard .act{display:flex;gap:8px}
.firmcard .act a{flex:1;text-align:center;font-size:13.5px;font-weight:600;padding:10px;border-radius:10px;border:1px solid var(--line);color:var(--em);transition:.18s}
.firmcard .act a:hover{border-color:var(--em);background:var(--em-tint)}
.firmcard .act a.primary{background:var(--em-grad-deep);color:#fff;border-color:transparent}
.firmcard .act a.primary:hover{background:var(--em-deep);box-shadow:0 8px 18px -8px rgba(14,124,102,.7)}

/* guide card */
.guide{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:.25s}
.guide:hover{transform:translateY(-4px);box-shadow:var(--sh-card)}
.guide .ph{position:relative;overflow:hidden;height:120px;padding:14px;display:flex;align-items:flex-end;background:radial-gradient(120% 100% at 85% 0%,rgba(255,255,255,.18),rgba(255,255,255,0) 55%),linear-gradient(135deg,var(--em),var(--em-soft))}
.guide .ph::before{content:"";position:absolute;right:-8px;top:-12px;width:94px;height:94px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M3 9h10a3 3 0 1 0-3-3'/%3E%3Cpath d='M3 14h14a3 3 0 1 1-3 3'/%3E%3Cpath d='M3 19h7'/%3E%3C/svg%3E") no-repeat center/contain;opacity:.18;pointer-events:none;animation:guide-breeze 6s ease-in-out infinite}
.guide .ph span{position:relative;z-index:1}
.guide:hover .ph::before{opacity:.3}
@keyframes guide-breeze{0%,100%{transform:translateX(-2px)}50%{transform:translateX(5px)}}
@media (prefers-reduced-motion:reduce){.guide .ph::before{animation:none}}
.guide .ph span{color:#fff;font-size:11.5px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;opacity:.92}
.guide .bd{padding:18px}
.guide .bd .tag{font-size:11.5px;font-weight:700;color:var(--em);text-transform:uppercase;letter-spacing:1px}
.guide .bd h3{font-family:var(--font-disp);font-weight:700;font-size:17px;line-height:1.25;margin:7px 0 6px}
.guide .bd p{font-size:13.5px;color:var(--muted)}

/* trust band */
.band{background:var(--em);border-radius:var(--r-xl);padding:46px 40px;color:#fff;position:relative;overflow:hidden}
.band>*{position:relative;z-index:1}
.band::after{content:"";position:absolute;right:-70px;bottom:-90px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle at 32% 32%,rgba(255,255,255,.18),rgba(255,255,255,0) 70%);z-index:0;pointer-events:none;animation:orb-a 17s ease-in-out infinite}
.band::before{content:"";position:absolute;left:-60px;top:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(240,169,59,.22),rgba(240,169,59,0) 72%);z-index:0;pointer-events:none;animation:orb-b 13s ease-in-out infinite}
@keyframes orb-a{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,-22px) scale(1.1)}}
@keyframes orb-b{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(26px,20px) scale(1.14)}}
@media (prefers-reduced-motion:reduce){.band::before,.band::after{animation:none}}
.band.center{text-align:center}
.band h2{font-family:var(--font-disp);font-weight:800;font-size:clamp(26px,3vw,33px);letter-spacing:-.8px;position:relative}
.band p{opacity:.9;margin:12px 0 0;font-size:16px;position:relative}

/* stats row */
.stats{display:flex;gap:0;flex-wrap:wrap}
.stats .s{padding:0 28px;border-right:1px solid var(--line)}
.stats .s:first-child{padding-left:0}
.stats .s:last-child{border-right:none}
.stats .s b{font-family:var(--font-disp);font-weight:800;font-size:30px;display:block;color:var(--em-deep);letter-spacing:-.5px}
.stats .s span{font-size:13px;color:var(--muted)}

/* footer */
.site-foot{border-top:1px solid var(--line);background:var(--white);margin-top:20px}
.site-foot .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding:48px 26px 30px}
.site-foot .cols h3{font-family:var(--font-disp);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--em-deep);margin-bottom:14px}
.site-foot .cols a{display:block;font-size:14px;color:var(--muted);padding:5px 0;transition:.2s}
.site-foot .cols a:hover{color:var(--em)}
.site-foot .cols p{font-size:13.5px;color:var(--muted);margin-top:10px;max-width:260px}
.site-foot .legal{border-top:1px solid var(--line);padding:18px 26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:var(--muted)}

/* load animation */
.fade{opacity:0;transform:translateY(16px);animation:up .7s forwards}
.d1{animation-delay:.08s}.d2{animation-delay:.16s}.d3{animation-delay:.24s}.d4{animation-delay:.32s}
@keyframes up{to{opacity:1;transform:none}}

/* ===== layout + responsive (mobile-first redesign) ===== */
.herohero{display:grid;grid-template-columns:1.02fr .98fr;gap:48px;align-items:center;padding:50px 26px 36px}
.burger,.mobcta{display:none}

@media(max-width:920px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .site-foot .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .site-nav .row{position:relative;padding:11px 26px}
  .brand{font-size:21px}
  .burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:40px;padding:0 11px;border:1px solid var(--line);border-radius:11px;background:var(--white);cursor:pointer}
  .burger span{height:2px;background:var(--em-deep);border-radius:2px;transition:.25s}
  .burger:focus-visible{outline:2px solid var(--em);outline-offset:2px}
  .burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-links{display:flex;position:absolute;top:calc(100% + 10px);left:26px;right:26px;flex-direction:column;align-items:stretch;gap:0;background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-pop);padding:6px 0;overflow:hidden;max-height:0;opacity:0;visibility:hidden;transform:translateY(-10px) scaleY(.97);transform-origin:top;transition:max-height .32s ease,opacity .24s ease,transform .32s ease,visibility .32s}
  .burger[aria-expanded="true"] ~ .nav-links{max-height:560px;opacity:1;visibility:visible;transform:none}
  .nav-links a{opacity:.85;transition:opacity .2s,background .15s}.nav-links a:active{background:var(--em-tint)}
  .nav-links a:not(.pill){display:block;opacity:1;padding:14px 20px;font-size:16px;border-bottom:1px solid var(--line)}
  .nav-links a.pill{margin:10px 16px;text-align:center;border-radius:12px;padding:13px}
  .herohero{grid-template-columns:1fr;gap:26px;padding:28px 26px 22px}
  .section{padding:42px 0}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .site-foot .cols{grid-template-columns:1fr 1fr;gap:20px}
  .stats{flex-direction:column}
  .stats .s{padding:12px 0!important;border-right:none!important;border-bottom:1px solid var(--line)}
  .band{padding:34px 22px}
  input,select,textarea{font-size:16px!important}
  .pill,.gobtn,.btn{min-height:46px}
  .mobcta{display:flex;position:fixed;left:12px;right:12px;bottom:12px;z-index:55;justify-content:center;align-items:center;gap:9px;background:var(--em);color:#fff;font-family:var(--font-disp);font-weight:700;font-size:15.5px;padding:15px;border-radius:14px;box-shadow:0 10px 28px -6px rgba(14,124,102,.7);animation:none}
  body:has(.mobcta){padding-bottom:82px}
}
@media(max-width:480px){
  .site-foot .cols{grid-template-columns:1fr}
  .g4{grid-template-columns:1fr}
}


/* animated breeze mark (homepage logo) — gentle wind */
.mk .breeze{width:62%;height:62%}
.mk .breeze path{transform-box:fill-box;transform-origin:center;animation:breeze-gust 3.4s ease-in-out infinite}
.mk .breeze path:nth-of-type(2){animation-delay:.35s}
.mk .breeze path:nth-of-type(3){animation-delay:.7s}
@keyframes breeze-gust{0%,100%{transform:translateX(-.4px);opacity:.82}50%{transform:translateX(1.5px);opacity:1}}
@media (prefers-reduced-motion:reduce){.mk .breeze path{animation:none}}


/* inviting primary CTAs — gentle shine sweep + glow + press feel */
.pill,.gobtn{position:relative;overflow:hidden}
.pill::after,.gobtn::after{content:"";position:absolute;top:0;left:-75%;width:45%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.42),transparent);transform:skewX(-20deg);pointer-events:none;animation:cta-shine 5s ease-in-out infinite}
@keyframes cta-shine{0%{left:-75%}22%{left:140%}100%{left:140%}}
.pill:hover,.gobtn:hover{transform:translateY(-2px)}
.pill:active,.gobtn:active{transform:translateY(0) scale(.98)}
.gobtn{animation:cta-glow 3s ease-in-out infinite}
@keyframes cta-glow{0%,100%{box-shadow:0 8px 20px -10px rgba(14,124,102,.5)}50%{box-shadow:0 14px 32px -8px rgba(14,124,102,.85)}}
.pill.amber{animation:cta-glow-w 2.8s ease-in-out infinite}
@keyframes cta-glow-w{0%,100%{box-shadow:0 6px 18px -8px rgba(255,255,255,.45)}50%{box-shadow:0 12px 30px -6px rgba(255,255,255,.85)}}
@media (prefers-reduced-motion:reduce){.pill::after,.gobtn::after{display:none}.gobtn,.pill.amber{animation:none}}
