/* ===========================================================================
   NotaryAve — Robin Nunn, Texas Remote Online Notary / Mobile / Apostille
   Shared stylesheet. Palette: forest green + antique gold + cream paper.
   =========================================================================== */
:root{
  --forest:#14352a; --forest-deep:#0e251c; --forest-soft:#1d4a3a;
  --gold:#b8893f; --gold-light:#cda45b; --gold-ink:#8a5e22;
  --cream:#f7f1e4; --cream-2:#efe6d2; --paper:#fbf7ee;
  --ink:#23261f; --ink-soft:#55584d; --line:#d8cdb4;
  --shadow:0 24px 60px -28px rgba(20,53,42,.45);
  --shadow-sm:0 10px 30px -18px rgba(20,53,42,.4);
  --r:16px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --roman:"Cinzel",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --script:"Pinyon Script",cursive;
  --maxw:1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E")}
.wrap{width:min(var(--maxw),92vw);margin-inline:auto;position:relative;z-index:1}
a{color:inherit}
img{display:block;max-width:100%;height:auto}
svg{display:block;max-width:100%}
h1,h2,h3,h4{margin:0;font-weight:500;line-height:1.1;letter-spacing:.2px}
p{margin:0 0 1em}
.muted{color:var(--ink-soft)}
.center{text-align:center}

.eyebrow{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-ink);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.c{justify-content:center}
.eyebrow.c::after{content:"";width:26px;height:1px;background:var(--gold);display:inline-block}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;cursor:pointer;border:0;background:var(--gold);color:var(--forest-deep);font-family:var(--sans);font-weight:600;font-size:.96rem;letter-spacing:.02em;padding:.92em 1.5em;border-radius:999px;text-decoration:none;transition:transform .25s,box-shadow .25s,background .25s;box-shadow:0 12px 28px -14px rgba(184,137,63,.7)}
.btn:hover{transform:translateY(-2px);background:var(--gold-light);box-shadow:0 18px 34px -14px rgba(184,137,63,.8)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translate(3px,-3px)}
.btn.ghost{background:transparent;color:var(--forest);box-shadow:none;border:1px solid var(--forest)}
.btn.ghost:hover{background:var(--forest);color:var(--cream)}
.btn.cream{background:var(--cream);color:var(--forest-deep);box-shadow:0 12px 30px -16px rgba(0,0,0,.5)}
.btn.cream:hover{background:#fff}
.btn.lg{padding:1.05em 1.8em;font-size:1.02rem}

/* Header */
header.site{position:sticky;top:0;z-index:50;transition:background .3s,box-shadow .3s}
header.site.scrolled{background:rgba(247,241,228,.9);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:20px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img.logo{height:48px;width:auto;border-radius:8px;flex:0 0 auto;box-shadow:var(--shadow-sm)}
footer .brand img.logo{height:54px}
.brand .bn{display:flex;flex-direction:column;line-height:1}
.brand .bn b{font-family:var(--roman);font-weight:600;font-size:1.16rem;letter-spacing:.15em;color:var(--forest)}
.brand .bn span{font-family:var(--sans);font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-ink);margin-top:4px}
nav.links{display:flex;align-items:center;gap:26px}
nav.links a{font-size:.93rem;font-weight:500;text-decoration:none;color:var(--ink);position:relative;padding:6px 0}
nav.links a::after{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1.5px;background:var(--gold);transition:width .3s}
nav.links a:hover,nav.links a[aria-current=page]{color:var(--forest)}
nav.links a:hover::after,nav.links a[aria-current=page]::after{width:100%}
.navcta{display:flex;align-items:center;gap:12px}
.tel{font-weight:700;color:var(--forest);text-decoration:none;white-space:nowrap}
.tel:hover{color:var(--gold-ink)}
#navToggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
#navToggle span{position:absolute;left:0;height:2px;width:100%;background:var(--forest);transition:.3s;border-radius:2px}
#navToggle span:nth-child(1){top:2px}#navToggle span:nth-child(2){top:11px}#navToggle span:nth-child(3){top:20px}

/* Hero (home) */
.hero{position:relative;padding:64px 0 70px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.hero h1{font-family:var(--serif);font-size:clamp(2.6rem,5.4vw,4.3rem);letter-spacing:-.5px;color:var(--forest);margin:.3em 0 .26em}
.hero h1 em{font-style:italic;color:var(--gold-ink)}
.hero .lede{font-size:1.18rem;color:var(--ink-soft);max-width:40ch;margin-bottom:1.6em}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.chip{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;font-weight:500;color:var(--forest);background:var(--paper);border:1px solid var(--line);padding:.5em .85em;border-radius:999px}
.chip svg{width:15px;height:15px;color:var(--gold-ink)}
.portrait{position:relative}
.portrait img{width:100%;border-radius:22px;box-shadow:var(--shadow);border:1px solid var(--line)}
.portrait .badge{position:absolute;bottom:-18px;left:-18px;background:var(--forest);color:var(--cream);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;max-width:230px}
.portrait .badge svg{width:30px;height:30px;color:var(--gold-light);flex:0 0 auto}
.portrait .badge b{font-family:var(--serif);font-size:1.1rem;display:block;line-height:1.1}
.portrait .badge span{font-size:.72rem;color:rgba(247,241,228,.8)}

/* Page hero (service / city / about) */
.phero{position:relative;color:var(--cream);padding:120px 0 60px;background:var(--forest)}
.phero::before{content:"";position:absolute;inset:0;background-size:cover;background-position:center;opacity:.26;z-index:0}
.phero[data-bg]::before{background-image:var(--bg)}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,37,28,.6),rgba(14,37,28,.86));z-index:0}
.phero .wrap{position:relative;z-index:1}
.phero h1{font-family:var(--serif);font-size:clamp(2.2rem,4.6vw,3.6rem);max-width:18ch;margin:.2em 0 .3em}
.phero p{color:rgba(247,241,228,.85);font-size:1.12rem;max-width:54ch}
.phero .hero-cta{margin-top:24px}

/* Breadcrumb */
.crumb{font-size:.82rem;color:rgba(247,241,228,.7);display:flex;gap:.5em;flex-wrap:wrap;align-items:center}
.crumb a{color:var(--gold-light);text-decoration:none}
.crumb a:hover{text-decoration:underline}
.crumb .sep{opacity:.5}

/* Sections */
section{position:relative;z-index:1}
.band{padding:84px 0}
.band.tight{padding:60px 0}
.band.green{background:var(--forest);color:var(--cream)}
.band.green h2,.band.green h3{color:var(--cream)}
.band.deep{background:var(--forest-deep);color:var(--cream)}
.band.cream2{background:var(--cream-2)}
.sec-head{max-width:64ch}
.sec-head.c{margin-inline:auto;text-align:center}
.sec-head h2{font-family:var(--serif);font-size:clamp(2rem,3.7vw,3rem);color:var(--forest);margin:.26em 0 .3em}
.band.green .sec-head h2,.band.deep .sec-head h2{color:var(--cream)}
.sec-head p{color:var(--ink-soft);font-size:1.08rem}
.band.green .sec-head p,.band.deep .sec-head p{color:rgba(247,241,228,.8)}
.prose{max-width:72ch}
.prose h2{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.3rem);color:var(--forest);margin:1.4em 0 .4em}
.prose h3{font-family:var(--serif);font-size:1.4rem;color:var(--forest);margin:1.2em 0 .3em}
.prose ul{padding-left:0;list-style:none;display:grid;gap:10px;margin:1em 0}
.prose ul li{display:flex;gap:.6em}
.prose ul li::before{content:"";flex:0 0 auto;width:18px;height:18px;margin-top:4px;background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b8893f' stroke-width='2.5'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E")}

/* Trust strip */
.trust{background:var(--forest-deep);color:var(--cream);padding:18px 0}
.trust .row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 34px;align-items:center}
.trust .item{display:flex;align-items:center;gap:.6em;font-size:.86rem;color:rgba(247,241,228,.9)}
.trust .item svg{width:17px;height:17px;color:var(--gold-light);flex:0 0 auto}
.trust .dot{width:4px;height:4px;border-radius:50%;background:var(--gold);opacity:.6}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:46px}
.step{position:relative;padding:30px 24px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r)}
.step .no{font-family:var(--serif);font-style:italic;font-size:2.6rem;color:var(--gold);line-height:1;margin-bottom:.2em}
.step h3{font-family:var(--serif);font-size:1.4rem;color:var(--forest);margin-bottom:.3em}
.step p{font-size:.96rem;color:var(--ink-soft);margin:0}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.card{display:flex;flex-direction:column;padding:28px 26px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);transition:transform .3s,box-shadow .3s,border-color .3s;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold)}
.card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--forest);color:var(--gold-light);margin-bottom:16px}
.card .ic svg{width:24px;height:24px}
.card h3{font-family:var(--serif);font-size:1.5rem;color:var(--forest);margin-bottom:.25em}
.card p{font-size:.95rem;color:var(--ink-soft);margin:0 0 1em}
.card .more{margin-top:auto;font-weight:600;color:var(--gold-ink);font-size:.9rem;display:inline-flex;gap:.4em;align-items:center}

/* Split image + text */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split.flip .fig{order:2}
.split .fig img{width:100%;border-radius:20px;box-shadow:var(--shadow);border:1px solid var(--line)}
.split .body h2{font-family:var(--serif);font-size:clamp(1.8rem,3.2vw,2.5rem);color:var(--forest);margin:.2em 0 .4em}
.band.green .split .body h2{color:var(--cream)}

/* Showcase banner */
.showcase{max-width:940px;margin-inline:auto}
.showcase img{width:100%;border-radius:20px;box-shadow:var(--shadow);border:1px solid var(--line)}

/* Audience */
.aud{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:44px}
.aud .a{padding:26px 18px;text-align:center;border:1px solid rgba(247,241,228,.18);border-radius:var(--r);background:rgba(255,255,255,.03);transition:.3s}
.aud .a:hover{background:rgba(184,137,63,.12);border-color:var(--gold)}
.aud .a svg{width:30px;height:30px;color:var(--gold-light);margin:0 auto 12px}
.aud .a b{display:block;font-family:var(--serif);font-size:1.22rem;color:var(--cream);font-weight:500;margin-bottom:.2em}
.aud .a span{font-size:.83rem;color:rgba(247,241,228,.7)}

/* About */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.about-grid .fig img{width:100%;border-radius:22px;box-shadow:var(--shadow);border:1px solid var(--line)}
.creds{list-style:none;padding:0;margin:24px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:12px 22px}
.creds li{display:flex;gap:.6em;align-items:flex-start;font-size:.96rem}
.creds li svg{width:18px;height:18px;color:var(--gold);flex:0 0 auto;margin-top:3px}

/* Pricing */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px;align-items:stretch}
.price{display:flex;flex-direction:column;padding:34px 30px;background:var(--paper);border:1px solid var(--line);border-radius:20px;position:relative}
.price.feat{background:var(--forest);color:var(--cream);border-color:var(--forest);box-shadow:var(--shadow)}
.price.feat .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--forest-deep);font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:.4em 1em;border-radius:999px}
.price .pt{font-family:var(--sans);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.82rem;color:var(--gold-ink)}
.price.feat .pt{color:var(--gold-light)}
.price .amt{font-family:var(--serif);font-size:3rem;color:var(--forest);line-height:1;margin:.18em 0}
.price.feat .amt{color:var(--cream)}
.price .amt small{font-size:1rem;color:var(--ink-soft);font-family:var(--sans);font-weight:500}
.price.feat .amt small{color:rgba(247,241,228,.75)}
.price ul{list-style:none;padding:0;margin:18px 0 26px;display:grid;gap:11px}
.price li{display:flex;gap:.6em;font-size:.94rem;color:var(--ink-soft)}
.price.feat li{color:rgba(247,241,228,.85)}
.price li svg{width:17px;height:17px;color:var(--gold);flex:0 0 auto;margin-top:3px}
.price .btn{margin-top:auto;justify-content:center}
.note{text-align:center;margin-top:22px;font-size:.86rem;color:var(--ink-soft)}

/* FAQ */
.faq{max-width:820px;margin:42px auto 0}
details{border-bottom:1px solid var(--line);padding:6px 0}
details summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:20px 4px;font-family:var(--serif);font-size:1.32rem;color:var(--forest);font-weight:500}
details summary::-webkit-details-marker{display:none}
details summary .pm{flex:0 0 auto;width:26px;height:26px;border:1px solid var(--gold);border-radius:50%;position:relative;transition:.3s}
details summary .pm::before,details summary .pm::after{content:"";position:absolute;background:var(--gold-ink);top:50%;left:50%;transform:translate(-50%,-50%)}
details summary .pm::before{width:11px;height:1.6px}
details summary .pm::after{width:1.6px;height:11px;transition:.3s}
details[open] summary .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
details[open] summary .pm{background:var(--gold)}
details .ans{padding:0 4px 22px;color:var(--ink-soft);max-width:74ch}

/* City grid */
.citygrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-top:36px}
.citygrid a{display:flex;align-items:center;gap:.6em;padding:14px 16px;background:var(--paper);border:1px solid var(--line);border-radius:12px;text-decoration:none;color:var(--forest);font-weight:500;font-size:.95rem;transition:.25s}
.citygrid a:hover{border-color:var(--gold);background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.citygrid a svg{width:16px;height:16px;color:var(--gold-ink);flex:0 0 auto}

/* Area tags */
.areas{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.areas span{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.45em .9em;font-size:.86rem;color:var(--forest)}
.band.green .areas span{background:rgba(255,255,255,.06);border-color:rgba(247,241,228,.2);color:var(--cream)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.contact-copy h2{font-family:var(--serif);font-size:clamp(2rem,3.6vw,2.8rem);color:var(--cream);margin:.3em 0}
.contact-copy p{color:rgba(247,241,228,.82)}
.contact-copy .alt{margin-top:24px;display:flex;flex-direction:column;gap:12px}
.contact-copy .alt a{display:inline-flex;align-items:center;gap:.7em;color:var(--cream);text-decoration:none;font-weight:500}
.contact-copy .alt a svg{width:20px;height:20px;color:var(--gold-light)}
form.lead{background:var(--paper);border-radius:24px;padding:32px 30px;box-shadow:var(--shadow)}
form.lead .fields{display:grid;gap:15px}
form.lead .two{display:grid;grid-template-columns:1fr 1fr;gap:15px}
label{display:block;font-size:.76rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--gold-ink);margin-bottom:6px}
input,select,textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--cream);border:1px solid var(--line);border-radius:11px;padding:.78em .9em;transition:border-color .25s,box-shadow .25s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,137,63,.18)}
textarea{resize:vertical;min-height:90px}
form.lead .btn{width:100%;justify-content:center;margin-top:4px}
#formMsg{margin-top:13px;font-size:.92rem;color:var(--forest);min-height:1.2em;font-weight:500}

/* Map */
.mapwrap{margin-top:32px;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);aspect-ratio:16/7;background:var(--paper)}
.mapwrap iframe{width:100%;height:100%;border:0;display:block}
@media (max-width:680px){.mapwrap{aspect-ratio:4/5}}

/* CTA band */
.ctaband{background:var(--forest);color:var(--cream);text-align:center;padding:70px 0}
.ctaband h2{font-family:var(--serif);font-size:clamp(2rem,3.6vw,2.8rem);color:var(--cream);margin:0 0 .3em}
.ctaband p{color:rgba(247,241,228,.82);max-width:52ch;margin:0 auto 1.6em}
.ctaband .hero-cta{justify-content:center}

/* Footer */
footer.site{background:var(--forest-deep);color:rgba(247,241,228,.8);padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:28px;padding-bottom:34px;border-bottom:1px solid rgba(247,241,228,.14)}
footer .brand .bn b{color:var(--cream)}
footer .ft-tag{font-family:var(--serif);font-style:italic;color:var(--gold-light);font-size:1.12rem;margin:14px 0 0}
footer h4{font-family:var(--sans);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-light);margin:0 0 15px}
footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
footer ul a{color:rgba(247,241,228,.78);text-decoration:none;font-size:.94rem}
footer ul a:hover{color:var(--cream)}
.disclaimer{font-size:.78rem;color:rgba(247,241,228,.5);max-width:90ch;margin:22px 0 0;line-height:1.6}
.copy{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:20px;font-size:.82rem;color:rgba(247,241,228,.55)}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:36px}.portrait{max-width:440px;margin-inline:auto}
  .steps{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:repeat(2,1fr)}
  .aud{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr;gap:30px}.split.flip .fig{order:0}
  .about-grid{grid-template-columns:1fr;gap:30px}.about-grid .fig{max-width:420px;margin-inline:auto}
  .prices{grid-template-columns:1fr;gap:26px}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  nav.links,.navcta .tel,.navcta .btn{display:none}
  #navToggle{display:block}
  nav.links.open{display:flex;position:absolute;top:70px;left:4vw;right:4vw;flex-direction:column;gap:4px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px 20px;box-shadow:var(--shadow)}
  .cards{grid-template-columns:1fr}.aud{grid-template-columns:repeat(2,1fr)}
  .creds,.two{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .phero{padding:96px 0 50px}
  .portrait .badge{left:0}
}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* Azure Maps control */
#azmap{width:100%;height:100%}

/* Chatbot */
.chat-fab{position:fixed;right:20px;bottom:20px;z-index:60;display:inline-flex;align-items:center;gap:.5em;background:var(--forest);color:var(--cream);border:0;border-radius:999px;padding:.8em 1.2em;font-family:var(--sans);font-weight:600;font-size:.95rem;cursor:pointer;box-shadow:var(--shadow);transition:transform .25s,background .25s}
.chat-fab:hover{transform:translateY(-2px);background:var(--forest-soft)}
.chat-fab svg{width:20px;height:20px}
.chat-panel{position:fixed;right:20px;bottom:20px;z-index:61;width:min(380px,92vw);height:min(560px,80vh);background:var(--paper);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}
.chat-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;background:var(--forest);color:var(--cream)}
.chat-head .chat-h b{font-family:var(--serif);font-size:1.12rem;display:block;line-height:1.1}
.chat-head .chat-h span{font-size:.72rem;color:rgba(247,241,228,.75)}
.chat-close{background:none;border:0;color:var(--cream);font-size:1.6rem;line-height:1;cursor:pointer;padding:0 4px}
.chat-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chat-msg{max-width:86%;padding:.7em .9em;border-radius:14px;font-size:.92rem;line-height:1.5}
.chat-msg.bot{background:var(--cream-2);color:var(--ink);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.me{background:var(--forest);color:var(--cream);align-self:flex-end;border-bottom-right-radius:4px}
.chat-msg.typing{color:var(--ink-soft);font-style:italic}
.chat-sugg{display:flex;flex-wrap:wrap;gap:6px;padding:0 16px 8px}
.chat-sugg button{background:var(--paper);border:1px solid var(--line);color:var(--forest);border-radius:999px;padding:.4em .8em;font-size:.8rem;cursor:pointer;font-family:var(--sans)}
.chat-sugg button:hover{border-color:var(--gold);background:#fff}
.chat-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:999px;padding:.65em .9em;font-family:var(--sans);font-size:.92rem;background:var(--cream)}
.chat-input input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,137,63,.18)}
.chat-input button{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:0;background:var(--gold);color:var(--forest-deep);cursor:pointer;display:grid;place-items:center}
.chat-input button svg{width:18px;height:18px}
.chat-foot{font-size:.72rem;color:var(--ink-soft);text-align:center;padding:0 14px 12px}
.chat-foot a{color:var(--gold-ink);font-weight:600;text-decoration:none}
@media (max-width:680px){.chat-fab span{display:none}.chat-fab{padding:.9em}.chat-panel{right:8px;bottom:8px;width:96vw;height:84vh}}
