/* Palma design system — "Editorial Light" — shared by service, city, guide, results & how-it-works pages */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..600;1,9..144,400..500&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --paper:#f6f2e9; --paper2:#fffdf8; --warm:#efe9dc;
  --ink:#1b1813; --ink2:#262219; --muted:#6f6757;
  --accent:#b4502e; --accent2:#8f3d22; --accent-soft:rgba(180,80,46,.10);
  --line:rgba(27,24,19,.14); --line2:rgba(27,24,19,.26);
  --green:#3f7d5a; --red:#b4402e; --gold:#b4502e; --gold2:#8f3d22; --panel:#fffdf8; --txt:#1b1813;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:"Hanken Grotesk",-apple-system,Arial,sans-serif;-webkit-font-smoothing:antialiased;font-size:17px;line-height:1.6}
.serif{font-family:"Fraunces",Georgia,serif;font-optical-sizing:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 32px}

/* nav */
nav{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;background:rgba(246,242,233,.9);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.brand{display:flex;align-items:center;gap:11px;font-size:15px;letter-spacing:.04em;font-weight:600}
.brand b{font-weight:700}.brand span{color:var(--muted);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase}
.mark{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:var(--paper);background:var(--accent);font-size:14px}
.navlinks{display:flex;gap:26px;align-items:center;font-size:14px;color:var(--ink)}
.navlinks a:hover{color:var(--accent)}
.navcta{border:1px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:4px;font-weight:600;font-size:13px}
.navcta:hover{background:var(--ink);color:var(--paper)}

/* hero */
.hero{padding:96px 0 56px;border-bottom:1px solid var(--line)}
.eyebrow{color:var(--accent);letter-spacing:.18em;font-size:12px;font-weight:600;text-transform:uppercase;display:inline-block}
h1{font-family:"Fraunces",Georgia,serif;font-weight:430;font-size:clamp(38px,6.4vw,76px);line-height:1.02;letter-spacing:-.015em;margin:18px 0 0}
h1 i{font-style:normal;color:var(--accent)}
.lead{color:var(--muted);font-size:19px;line-height:1.62;max-width:660px;margin-top:22px}
.lead2{color:var(--muted);font-size:17px;line-height:1.6;max-width:680px;margin-top:8px}
.btns{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.btn{padding:14px 26px;border-radius:5px;font-size:15px;font-weight:600;transition:transform .15s,background .2s,color .2s}
.btn.solid{background:var(--accent);color:#fff}.btn.solid:hover{background:var(--accent2)}
.btn.ghost{border:1px solid var(--line2);color:var(--ink)}.btn.ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}

/* sections */
section.block{padding:72px 0;border-bottom:1px solid var(--line)}
.block.alt{background:var(--warm)}
h2.sec{font-family:"Fraunces",Georgia,serif;font-weight:430;font-size:clamp(28px,4vw,44px);line-height:1.08;letter-spacing:-.01em;margin:0 0 6px}
h2.sec i{font-style:normal;color:var(--accent)}

/* feature list */
ul.handle{list-style:none;margin:22px 0 0;display:grid;gap:14px;max-width:760px}
ul.handle li{padding-left:30px;position:relative;color:var(--ink);line-height:1.5;font-size:16.5px}
ul.handle li:before{content:"";position:absolute;left:0;top:9px;width:14px;height:2px;background:var(--accent)}

/* callout note */
.note{border-left:3px solid var(--accent);background:var(--paper2);border-radius:0 8px 8px 0;padding:18px 22px;color:var(--ink);line-height:1.6;margin-top:26px;max-width:820px;box-shadow:0 1px 0 var(--line)}
.note b{color:var(--accent2)}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
.step{background:var(--paper2);border:1px solid var(--line);border-radius:10px;padding:24px;transition:transform .18s,border-color .18s}
.step:hover{transform:translateY(-3px);border-color:var(--line2)}
.step .n{color:var(--accent);font-size:12px;letter-spacing:.16em;font-weight:700;text-transform:uppercase}
.step h4{font-family:"Fraunces",Georgia,serif;font-weight:500;font-size:19px;margin:10px 0 7px}
.step p{color:var(--muted);font-size:15px;line-height:1.55}

/* testimonials */
.quote{background:var(--paper2);border:1px solid var(--line);border-radius:10px;padding:24px 26px;margin-top:16px;max-width:820px}
.quote .q{font-family:"Fraunces",Georgia,serif;font-weight:400;font-size:20px;line-height:1.5;color:var(--ink)}
.quote .who{color:var(--accent2);font-size:13.5px;font-weight:600;margin-top:14px;letter-spacing:.01em}

/* faq */
.faq{margin-top:22px;max-width:840px}
.faq details{border-bottom:1px solid var(--line);padding:18px 0}
.faq summary{cursor:pointer;font-size:18px;color:var(--ink);font-weight:600;list-style:none;display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";color:var(--accent);font-weight:400;font-size:22px;line-height:1}
.faq details[open] summary:after{content:"\2212"}
.faq p{color:var(--muted);margin-top:10px;line-height:1.65;font-size:16px;max-width:740px}

/* pill links */
.links{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}
.links a{border:1px solid var(--line2);border-radius:4px;padding:8px 14px;font-size:13.5px;color:var(--ink);transition:background .15s,color .15s,border-color .15s}
.links a:hover{border-color:var(--ink);background:var(--ink);color:var(--paper)}

/* lead form */
.lf{max-width:580px;margin:22px 0 0;display:grid;gap:13px}.lf .two{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.lf input,.lf select,.lf textarea{width:100%;background:var(--paper2);border:1px solid var(--line2);border-radius:6px;padding:14px 15px;color:var(--ink);font-size:15px;font-family:inherit;outline:none;transition:border-color .15s}
.lf input::placeholder,.lf textarea::placeholder{color:#9a9486}
.lf input:focus,.lf select:focus,.lf textarea:focus{border-color:var(--accent)}
.lf textarea{min-height:90px;resize:vertical}.lf select{appearance:none}
.lf .submit{background:var(--accent);color:#fff;font-weight:700;border:none;border-radius:6px;padding:15px 24px;font-size:15px;cursor:pointer;transition:background .2s}
.lf .submit:hover{background:var(--accent2)}.lf .submit:disabled{opacity:.55}
.lf .status{font-size:14px;min-height:18px}.lf .status.ok{color:var(--green)}.lf .status.err{color:var(--red)}

/* dark callout card (free-tool hook) — high contrast against the light page */
.toolhook{background:var(--ink2);color:var(--paper);border-radius:14px;padding:30px;margin-top:28px;max-width:860px}
.toolhook .lab{color:#e7b9a6;font-size:12px;letter-spacing:.16em;font-weight:700;text-transform:uppercase}
.toolhook b{display:block;font-family:"Fraunces",Georgia,serif;font-weight:500;color:#fff;font-size:23px;margin:10px 0 6px}
.toolhook p{color:#c9c1b1;font-size:15px;line-height:1.55;margin-bottom:18px;max-width:620px}
.toolhook .cta{display:inline-block;background:var(--accent);color:#fff;font-weight:600;border-radius:6px;padding:13px 24px;font-size:15px}
.toolhook .cta:hover{background:var(--accent2)}
.trow{display:flex;gap:10px;flex-wrap:wrap}
.trow input{flex:1;min-width:240px;background:#322d22;border:1px solid #4a4435;border-radius:6px;padding:14px 15px;color:#fff;font-size:15px;outline:none}
.trow input::placeholder{color:#9a9486}.trow input:focus{border-color:var(--accent)}
.trow button{background:var(--accent);color:#fff;font-weight:600;border:none;border-radius:6px;padding:14px 22px;font-size:15px;cursor:pointer;white-space:nowrap}
.trow button:hover{background:var(--accent2)}

/* audience cards */
.audgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.aud{background:var(--paper2);border:1px solid var(--line);border-radius:10px;padding:24px}
.aud h4{font-family:"Fraunces",Georgia,serif;font-weight:500;margin:0 0 12px;font-size:18px;color:var(--ink)}
.aud ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.aud li{color:var(--ink);font-size:14px;padding-left:18px;position:relative;line-height:1.45}
.aud li:before{content:"";position:absolute;left:0;top:8px;width:9px;height:2px;background:var(--accent)}

/* stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:10px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.stat{background:var(--paper2);padding:26px 20px;text-align:left}
.stat .num{font-family:"Fraunces",Georgia,serif;color:var(--accent);font-size:34px;font-weight:500;line-height:1}
.stat .lab{color:var(--muted);font-size:13px;margin-top:8px;line-height:1.35}

/* service cards (hub) */
.svcgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:30px}
.svccard{display:flex;flex-direction:column;background:var(--paper2);border:1px solid var(--line);border-radius:12px;padding:30px;transition:transform .2s,border-color .2s}
.svccard:hover{transform:translateY(-4px);border-color:var(--accent)}
.svccard .ic{width:44px;height:44px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent);font-size:20px;margin-bottom:16px}
.svccard h3{font-family:"Fraunces",Georgia,serif;font-weight:500;font-size:22px;margin:0 0 9px}
.svccard p{color:var(--muted);font-size:15px;line-height:1.55;margin:0 0 16px}
.svccard ul{list-style:none;margin:0 0 20px;padding:0;display:grid;gap:8px}
.svccard li{color:var(--ink);font-size:14px;padding-left:18px;position:relative;line-height:1.4}
.svccard li:before{content:"";position:absolute;left:0;top:8px;width:9px;height:2px;background:var(--accent)}
.svccard .go{margin-top:auto;color:var(--accent);font-weight:600;font-size:15px}

/* tool portal note */
.toolnote{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;background:var(--ink2);color:var(--paper);border-radius:14px;padding:28px;margin-top:28px}
.toolnote .tx b{font-family:"Fraunces",Georgia,serif;color:#fff;font-size:19px;font-weight:500}
.toolnote .tx p{color:#c9c1b1;font-size:14px;margin-top:5px}
.toolnote .cta{background:var(--accent);color:#fff;font-weight:600;border-radius:6px;padding:13px 24px;font-size:15px;white-space:nowrap}
.toolnote .cta:hover{background:var(--accent2)}

/* article prose */
.prose{max-width:720px;margin-top:6px}
.prose p{color:var(--ink);font-size:18px;line-height:1.75;margin:0 0 18px}
.prose h2{font-family:"Fraunces",Georgia,serif;font-weight:430;font-size:clamp(24px,3vw,32px);margin:36px 0 12px;letter-spacing:-.01em}.prose h2 i{font-style:normal;color:var(--accent)}
.prose h3{font-family:"Fraunces",Georgia,serif;color:var(--ink);font-size:21px;font-weight:500;margin:28px 0 8px}
.prose ul{margin:0 0 18px 0;padding:0;list-style:none;display:grid;gap:10px}
.prose ul li{color:var(--ink);font-size:16.5px;line-height:1.6;padding-left:24px;position:relative}
.prose ul li:before{content:"";position:absolute;left:0;top:12px;width:14px;height:2px;background:var(--accent)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.cback{display:inline-block;margin-top:10px;color:var(--accent);font-size:15px;font-weight:600}

/* footer — dark ink bookend */
footer{padding:48px 0;background:var(--ink);color:#b8b1a2;font-size:14px;line-height:1.7}
footer .wrap{max-width:1120px}
footer a{color:#e9c0ad}footer a:hover{color:#fff}

@media(max-width:820px){
  .wrap{padding:0 22px}
  .steps{grid-template-columns:1fr}.audgrid{grid-template-columns:1fr}
  .statband{grid-template-columns:1fr 1fr}.svcgrid{grid-template-columns:1fr}.lf .two{grid-template-columns:1fr}
  .hero{padding:64px 0 44px}
}
