@import url('https://fonts.googleapis.com/css2?family=Bree+Serif&display=swap');

:root{--bg:#071016;--panel:#0e1b25;--panel2:#122838;--text:#eef8ff;--muted:#a8bdca;--line:rgba(255,255,255,.12);--blue:#57c4ff;--gold:#ffd166;--green:#7ee2b8;--shadow:0 16px 45px rgba(0,0,0,.38);--radius:22px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:'Bree Serif',Georgia,'Times New Roman',serif;background:radial-gradient(900px 480px at 10% -10%,rgba(87,196,255,.22),transparent),radial-gradient(760px 440px at 90% 0%,rgba(255,209,102,.13),transparent),linear-gradient(180deg,#03070b,#071016 38%,#031017);color:var(--text);line-height:1.55;position:relative;min-height:100vh;isolation:isolate}body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;background:linear-gradient(180deg,rgba(3,7,11,.78),rgba(7,16,22,.62),rgba(3,16,23,.82)),url('/assets/images/new-smyrna-beach-sunrise.webp');background-size:cover;background-position:center center;background-repeat:no-repeat;opacity:.20;transform:scale(1.04)}body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(60% 42% at 18% 18%,rgba(121,222,255,.12),transparent 68%),radial-gradient(56% 38% at 82% 12%,rgba(255,209,102,.10),transparent 66%),radial-gradient(60% 48% at 50% 100%,rgba(255,220,170,.08),transparent 70%)}a{color:inherit}.wrap{max-width:1180px;margin:0 auto;padding:28px 18px 70px;position:relative;z-index:1}header{display:flex;justify-content:space-between;align-items:center;gap:14px}.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.logo{width:62px;height:62px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.04);overflow:hidden;display:grid;place-items:center;flex:0 0 auto}.logo img{width:100%;height:100%;object-fit:cover;display:block}.brand span{font-weight:950;font-size:20px;letter-spacing:.2px}nav{display:flex;gap:9px;flex-wrap:wrap}.pill,.tag{border:1px solid var(--line);background:rgba(255,255,255,.04);padding:9px 12px;border-radius:999px;text-decoration:none;color:var(--muted);font-weight:800;font-size:14px}.pill:hover{color:var(--text);border-color:rgba(87,196,255,.5)}.hero{margin-top:18px;min-height:560px;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;position:relative;background:linear-gradient(90deg,rgba(3,7,11,.82),rgba(3,7,11,.48)),var(--hero);background-size:cover;background-position:center}.hero.small{min-height:390px}.hero .inner{position:absolute;inset:auto 0 0 0;padding:44px 28px;background:linear-gradient(0deg,rgba(3,7,11,.88),rgba(3,7,11,.05))}.kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:950}.hero h1,h1{font-size:clamp(34px,5vw,66px);line-height:1.02;margin:8px 0 12px;letter-spacing:-.04em}.sub{max-width:82ch;color:var(--muted);font-size:17px}.cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.btn{border:1px solid var(--line);background:rgba(255,255,255,.05);padding:13px 16px;border-radius:14px;text-decoration:none;font-weight:950;display:inline-flex;align-items:center;gap:8px}.btn.primary{border-color:rgba(87,196,255,.5);background:linear-gradient(135deg,rgba(87,196,255,.22),rgba(255,209,102,.16))}.section-title{margin:38px 0 13px;font-size:24px;letter-spacing:-.02em;font-weight:950}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.grid.two{grid-template-columns:1.1fr .9fr}.grid.four{grid-template-columns:repeat(4,1fr)}@media(max-width:900px){.grid,.grid.two,.grid.four{grid-template-columns:1fr}.hero{min-height:520px}header{align-items:flex-start;flex-direction:column}}.card{border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.045);box-shadow:var(--shadow);padding:20px}.card h2,.card h3{margin:0 0 8px}.card p{color:var(--muted)}.photo-card{overflow:hidden;padding:0}.photo-card img{width:100%;height:240px;object-fit:cover;display:block}.photo-card .pad{padding:18px}.list{color:var(--muted);padding-left:20px}.list li{margin:7px 0}.directory{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(max-width:800px){.directory{grid-template-columns:1fr}}.biz{border:1px solid var(--line);border-radius:16px;padding:14px;background:rgba(255,255,255,.035)}.biz strong{display:block}.biz span{color:var(--muted);font-size:14px}.notice{border:1px solid rgba(87,196,255,.32);background:rgba(87,196,255,.07);padding:14px;border-radius:16px;color:var(--muted)}.offer-bg{position:relative;background:linear-gradient(135deg,rgba(11,24,34,.96),rgba(7,16,22,.92));background-size:cover;background-position:center;background-repeat:no-repeat}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:900px){.two-col{grid-template-columns:1fr}}form{display:grid;gap:10px}label{font-weight:900;font-size:13px;color:var(--muted)}input,textarea,select{width:100%;padding:12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.035);color:var(--text)}textarea{min-height:130px}.faq{border-top:1px solid var(--line)}.faq:first-child{border-top:0}.faq-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0}.faq-question-link{text-decoration:none;flex:1}.faq-q{margin:0;font-size:17px;font-weight:950}.faq-question-link:hover .faq-q{text-decoration:underline;text-underline-offset:3px}.faq-toggle{border:0;background:transparent;color:var(--text);cursor:pointer}.chev{width:34px;height:34px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);display:grid;place-items:center;transition:transform .25s}.faq[aria-expanded=true] .chev{transform:rotate(180deg)}.faq-panel{overflow:hidden;max-height:0;transition:max-height .28s}.faq-inner{padding:0 0 14px;color:var(--muted)}footer{margin-top:34px;padding-top:20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:14px}.hidden{display:none}.source-note{font-size:12px;color:var(--muted)}

.section-intro{color:var(--muted);max-width:88ch;margin:0 0 16px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);padding:16px}.kpi strong{display:block;font-size:28px;line-height:1;margin-bottom:8px}.kpi span{color:var(--muted);font-size:14px}@media(max-width:900px){.kpi-grid{grid-template-columns:1fr 1fr}}@media(max-width:640px){.kpi-grid{grid-template-columns:1fr}}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:14px}@media(max-width:900px){.split{grid-template-columns:1fr}}
.feature-list{display:grid;gap:12px}.feature{border:1px solid var(--line);border-radius:16px;padding:14px;background:rgba(255,255,255,.035)}.feature h3{margin:0 0 6px}.feature p{margin:0;color:var(--muted)}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.cta-banner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;border:1px solid rgba(126,226,184,.28);background:rgba(126,226,184,.08);border-radius:18px;padding:16px 18px;margin-top:18px}.cta-banner p{margin:0;color:var(--muted)}
.breadcrumbs{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:14px;margin:16px 0}.breadcrumbs a{text-decoration:none}.breadcrumbs a:hover{text-decoration:underline}
.table-list{display:grid;gap:12px}.rank-card{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);padding:16px}.rank-card h3{margin:0 0 6px}.meta{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 10px}.meta .tag{font-size:12px;padding:6px 10px}.small{font-size:14px;color:var(--muted)}
.category-links{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.category-links a{display:block;border:1px solid var(--line);border-radius:18px;padding:18px;text-decoration:none;background:rgba(255,255,255,.04);box-shadow:var(--shadow)}.category-links h3{margin:0 0 6px}.category-links p{margin:0;color:var(--muted)}@media(max-width:900px){.category-links{grid-template-columns:1fr}}
.story-block{display:grid;grid-template-columns:.95fr 1.05fr;gap:14px;align-items:start}@media(max-width:900px){.story-block{grid-template-columns:1fr}}.story-block img{width:100%;height:100%;max-height:340px;object-fit:cover;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow)}
.link-list{display:grid;gap:8px}.link-list a{color:var(--text);text-decoration:none;font-weight:800}.link-list a:hover{text-decoration:underline}
.directory-note{font-size:13px;color:var(--muted);margin-top:10px}

.search-box{margin:14px 0 20px;display:flex;gap:10px;flex-wrap:wrap}.search-box input{flex:1;min-width:260px}.az{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.az a{border:1px solid var(--line);padding:7px 10px;border-radius:10px;text-decoration:none;color:var(--muted);font-weight:800}.az a:hover{color:var(--text);border-color:rgba(87,196,255,.45)}
.biz-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.badge{display:inline-block;border:1px solid rgba(255,209,102,.32);background:rgba(255,209,102,.08);padding:5px 9px;border-radius:999px;font-size:12px;font-weight:900;color:var(--gold);margin-bottom:8px}.detail-hero{display:grid;grid-template-columns:1fr .75fr;gap:14px;align-items:stretch}.detail-hero img{width:100%;height:100%;min-height:300px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}@media(max-width:900px){.detail-hero{grid-template-columns:1fr}.detail-hero img{min-height:220px}}
.quick-nav{position:sticky;top:0;z-index:4;background:rgba(7,16,22,.86);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:18px;padding:10px;margin:16px 0;display:flex;gap:8px;overflow:auto}.quick-nav a{white-space:nowrap;text-decoration:none;color:var(--muted);font-weight:800;border:1px solid var(--line);border-radius:999px;padding:7px 10px}.quick-nav a:hover{color:var(--text)}
.stat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}@media(max-width:900px){.stat-row{grid-template-columns:1fr 1fr}}.stat{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035);padding:14px}.stat strong{display:block;font-size:24px}.stat span{color:var(--muted);font-size:13px}
.timeline{border-left:2px solid rgba(87,196,255,.35);padding-left:18px}.timeline .event{margin:0 0 18px}.timeline .event strong{display:block;color:var(--text)}
.featured-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:900px){.featured-strip{grid-template-columns:1fr 1fr}}@media(max-width:620px){.featured-strip{grid-template-columns:1fr}}
.disclaimer{font-size:12px;color:var(--muted);border-top:1px solid var(--line);padding-top:10px;margin-top:12px}

/* Verification-safe listing visual: used when a specific business photo has not been verified. */
.listing-visual-panel{min-height:360px;border:1px solid var(--line);border-radius:22px;background:radial-gradient(700px 360px at 20% 0%,rgba(87,196,255,.16),transparent 60%),radial-gradient(700px 360px at 80% 0%,rgba(255,209,102,.12),transparent 60%),linear-gradient(180deg,rgba(18,40,56,.85),rgba(7,16,22,.96));box-shadow:var(--shadow);display:flex;align-items:flex-end;padding:22px;overflow:hidden;position:relative}.listing-visual-panel:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.04),transparent 40%);pointer-events:none}.listing-visual-panel .visual-copy{position:relative}.listing-visual-panel .visual-copy strong{display:block;font-size:clamp(26px,4vw,48px);line-height:.95;letter-spacing:-.04em}.listing-visual-panel .visual-copy span{display:block;color:var(--muted);margin-top:10px;max-width:48ch}.verified-note{font-size:13px;color:var(--muted);margin-top:10px}

/* V5 verification-first styles */
body{background:radial-gradient(1000px 520px at 10% -10%,rgba(87,196,255,.20),transparent),radial-gradient(780px 520px at 92% 0%,rgba(255,209,102,.13),transparent),linear-gradient(180deg,#03080d,#071016 36%,#031017)}
.home-gallery{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;margin-top:18px}.home-gallery img{width:100%;height:100%;min-height:260px;object-fit:cover;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow)}.home-gallery .stack{display:grid;gap:14px}.home-gallery .stack img{min-height:160px}@media(max-width:900px){.home-gallery{grid-template-columns:1fr}.home-gallery .stack{grid-template-columns:1fr 1fr}.home-gallery .stack img{min-height:140px}}@media(max-width:640px){.home-gallery .stack{grid-template-columns:1fr}}
.verified-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(max-width:850px){.verified-grid{grid-template-columns:1fr}}.verified-card{border:1px solid var(--line);border-radius:18px;padding:16px;background:rgba(255,255,255,.04)}.verified-card h3{margin:0 0 8px}.verified-card p{margin:4px 0;color:var(--muted);font-size:14px}.badge{display:inline-flex;border:1px solid rgba(126,226,184,.38);background:rgba(126,226,184,.09);color:var(--green);font-weight:900;padding:6px 10px;border-radius:999px;font-size:12px;margin-bottom:10px}.pending-note{border:1px solid rgba(255,209,102,.3);background:rgba(255,209,102,.07);border-radius:18px;padding:16px;color:var(--muted)}.source-list{font-size:13px;color:var(--muted);line-height:1.7}.source-list li{margin:6px 0}.count-pill{display:inline-flex;border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:999px;padding:7px 11px;color:var(--muted);font-weight:800;margin:3px}.hero.clean{min-height:520px}.hero.clean .inner{background:linear-gradient(0deg,rgba(3,7,11,.90),rgba(3,7,11,.10))}.image-credit{font-size:12px;color:var(--muted);margin-top:8px}.cta-strip{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;border:1px solid rgba(87,196,255,.28);background:rgba(87,196,255,.075);border-radius:18px;padding:16px 18px;margin:18px 0}.cta-strip p{margin:0;color:var(--muted)}

/* V6: simplified verification-first directory cards */
.verified-card h3{margin:0;font-size:18px}.verified-card p,.verified-card .badge{display:none}.verified-grid + .pending-note{margin-top:18px}

.mega-disclaimer{margin:22px 0}.category-stats{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}.category-jump{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}@media(max-width:900px){.category-jump{grid-template-columns:1fr}}.category-jump a{border:1px solid var(--line);border-radius:18px;padding:16px;text-decoration:none;background:rgba(255,255,255,.04)}.category-jump strong{display:block}.category-jump span{color:var(--muted);font-size:14px}.image-strip{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:12px;margin-top:18px}.image-strip img{width:100%;height:260px;object-fit:cover;border-radius:18px;border:1px solid var(--line);box-shadow:var(--shadow)}@media(max-width:900px){.image-strip{grid-template-columns:1fr}.image-strip img{height:220px}}.mega-section{margin-top:28px}.count-note{color:var(--muted);font-size:14px;margin:6px 0 12px}.homepage-note{border:1px solid rgba(87,196,255,.28);background:rgba(87,196,255,.07);border-radius:18px;padding:16px;color:var(--muted)}

.simple-note{color:var(--muted);font-size:14px}.verified-card h3{font-size:18px;line-height:1.3}.image-strip + .image-credit{margin-bottom:8px}

.verified-card h3 a{color:var(--text);text-decoration:none}
.verified-card h3 a:hover{text-decoration:underline;text-underline-offset:3px}
.pending-note p{margin:0 0 8px}
.pending-note p:last-child{margin-bottom:0}


/* NSB101 Version 11 additions */
.branch-line{font-size:13px;color:var(--muted);margin-top:4px}
.branch-line a{color:var(--text);font-weight:900}
.things-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
@media(max-width:950px){.things-grid{grid-template-columns:1fr}}
.thing-card{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:rgba(255,255,255,.045);box-shadow:var(--shadow)}
.thing-card img{width:100%;height:190px;object-fit:cover;display:block}
.thing-card .thing-body{padding:18px}
.thing-card h2{margin:0 0 8px;font-size:22px;line-height:1.1}
.thing-card .thing-cat{display:inline-flex;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:950;margin-bottom:8px}
.detail-list{display:grid;gap:8px;margin:14px 0;color:var(--muted);font-size:14px}
.detail-list div{border-top:1px solid var(--line);padding-top:8px}
.source-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.source-links a{font-size:13px;border:1px solid var(--line);border-radius:999px;padding:7px 10px;text-decoration:none;color:var(--text);background:rgba(255,255,255,.04)}
.price-note{border:1px solid rgba(255,209,102,.32);background:rgba(255,209,102,.08);border-radius:18px;padding:15px;margin:18px 0;color:var(--muted)}
.photo-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}
.photo-row img{height:210px;width:100%;object-fit:cover;border-radius:18px;border:1px solid var(--line)}
@media(max-width:850px){.photo-row{grid-template-columns:1fr 1fr}.photo-row img{height:170px}}


.todo-list{display:grid;gap:18px}.todo-card{display:grid;grid-template-columns:360px 1fr;gap:0;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:rgba(255,255,255,.045);box-shadow:var(--shadow)}.todo-card img{width:100%;height:100%;min-height:300px;object-fit:cover;display:block}.todo-body{padding:20px}.todo-body h2{margin:0 0 8px;font-size:27px}.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}.mini-grid p{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035);padding:12px;margin:0;color:var(--muted)}.source-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.source-links .tag{font-size:12px}.history-list{display:grid;gap:18px}.history-row{display:grid;grid-template-columns:330px 1fr;gap:0;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:rgba(255,255,255,.045);box-shadow:var(--shadow)}.history-row img{width:100%;height:100%;min-height:280px;object-fit:cover;display:block;filter:contrast(1.05)}.history-row div{padding:22px}.history-row h2{margin:0 0 8px;font-size:28px}.history-row p{color:var(--muted);font-size:17px}.offer-bg{position:relative;background:linear-gradient(135deg,rgba(11,24,34,.96),rgba(7,16,22,.92));background-size:cover;background-position:center;background-repeat:no-repeat}@media(max-width:900px){.todo-card,.history-row{grid-template-columns:1fr}.todo-card img,.history-row img{height:260px;min-height:260px}.mini-grid{grid-template-columns:1fr}}

/* V13 duplicate-image cleanup */
.hero.no-photo{background:linear-gradient(135deg,rgba(7,16,22,.98),rgba(13,34,48,.94));}
.offer-bg.home-boat-bg{background:linear-gradient(rgba(11,15,20,.72),rgba(11,15,20,.72)),url('/images/fishing-for-redfish-nsb-new-smyrna-beach-florida.webp');background-size:cover;background-position:center;background-repeat:no-repeat}
.image-strip{display:none!important}
.photo-card img{display:none}
.photo-card{background:linear-gradient(135deg,rgba(87,196,255,.08),rgba(255,209,102,.07));}
.unique-photo-panel{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin:18px 0;background:rgba(255,255,255,.04)}
.unique-photo-panel img{width:100%;height:min(440px,48vw);object-fit:cover;display:block}
.visual-card{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,rgba(87,196,255,.09),rgba(255,209,102,.06));padding:20px;box-shadow:var(--shadow)}

/* V14 FAQ and deep history additions */
.faq-mega{display:grid;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);padding:16px}
.faq-item h2,.faq-item h3{margin:0 0 8px;font-size:18px;line-height:1.25}
.faq-item p{margin:0;color:var(--muted)}
.source-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.source-links a{border:1px solid var(--line);border-radius:999px;padding:6px 10px;text-decoration:none;color:var(--muted);font-size:13px}
.history-timeline{display:grid;gap:14px}
.history-block{border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.04);padding:20px}
.history-block h2{margin:0 0 10px}
.history-block p{color:var(--muted)}
.callout-soft{border:1px solid rgba(255,209,102,.3);background:rgba(255,209,102,.07);border-radius:18px;padding:16px;color:var(--muted)}
.about-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}}

/* V15 FAQ dropdown accordion */
.faq-accordion{display:grid;gap:12px;margin-top:18px}
.faq-accordion details{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);overflow:hidden}
.faq-accordion summary{cursor:pointer;list-style:none;padding:16px 18px;font-weight:950;font-size:18px;line-height:1.3;display:flex;align-items:center;gap:12px}
.faq-accordion summary::-webkit-details-marker{display:none}
.faq-accordion summary::after{content:"+";margin-left:auto;border:1px solid var(--line);width:32px;height:32px;border-radius:10px;display:grid;place-items:center;color:var(--gold);font-weight:950}
.faq-accordion details[open] summary::after{content:"–"}
.faq-answer{padding:0 18px 18px;color:var(--muted);font-size:16px;line-height:1.75}
.faq-answer p{margin:0 0 12px}
.faq-tools{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}
.faq-tools button{border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);padding:10px 14px;border-radius:12px;font-weight:900;cursor:pointer}

.about-expanded .history-block{background:linear-gradient(135deg,rgba(255,255,255,.045),rgba(87,196,255,.035))}
.about-expanded .history-block h2{font-size:22px}
.about-expanded .history-block p{font-size:16px;line-height:1.75}


/* V19 things-to-do expansion */
.todo-card .card-intro{font-size:16px;line-height:1.7;color:var(--muted)}
.todo-summary{display:grid;gap:10px;margin:14px 0}
.todo-summary p{margin:0;color:var(--muted)}
.todo-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.todo-actions .btn{padding:10px 14px;font-size:14px}
.detail-sections{display:grid;gap:14px}
.detail-block{border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.04);padding:20px}
.detail-block h2{margin:0 0 10px;font-size:26px;letter-spacing:-.02em}
.detail-block p{color:var(--muted);font-size:16px;line-height:1.8}
.detail-block ul{margin:0;padding-left:18px;color:var(--muted)}
.detail-block li{margin:8px 0}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.info-grid .detail-block{padding:16px}
@media(max-width:900px){.info-grid{grid-template-columns:1fr}}
.back-row{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}
.quick-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}
.quick-facts .fact{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035);padding:14px}
.quick-facts .fact strong{display:block;margin-bottom:6px}
@media(max-width:900px){.quick-facts{grid-template-columns:1fr}}

/* V20 combined About NSB + History page */
.about-hub-grid{display:grid;gap:18px}
.about-topic-card{display:grid;grid-template-columns:360px 1fr;gap:0;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:rgba(255,255,255,.045);box-shadow:var(--shadow)}
.about-topic-card img{width:100%;height:100%;min-height:310px;object-fit:cover;display:block}
.about-topic-body{padding:22px}
.about-topic-body h2{margin:0 0 8px;font-size:29px;line-height:1.08}
.about-topic-body p{color:var(--muted);font-size:16px;line-height:1.7}
.about-topic-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.about-topic-actions .btn{padding:10px 14px;font-size:14px}
.about-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}
.about-mini-grid p{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035);padding:12px;margin:0;color:var(--muted)}
.deep-readable p{font-size:17px;line-height:1.8;color:var(--muted)}
@media(max-width:900px){.about-topic-card{grid-template-columns:1fr}.about-topic-card img{height:260px;min-height:260px}.about-mini-grid{grid-template-columns:1fr}}


.ai-note{font-size:.72rem;opacity:.75;margin-top:.45rem;line-height:1.35}.ai-note a{color:inherit}.ai-note-wrap{margin-top:.35rem}

/* V27 beach atmosphere background behind containers */
header,.hero,.card,.thing-card,.todo-card,.history-row,.about-topic-card,.rank-card,.verified-card,.biz,.visual-card,.unique-photo-panel,.quick-nav,.notice,.homepage-note,.callout-soft,.faq-item,.faq-accordion details,.history-block,.detail-block{backdrop-filter:saturate(1.06) blur(1.2px)}

/* V34 About NSB history-first rebuild */
.history-hub-grid{display:grid;gap:18px}
.history-topic-card{display:grid;grid-template-columns:340px 1fr;gap:0;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:rgba(255,255,255,.045);box-shadow:var(--shadow)}
.history-topic-card img{width:100%;height:100%;min-height:310px;object-fit:cover;display:block}
.history-topic-body{padding:22px}
.history-topic-body h2{margin:0 0 8px;font-size:29px;line-height:1.08}
.history-topic-body p{color:var(--muted);font-size:16px;line-height:1.75}
.history-detail-list{display:grid;gap:14px}
.history-source-note{font-size:13px;color:var(--muted);border-top:1px solid var(--line);padding-top:10px;margin-top:14px}
@media(max-width:900px){.history-topic-card{grid-template-columns:1fr}.history-topic-card img{height:260px;min-height:260px}}

/* V37 hometown search tools */
.local-search-card{
  border:1px solid rgba(87,196,255,.34);
  border-radius:24px;
  padding:18px;
  margin:18px 0 24px;
  background:
    linear-gradient(135deg,rgba(87,196,255,.10),rgba(255,209,102,.055)),
    rgba(8,22,31,.82);
  box-shadow:0 18px 55px rgba(0,0,0,.28);
}
.local-search-card .search-label{
  display:block;
  font-weight:950;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--gold);
  font-size:13px;
  margin-bottom:8px;
}
.local-search-card input{
  width:100%;
  box-sizing:border-box;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px 18px;
  background:rgba(255,255,255,.055);
  color:var(--text);
  font-size:18px;
  outline:none;
}
.local-search-card input:focus{
  border-color:rgba(87,196,255,.7);
  box-shadow:0 0 0 4px rgba(87,196,255,.10);
}
.search-help{
  color:var(--muted);
  margin:10px 0 0;
  line-height:1.6;
}
.search-results-note{
  display:inline-flex;
  margin-top:12px;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--muted);
  background:rgba(255,255,255,.035);
  font-size:14px;
}
.search-hidden{display:none!important}
.directory-empty,.faq-empty{
  display:none;
  border:1px solid rgba(255,209,102,.28);
  border-radius:18px;
  padding:16px;
  color:var(--muted);
  background:rgba(255,209,102,.06);
  margin:12px 0 20px;
}
.directory-empty.show,.faq-empty.show{display:block}

/* V38 homepage experience feature */
.experience-feature{
  border:1px solid var(--line);
  border-radius:28px;
  padding:22px;
  background:linear-gradient(135deg,rgba(87,196,255,.08),rgba(255,209,102,.055)),rgba(8,22,31,.82);
  box-shadow:var(--shadow);
  margin:16px 0 28px;
}
.experience-feature h2{margin:0 0 8px;font-size:34px;letter-spacing:-.02em}
.experience-feature .lead{color:var(--muted);font-size:17px;line-height:1.7;max-width:900px;margin:0 0 18px}
.experience-options{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.experience-option{position:relative;min-height:245px;border:1px solid var(--line);border-radius:22px;overflow:hidden;text-decoration:none;background:#08161f;display:flex;align-items:flex-end;box-shadow:0 14px 40px rgba(0,0,0,.28)}
.experience-option img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62;transition:transform .35s ease,opacity .35s ease}
.experience-option:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(2,8,12,.08),rgba(2,8,12,.82))}
.experience-option .content{position:relative;z-index:1;padding:18px}
.experience-option h3{margin:0 0 8px;font-size:24px}
.experience-option p{margin:0;color:rgba(230,242,250,.86);line-height:1.5}
.experience-option:hover img{transform:scale(1.05);opacity:.78}
@media(max-width:1000px){.experience-options{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.experience-options{grid-template-columns:1fr}.experience-feature h2{font-size:28px}.experience-option{min-height:220px}}

/* V42 functional search result cards */
.faq-search-results,.directory-search-results{display:grid;gap:12px;margin:14px 0 22px}
.search-result-card{
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.045);
  padding:16px 18px;
  box-shadow:0 12px 36px rgba(0,0,0,.22);
}
.search-result-card h3{margin:0 0 8px;font-size:20px}
.search-result-card p{margin:0 0 12px;color:var(--muted);line-height:1.65}
.search-result-card a{font-weight:950;color:var(--text)}
.search-result-card .mini-label{display:inline-flex;margin-bottom:8px;color:var(--gold);font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:950}
.search-result-actions{display:flex;gap:10px;flex-wrap:wrap}
.search-result-actions a{
  display:inline-flex;
  border:1px solid rgba(87,196,255,.34);
  border-radius:999px;
  padding:8px 12px;
  text-decoration:none;
  background:rgba(87,196,255,.08);
}

body,input,textarea,select,button,.pill,.tag,.btn,.brand span,h1,h2,h3,h4,h5,h6,.section-title,label{font-family:'Bree Serif',Georgia,'Times New Roman',serif}

/* V55 homepage transparent container cleanup */
.hero.no-photo{
  background:rgba(8,22,31,.72)!important;
  min-height:430px;
}
.hero.no-photo .inner{
  background:linear-gradient(0deg,rgba(3,7,11,.74),rgba(3,7,11,.16));
}
.experience-feature.transparent-box{
  background:rgba(8,22,31,.72)!important;
}
.experience-feature.transparent-box .experience-option{
  background:rgba(255,255,255,.045)!important;
  min-height:175px;
}
.experience-feature.transparent-box .experience-option:after{
  display:none!important;
}
.experience-feature.transparent-box .experience-option .content{
  position:relative;
  z-index:1;
}

/* V56: make all major containers match the transparent listing-help box style */
.card,
.biz,
.notice,
.pending-note,
.callout-soft,
.local-search-card,
.search-result-card,
.faq-accordion details,
.detail-block,
.detail-hero,
.history-topic-card,
.history-block,
.about-topic-card,
.rank-card,
.verified-card,
.visual-card,
.unique-photo-panel,
.quick-nav,
.homepage-note,
.experience-feature,
.experience-option,
.kpi,
.todo-card,
.thing-card,
.history-row,
form,
.offer-bg {
  background: rgba(8,22,31,.58) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 16px 45px rgba(0,0,0,.24) !important;
  backdrop-filter: saturate(1.05) blur(1.4px);
}

.hero.no-photo {
  background: rgba(8,22,31,.58) !important;
  min-height: auto !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 16px 45px rgba(0,0,0,.24) !important;
  backdrop-filter: saturate(1.05) blur(1.4px);
}

.hero.no-photo .inner {
  position: relative !important;
  inset: auto !important;
  padding: 44px 28px !important;
  background: transparent !important;
}

.experience-feature.transparent-box {
  background: rgba(8,22,31,.58) !important;
}

.experience-feature.transparent-box .experience-option {
  background: rgba(8,22,31,.48) !important;
  min-height: 175px !important;
}

.experience-feature.transparent-box .experience-option:after {
  display: none !important;
}

.hero h1,
.hero.no-photo h1 {
  margin-top: 0 !important;
}

footer {
  background: rgba(8,22,31,.30);
  border-radius: 18px;
  padding: 18px;
}

/* V57 final homepage hero and experience image fix */
body.home-page-fix {}

.hero.no-photo {
  background: rgba(8,22,31,.58) !important;
  min-height: auto !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 16px 45px rgba(0,0,0,.24) !important;
  backdrop-filter: saturate(1.05) blur(1.4px);
}

.hero.no-photo .inner {
  position: relative !important;
  inset: auto !important;
  padding: 46px 28px !important;
  background: transparent !important;
}

.experience-feature.transparent-box,
.experience-feature {
  background: rgba(8,22,31,.58) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 16px 45px rgba(0,0,0,.24) !important;
  backdrop-filter: saturate(1.05) blur(1.4px);
}

.experience-option {
  position: relative !important;
  min-height: 245px !important;
  overflow: hidden !important;
  background: rgba(8,22,31,.40) !important;
}

.experience-option img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  opacity: .62 !important;
  display: block !important;
}

.experience-option:after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg,rgba(2,8,12,.08),rgba(2,8,12,.82)) !important;
}

.experience-option .content {
  position: relative !important;
  z-index: 2 !important;
}

/* V58: center and organize main containers sitewide */
.wrap{
  max-width:1180px;
  margin-left:auto;
  margin-right:auto;
}

header{
  justify-content:center;
  text-align:center;
  row-gap:16px;
}

.brand{
  justify-content:center;
}

nav{
  justify-content:center;
}

.hero,
.card,
.notice,
.pending-note,
.callout-soft,
.local-search-card,
.experience-feature,
.detail-hero,
.history-topic-card,
.todo-card,
.thing-card,
.rank-card,
.verified-card,
.visual-card,
.unique-photo-panel{
  margin-left:auto;
  margin-right:auto;
}

.hero .inner,
.hero.no-photo .inner{
  text-align:center !important;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

.hero h1,
.hero.no-photo h1{
  max-width:940px;
  margin-left:auto !important;
  margin-right:auto !important;
}

.hero .sub,
.sub{
  margin-left:auto;
  margin-right:auto;
  text-align:center;
}

.cta,
.hero-actions{
  justify-content:center;
}

.section-title{
  text-align:center;
}

.section-intro{
  margin-left:auto;
  margin-right:auto;
  text-align:center;
}

.grid{
  justify-items:stretch;
}

.grid > .card,
.grid > a.card,
.kpi,
.photo-card .pad,
.experience-feature{
  text-align:center;
}

.card p,
.notice p,
.pending-note p,
.callout-soft p,
.local-search-card p,
.experience-feature .lead{
  margin-left:auto;
  margin-right:auto;
}

.experience-feature{
  padding:26px;
}

.experience-feature h2,
.experience-feature .lead{
  text-align:center;
}

.experience-options{
  align-items:stretch;
}

.experience-option{
  text-align:left;
}

.experience-option img{
  display:block !important;
}

.experience-option .content{
  text-align:left;
}

footer{
  justify-content:center;
  text-align:center;
}

footer > div{
  width:100%;
}

/* Keep longer reading sections easy to read */
.faq-answer,
.detail-block,
.history-topic-body,
.search-result-card,
.biz,
.directory,
form,
input,
textarea,
select,
.list{
  text-align:left;
}

.detail-block p,
.history-topic-body p,
.faq-answer p,
.search-result-card p{
  margin-left:0;
  margin-right:0;
}

/* Make the homepage hero feel intentional instead of empty */
.hero.no-photo{
  padding:0;
}
.hero.no-photo .inner{
  min-height:300px;
}

/* V59: move directory CTA above listing help */
.directory-button-row{
  display:flex;
  justify-content:flex-end;
  margin:28px 0 10px;
}
.directory-button-row .btn{
  min-width:240px;
  justify-content:center;
}
@media(max-width:700px){
  .directory-button-row{
    justify-content:center;
  }
}

/* V60: hometown blog preview replacing old homepage mission boxes */
.hometown-blog-widget{
  width:100%;
  max-width:none;
  margin:0 auto 34px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:24px;
  background:rgba(8,22,31,.58);
  box-shadow:0 16px 45px rgba(0,0,0,.24);
  backdrop-filter:saturate(1.05) blur(1.4px);
  overflow:hidden;
}
.hometown-blog-widget .blog-scroll{
  max-height:360px;
  overflow-y:auto;
  padding:16px;
}
.blog-preview-card{
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  background:rgba(255,255,255,.035);
  overflow:hidden;
}
.blog-cover{
  height:190px;
  display:grid;
  place-items:center;
  background:
    linear-gradient(180deg,rgba(3,7,11,.10),rgba(3,7,11,.42)),
    url('/assets/images/nsb-water-sandbar.webp');
  background-size:cover;
  background-position:center;
}
.book-mark{
  border:1px solid rgba(255,255,255,.28);
  border-radius:16px;
  padding:12px 18px;
  background:rgba(8,22,31,.58);
  color:var(--text);
  font-weight:950;
  letter-spacing:.08em;
}
.blog-preview-body{
  padding:18px;
  text-align:center;
}
.blog-preview-body h2{
  margin:0 0 8px;
  font-size:30px;
}
.blog-preview-body p{
  margin:0 auto;
  color:var(--muted);
  max-width:48ch;
}

/* V61: center directory CTA directly above listing help */
.directory-button-row{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  margin:32px auto 12px !important;
  width:100%;
}
.directory-button-row .btn{
  min-width:240px;
  justify-content:center;
  text-align:center;
}

/* V62: logo wrapper fits the NSB101 book exactly with no visible container edges */
.logo{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  height:auto !important;
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
  line-height:0 !important;
  flex:0 0 auto !important;
}

.logo img{
  display:block !important;
  width:54px !important;
  height:auto !important;
  object-fit:contain !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

.brand{
  align-items:center !important;
  gap:12px !important;
}
.branch-line{display:flex;align-items:center;}



/* V64: FAQ book flip-through layout */
.faq-book-wrap{
  padding:22px;
}
.faq-book-hero{
  min-height:320px;
}
.faq-book-hero .sub{max-width:72ch}
.book-toolbar{
  display:grid;
  grid-template-columns:1.2fr .9fr;
  gap:16px;
  align-items:end;
  margin-bottom:18px;
}
.book-search-block,
.book-nav-block{
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  background:rgba(255,255,255,.03);
  padding:16px;
}
.book-search-block label{
  display:block;
  color:var(--text);
  font-size:15px;
  margin-bottom:8px;
}
.book-helper{
  margin:8px 0 0;
  color:var(--muted);
  font-size:14px;
}
.book-nav-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:10px;
  align-items:center;
}
.book-nav-row select{
  min-width:0;
}
.book-count{
  margin-top:10px;
  text-align:center;
  color:var(--muted);
  font-weight:900;
}
.faq-book-search-results{
  display:grid;
  gap:12px;
  margin:0 0 18px;
}
.faq-book-search-empty{
  display:none;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(255,255,255,.035);
  padding:14px 16px;
  color:var(--muted);
  margin:0 0 18px;
}
.faq-book-search-empty.show{display:block}
.book-frame{
  position:relative;
  min-height:850px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:28px;
  overflow:hidden;
  background:linear-gradient(135deg,rgba(8,22,31,.92),rgba(10,28,40,.78));
  box-shadow:0 20px 60px rgba(0,0,0,.28);
}
.book-spine{
  position:absolute;
  inset:0 auto 0 0;
  width:42px;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border-right:1px solid rgba(255,255,255,.10);
}
.book-page{
  display:none;
  min-height:850px;
  padding:28px 28px 28px 62px;
}
.book-page.active{
  display:block;
  animation:bookPageIn .28s ease;
}
@keyframes bookPageIn{from{opacity:.25;transform:translateX(18px)}to{opacity:1;transform:none}}
.book-page-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.12);
  margin-bottom:18px;
}
.book-chapter-label{
  color:#9fdcff;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:950;
  margin-bottom:4px;
}
.book-page-header h2{
  margin:0 0 8px;
  font-size:36px;
  line-height:1.06;
}
.book-page-lead{
  margin:0;
  color:var(--muted);
  max-width:68ch;
}
.page-chip{
  flex:0 0 auto;
  border:1px solid rgba(87,196,255,.32);
  border-radius:999px;
  padding:10px 14px;
  background:rgba(87,196,255,.08);
  font-weight:900;
  color:var(--text);
}
.book-cover-layout{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:20px;
  align-items:center;
  margin-bottom:18px;
}
.book-cover-art{
  border:1px solid rgba(255,255,255,.14);
  border-radius:24px;
  padding:20px;
  background:rgba(255,255,255,.03);
  display:grid;
  place-items:center;
}
.book-cover-art img{width:100%;max-width:210px;height:auto;display:block}
.book-cover-copy{display:grid;gap:14px}
.book-note{
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  background:rgba(255,255,255,.035);
  padding:16px 18px;
}
.book-note strong{display:block;margin-bottom:8px;font-size:18px}
.book-note p{margin:0;color:var(--muted)}
.book-note ul{margin:0;padding-left:22px;color:var(--muted)}
.book-note li{margin:6px 0}
.toc-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.toc-item{
  text-align:left;
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  background:rgba(255,255,255,.035);
  color:var(--text);
  padding:16px 18px;
  cursor:pointer;
}
.toc-item strong{display:block;font-size:20px;margin:4px 0}
.toc-item span{display:block;color:var(--muted)}
.toc-page{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#9fdcff;font-weight:950}
.book-content-scroll{
  display:grid;
  gap:14px;
  max-height:720px;
  overflow:auto;
  padding-right:8px;
}
.book-qa{
  position:relative;
  display:grid;
  grid-template-columns:56px 1fr;
  gap:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  background:rgba(255,255,255,.035);
  padding:16px 18px;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.book-qa.flash{
  border-color:rgba(87,196,255,.60);
  box-shadow:0 0 0 3px rgba(87,196,255,.10);
  transform:translateY(-2px);
}
.book-qa-number{
  width:56px;
  height:56px;
  border-radius:18px;
  border:1px solid rgba(87,196,255,.26);
  background:rgba(87,196,255,.08);
  display:grid;
  place-items:center;
  font-weight:950;
  font-size:18px;
}
.book-qa-body h3{
  margin:0 0 8px;
  font-size:24px;
  line-height:1.2;
}
.book-qa-body p{
  margin:0 0 10px;
  color:var(--muted);
  line-height:1.7;
}
.book-qa-body p:last-child{margin-bottom:0}
.source-pill-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.source-pill{
  text-decoration:none;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:rgba(255,255,255,.04);
  padding:10px 14px;
  font-weight:900;
  color:var(--text);
}
.source-pill:hover{border-color:rgba(87,196,255,.45)}
.book-search-result-card{
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(255,255,255,.04);
  padding:16px 18px;
}
.book-search-result-card .result-chip{
  display:inline-flex;
  margin-bottom:8px;
  color:#9fdcff;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:950;
}
.book-search-result-card h3{margin:0 0 8px;font-size:21px}
.book-search-result-card p{margin:0 0 12px;color:var(--muted);line-height:1.6}
.book-search-result-card .search-result-actions{display:flex;gap:10px;flex-wrap:wrap}
.book-search-result-card .search-result-actions button,
.book-search-result-card .search-result-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(87,196,255,.32);
  border-radius:999px;
  background:rgba(87,196,255,.08);
  padding:8px 12px;
  color:var(--text);
  font-weight:900;
  text-decoration:none;
  cursor:pointer;
}
@media(max-width:960px){
  .book-toolbar{grid-template-columns:1fr}
  .book-cover-layout{grid-template-columns:1fr}
}
@media(max-width:760px){
  .book-nav-row{grid-template-columns:1fr}
  .book-frame,.book-page{min-height:auto}
  .book-page{padding:22px 18px 22px 48px}
  .book-content-scroll{max-height:none}
  .book-page-header{flex-direction:column}
  .toc-grid{grid-template-columns:1fr}
  .book-qa{grid-template-columns:1fr}
  .book-qa-number{width:48px;height:48px}
}


/* FAQ BOOK SINGLE PAGE UPGRADE */

.faq-detail-page .book-content-scroll{max-height:none;overflow:visible;padding-right:0}
.book-single-layout{display:grid;grid-template-columns:1fr;gap:22px;align-items:start}
.book-single-layout.has-image{grid-template-columns:minmax(240px,330px) 1fr}
.faq-page-figure{margin:0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:24px;overflow:hidden}
.faq-page-figure img{width:100%;height:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.faq-page-figure figcaption{padding:10px 14px;font-size:14px;color:var(--muted);background:rgba(2,10,18,.66)}
.faq-page-copy{display:grid;gap:14px;align-content:start}
.faq-book-single{display:block;padding:0;background:transparent;border:none;box-shadow:none}
.faq-book-single .book-qa-number{margin-bottom:2px}
.faq-book-single .book-note{background:rgba(255,255,255,.035)}
.faq-book-single .book-note strong{font-size:17px}
@media (max-width: 860px){
  .book-single-layout.has-image{grid-template-columns:1fr}
  .faq-page-figure img{aspect-ratio:16/10}
}


/* V66 FAQ BOOK POLISH */

.faq-book-wrap{
  padding:28px;
}
.faq-book-wrap .section-title,
.section-title + .faq-book-wrap{position:relative}
.book-toolbar{
  grid-template-columns:1.15fr .95fr;
  gap:18px;
  margin-bottom:20px;
}
.book-search-block,
.book-nav-block{
  border:1px solid rgba(123, 215, 255, .16);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(8,26,38,.86), rgba(6,19,29,.78));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  padding:18px 18px 16px;
}
.book-search-block label{
  font-weight:900;
  text-transform:none;
  letter-spacing:.01em;
}
.book-helper{
  font-size:14px;
}
.book-nav-row{
  grid-template-columns:1fr;
}
.book-nav-row > .btn{
  display:none;
}
.book-nav-row select{
  width:100%;
  min-height:50px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  padding:0 16px;
}
.book-count{
  margin-top:12px;
  font-size:14px;
  letter-spacing:.02em;
}
.book-frame{
  position:relative;
  min-height:900px;
  border:1px solid rgba(123, 215, 255, .14);
  border-radius:30px;
  overflow:hidden;
  background:linear-gradient(135deg, rgba(5,17,26,.94), rgba(8,26,38,.82));
  box-shadow:0 24px 60px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.04);
}
.book-spine{
  width:46px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border-right:1px solid rgba(255,255,255,.08);
}
.book-page{
  position:relative;
  min-height:900px;
  padding:32px 38px 34px 72px;
}
.book-page::before{
  content:"";
  position:absolute;
  inset:18px 18px 18px 56px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(249,244,234,.985) 0%, rgba(242,234,220,.965) 100%);
  box-shadow:0 22px 40px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.92), inset 0 -1px 0 rgba(188,165,132,.22);
}
.book-page > *{
  position:relative;
  z-index:1;
}
.book-page-header{
  padding:0 10px 16px;
  border-bottom:1px solid rgba(42,62,83,.14);
  margin:0 4px 18px;
}
.book-chapter-label{
  color:#5d7690;
  letter-spacing:.11em;
}
.book-page-header h2,
.book-page .book-note strong,
.book-page .book-qa-body h3,
.book-page .toc-item strong,
.book-page .page-chip,
.book-page .book-qa-number,
.book-page .toc-page,
.book-page .source-pill,
.book-page .book-search-result-card h3{
  color:#173047;
}
.book-page-header h2{
  font-size:42px;
  line-height:1.02;
  text-wrap:balance;
}
.book-page-lead,
.book-page .book-note p,
.book-page .book-note ul,
.book-page .book-note li,
.book-page .faq-page-figure figcaption,
.book-page .source-pill,
.book-page .book-search-result-card p,
.book-page .book-qa-body p{
  color:#475c70;
}
.page-chip{
  border-color:rgba(23,48,71,.16);
  background:rgba(23,48,71,.06);
}
.book-cover-layout{
  align-items:start;
  gap:22px;
  padding:0 8px;
}
.book-cover-art,
.book-note,
.toc-item,
.faq-page-figure,
.book-search-result-card,
.book-qa{
  background:rgba(255,255,255,.42);
  border:1px solid rgba(23,48,71,.10);
  box-shadow:0 10px 24px rgba(8,23,36,.07);
  backdrop-filter:blur(2px);
}
.book-cover-art{
  padding:24px;
}
.book-note{
  border-radius:18px;
}
.toc-grid{
  padding:2px 8px 0;
}
.toc-item{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.toc-item:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(8,23,36,.12);
  border-color:rgba(23,48,71,.20);
}
.toc-page{
  color:#58708a;
}
.book-content-scroll{
  max-height:690px;
  padding:4px 12px 0 8px;
}
.book-content-scroll::-webkit-scrollbar{width:10px}
.book-content-scroll::-webkit-scrollbar-thumb{background:rgba(23,48,71,.18);border-radius:999px}
.book-qa-number{
  border-color:rgba(23,48,71,.14);
  background:rgba(23,48,71,.07);
}
.book-page-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:58px;
  height:58px;
  border-radius:999px;
  border:1px solid rgba(123,215,255,.20);
  background:rgba(5,20,32,.72);
  color:#f7fbff;
  font-size:34px;
  line-height:1;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:0 10px 22px rgba(0,0,0,.24);
  transition:transform .18s ease, background .18s ease, opacity .18s ease;
}
.book-page-arrow:hover{
  transform:translateY(-50%) scale(1.03);
  background:rgba(10,31,48,.88);
}
.book-page-arrow:disabled{
  opacity:.35;
  cursor:not-allowed;
}
.book-page-arrow-prev{left:10px}
.book-page-arrow-next{right:14px}
.faq-detail-page .book-content-scroll{
  max-height:none;
  overflow:visible;
  padding-right:8px;
}
.book-single-layout{
  gap:24px;
  padding:0 8px;
}
.book-single-layout.has-image{
  grid-template-columns:minmax(250px, 335px) 1fr;
}
.faq-page-copy{
  gap:16px;
}
.book-search-result-card .search-result-actions button,
.book-search-result-card .search-result-actions a,
.book-page .source-pill,
.book-page .btn,
.book-page button,
.book-page select{
  font-family:inherit;
}
.book-page .source-pill{
  background:rgba(23,48,71,.05);
  border-color:rgba(23,48,71,.12);
}
.book-search-result-card .search-result-actions button{
  background:#173047;
  border-color:#173047;
  color:#fff;
}
.book-search-result-card .search-result-actions button:hover{
  background:#0e2436;
}
@media (max-width: 980px){
  .book-toolbar{grid-template-columns:1fr}
  .book-frame{min-height:820px}
  .book-page{padding:28px 28px 30px 62px}
  .book-page::before{inset:16px 16px 16px 50px}
  .book-page-header h2{font-size:36px}
}
@media (max-width: 760px){
  .faq-book-wrap{padding:18px}
  .book-page{padding:20px 16px 22px 48px}
  .book-page::before{inset:12px 12px 12px 42px;border-radius:20px}
  .book-page-header{padding:0 2px 14px;margin:0 0 14px}
  .book-page-header h2{font-size:30px}
  .book-page-arrow{width:46px;height:46px;font-size:28px}
  .book-page-arrow-prev{left:6px}
  .book-page-arrow-next{right:6px}
  .book-cover-layout,.book-single-layout,.book-single-layout.has-image{grid-template-columns:1fr}
  .book-content-scroll{max-height:none;padding:2px 2px 0 0}
}

/* V67: final NSB101.COM book logo positioning */
.logo{
  background:transparent!important;
  border:none!important;
  box-shadow:none!important;
  border-radius:0!important;
  padding:0!important;
  overflow:visible!important;
}
.logo img{
  width:78px!important;
  height:auto!important;
  object-fit:contain!important;
  display:block!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.brand{
  gap:12px!important;
}
@media(max-width:700px){
  .logo img{width:68px!important;}
}

/* V68: FAQ mobile book pages fit one screen and arrows stay centered while scrolling */
.book-page-arrow{
  position:fixed !important;
  top:50dvh !important;
  transform:translateY(-50%) !important;
  z-index:9999 !important;
}
.book-page-arrow-prev{
  left:max(10px, calc((100vw - 1180px) / 2 + 10px)) !important;
}
.book-page-arrow-next{
  right:max(10px, calc((100vw - 1180px) / 2 + 10px)) !important;
}
.book-page-arrow:hover{
  transform:translateY(-50%) scale(1.04) !important;
}

@media(max-width:760px){
  .faq-book-wrap{
    padding:12px !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }

  .book-toolbar{
    gap:10px !important;
    margin-bottom:12px !important;
  }

  .book-search-block,
  .book-nav-block{
    padding:12px !important;
    border-radius:18px !important;
  }

  .book-frame{
    min-height:calc(100dvh - 34px) !important;
    height:calc(100dvh - 34px) !important;
    max-height:calc(100dvh - 34px) !important;
    border-radius:22px !important;
    overflow:hidden !important;
  }

  .book-spine{
    width:28px !important;
  }

  .book-page{
    min-height:100% !important;
    height:100% !important;
    max-height:100% !important;
    padding:14px 12px 14px 34px !important;
    overflow:hidden !important;
  }

  .book-page::before{
    inset:8px 8px 8px 29px !important;
    border-radius:18px !important;
  }

  .book-page-header{
    margin:0 0 8px !important;
    padding:0 4px 8px !important;
    gap:6px !important;
  }

  .book-page-header h2{
    font-size:clamp(22px, 6vw, 30px) !important;
    line-height:1.08 !important;
    margin-bottom:5px !important;
  }

  .book-page-lead{
    font-size:14px !important;
    line-height:1.45 !important;
  }

  .book-chapter-label{
    font-size:10px !important;
    margin-bottom:3px !important;
  }

  .page-chip{
    font-size:11px !important;
    padding:7px 9px !important;
  }

  .book-content-scroll{
    max-height:calc(100dvh - 165px) !important;
    height:calc(100dvh - 165px) !important;
    overflow-y:auto !important;
    padding:2px 4px 8px 0 !important;
    -webkit-overflow-scrolling:touch !important;
  }

  .faq-detail-page .book-content-scroll{
    max-height:calc(100dvh - 165px) !important;
    height:calc(100dvh - 165px) !important;
    overflow-y:auto !important;
  }

  .book-single-layout,
  .book-single-layout.has-image{
    display:block !important;
    padding:0 !important;
  }

  .faq-page-figure{
    margin:0 0 10px !important;
    border-radius:16px !important;
  }

  .faq-page-figure img{
    aspect-ratio:16/9 !important;
    max-height:150px !important;
  }

  .faq-page-figure figcaption{
    font-size:11px !important;
    padding:6px 9px !important;
  }

  .faq-page-copy{
    gap:10px !important;
  }

  .book-note{
    border-radius:16px !important;
    padding:12px 13px !important;
  }

  .book-note strong{
    font-size:17px !important;
    margin-bottom:6px !important;
  }

  .book-note p,
  .book-note li{
    font-size:16px !important;
    line-height:1.55 !important;
  }

  .book-cover-layout{
    display:block !important;
    padding:0 !important;
  }

  .book-cover-art{
    max-width:180px !important;
    margin:0 auto 10px !important;
    padding:12px !important;
    border-radius:18px !important;
  }

  .toc-grid{
    display:block !important;
    padding:0 !important;
  }

  .toc-item{
    width:100% !important;
    margin:0 0 8px !important;
    border-radius:15px !important;
    padding:12px !important;
  }

  .toc-item strong{
    font-size:17px !important;
  }

  .book-page-arrow{
    width:48px !important;
    height:48px !important;
    font-size:34px !important;
    top:50dvh !important;
    background:rgba(5,20,32,.80) !important;
    border-color:rgba(123,215,255,.22) !important;
  }

  .book-page-arrow-prev{
    left:6px !important;
  }

  .book-page-arrow-next{
    right:6px !important;
  }
}

@media(max-width:420px){
  .book-frame{
    height:calc(100dvh - 22px) !important;
    min-height:calc(100dvh - 22px) !important;
    max-height:calc(100dvh - 22px) !important;
  }

  .book-page-header h2{
    font-size:clamp(20px, 6vw, 26px) !important;
  }

  .book-content-scroll,
  .faq-detail-page .book-content-scroll{
    max-height:calc(100dvh - 150px) !important;
    height:calc(100dvh - 150px) !important;
  }

  .book-note p,
  .book-note li{
    font-size:15px !important;
  }
}

/* V68 arrow visibility guard */
.book-page-arrow{
  opacity:0;
  pointer-events:none;
}
.book-page-arrow.book-arrow-visible{
  opacity:1;
  pointer-events:auto;
}

/* V69: FAQ book arrows hover on the screen center anytime the book is visible */
.book-page-arrow{
  position:fixed !important;
  top:50vh !important;
  top:50dvh !important;
  transform:translateY(-50%) !important;
  z-index:2147483000 !important;
  width:64px !important;
  height:64px !important;
  border-radius:999px !important;
  border:1px solid rgba(123,215,255,.30) !important;
  background:rgba(5,20,32,.82) !important;
  color:#f7fbff !important;
  font-size:44px !important;
  line-height:1 !important;
  display:grid !important;
  place-items:center !important;
  box-shadow:0 14px 30px rgba(0,0,0,.32) !important;
  cursor:pointer !important;
  opacity:0 !important;
  pointer-events:none !important;
  transition:opacity .18s ease, transform .18s ease, background .18s ease !important;
}

.book-page-arrow.book-arrow-visible{
  opacity:1 !important;
  pointer-events:auto !important;
}

.book-page-arrow-prev{
  left:18px !important;
  right:auto !important;
}

.book-page-arrow-next{
  right:18px !important;
  left:auto !important;
}

.book-page-arrow:hover{
  transform:translateY(-50%) scale(1.05) !important;
  background:rgba(8,31,48,.94) !important;
}

.book-page-arrow:disabled{
  opacity:.30 !important;
  pointer-events:none !important;
}

@media(max-width:760px){
  .book-page-arrow{
    width:54px !important;
    height:54px !important;
    font-size:38px !important;
    top:50vh !important;
    top:50dvh !important;
  }

  .book-page-arrow-prev{
    left:8px !important;
  }

  .book-page-arrow-next{
    right:8px !important;
  }
}

/* V73: restored /faq/ book route with custom FAQ book cover */
.book-cover-art{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  padding:8px !important;
}
.book-cover-art img{
  width:100% !important;
  max-width:380px !important;
  height:auto !important;
  object-fit:contain !important;
  display:block !important;
  margin:auto !important;
}
.faq-book-wrap{position:relative !important;}
.book-page-arrow{
  position:fixed !important;
  top:50vh !important;
  top:50dvh !important;
  transform:translateY(-50%) !important;
  z-index:2147483000 !important;
}
.book-page-arrow-prev{left:18px !important;}
.book-page-arrow-next{right:18px !important;}
@media(max-width:760px){
  .book-cover-art img{max-width:240px !important;}
  .book-page-arrow-prev{left:8px !important;}
  .book-page-arrow-next{right:8px !important;}
}

/* V74: custom FAQ image for top of page and social previews */
.book-cover-art img[src*="nsb101-faq-custom-book-top"]{
  width:100% !important;
  max-width:160px !important;
  height:auto !important;
  object-fit:contain !important;
  display:block !important;
  margin:0 auto !important;
}

/* V79: sitewide header/logo/nav consistency */
header{
  width:100% !important;
  max-width:1180px !important;
  margin:28px auto 26px !important;
  padding:0 !important;
  display:grid !important;
  grid-template-columns:auto auto 1fr !important;
  align-items:center !important;
  column-gap:18px !important;
  row-gap:10px !important;
  min-height:104px !important;
  box-sizing:border-box !important;
}

header .brand{
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  min-width:258px !important;
  height:104px !important;
  text-decoration:none !important;
  flex:0 0 auto !important;
}

header .logo{
  width:86px !important;
  height:104px !important;
  min-width:86px !important;
  max-width:86px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  border-radius:0 !important;
  padding:0 !important;
  overflow:visible !important;
}

header .logo img{
  width:86px !important;
  height:104px !important;
  max-width:86px !important;
  max-height:104px !important;
  object-fit:contain !important;
  display:block !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

header .brand span{
  display:inline-flex !important;
  align-items:center !important;
  white-space:nowrap !important;
  line-height:1 !important;
  font-size:22px !important;
  min-height:36px !important;
}

header .branch-line{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  min-height:36px !important;
  white-space:nowrap !important;
  margin:0 !important;
  font-size:14px !important;
}

header nav{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:10px !important;
  min-height:42px !important;
  margin:0 !important;
  padding:0 !important;
  flex-wrap:nowrap !important;
}

header nav .pill,
header nav a.pill{
  height:42px !important;
  min-height:42px !important;
  padding:0 18px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:999px !important;
  white-space:nowrap !important;
  box-sizing:border-box !important;
  line-height:1 !important;
  font-size:14px !important;
}

.wrap > header + .hero,
.wrap > header + .breadcrumbs,
.wrap > header + .section-title,
.wrap > header + main,
.wrap > header + section{
  margin-top:18px !important;
}

/* Keep first containers free to use their own page-specific height/width */
.hero,
.hero.small,
.card,
.faq-book-wrap{
  max-width:1180px;
  margin-left:auto;
  margin-right:auto;
}

@media(max-width:980px){
  header{
    grid-template-columns:1fr !important;
    justify-items:center !important;
    text-align:center !important;
    margin:18px auto 18px !important;
    min-height:auto !important;
  }

  header .brand{
    min-width:0 !important;
    height:auto !important;
    justify-content:center !important;
  }

  header .branch-line{
    justify-content:center !important;
  }

  header nav{
    justify-content:center !important;
    flex-wrap:wrap !important;
  }
}

@media(max-width:560px){
  header .logo,
  header .logo img{
    width:68px !important;
    height:82px !important;
    max-width:68px !important;
    max-height:82px !important;
  }

  header .brand span{
    font-size:20px !important;
  }

  header nav .pill,
  header nav a.pill{
    height:38px !important;
    min-height:38px !important;
    padding:0 14px !important;
    font-size:13px !important;
  }
}

/* V82: same homepage header logo sitewide */
header .logo img,
header .brand .logo img{
  content:url('/assets/images/nsb101-book-logo.webp') !important;
}
header .logo,
header .brand .logo{
  width:86px !important;
  height:104px !important;
  min-width:86px !important;
  max-width:86px !important;
}
header .logo img,
header .brand .logo img{
  width:86px !important;
  height:104px !important;
  max-width:86px !important;
  max-height:104px !important;
  object-fit:contain !important;
}
header nav .pill,
header nav a.pill{
  height:42px !important;
  min-height:42px !important;
  padding:0 18px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}
@media(max-width:560px){
  header .logo,
  header .brand .logo,
  header .logo img,
  header .brand .logo img{
    width:68px !important;
    height:82px !important;
    max-width:68px !important;
    max-height:82px !important;
  }
}

/* V83: header logo only, no duplicate NSB101.com text beside logo */
header .brand{
  min-width:86px !important;
  width:86px !important;
  gap:0 !important;
}
header .brand > span{
  display:none !important;
}
@media(max-width:560px){
  header .brand{
    min-width:68px !important;
    width:68px !important;
  }
}

/* V84: remove branch line from header sitewide */
header{
  grid-template-columns:auto 1fr !important;
  column-gap:24px !important;
}
header .branch-line{
  display:none !important;
}


/* V85: center header sitewide so logo and nav stay aligned consistently */
header{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:28px !important;
  width:fit-content !important;
  max-width:100% !important;
  margin:0 auto !important;
  padding-left:0 !important;
  padding-right:0 !important;
}
header .brand{
  flex:0 0 auto !important;
}
header nav{
  justify-content:center !important;
}
@media(max-width:980px){
  header{
    width:100% !important;
    justify-content:center !important;
    gap:18px !important;
  }
}

/* V86: mobile-only 3-line dropdown menu */
.mobile-menu-toggle{
  display:none;
}

@media(max-width:760px){
  header{
    width:100% !important;
    max-width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
    align-items:center !important;
    gap:10px !important;
    margin:16px auto 14px !important;
    padding:0 !important;
  }

  header .brand{
    order:1 !important;
    width:68px !important;
    min-width:68px !important;
    height:auto !important;
    justify-content:center !important;
  }

  header .logo,
  header .brand .logo,
  header .logo img,
  header .brand .logo img{
    width:68px !important;
    height:82px !important;
    max-width:68px !important;
    max-height:82px !important;
  }

  .mobile-menu-toggle{
    order:2 !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:52px !important;
    height:42px !important;
    border-radius:999px !important;
    border:1px solid var(--line) !important;
    background:rgba(255,255,255,.055) !important;
    color:var(--text) !important;
    font-size:25px !important;
    line-height:1 !important;
    font-weight:900 !important;
    cursor:pointer !important;
    box-shadow:0 10px 24px rgba(0,0,0,.18) !important;
  }

  header nav{
    order:3 !important;
    display:none !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    width:min(92vw,360px) !important;
    gap:8px !important;
    padding:10px !important;
    margin:0 auto !important;
    border:1px solid var(--line) !important;
    border-radius:22px !important;
    background:rgba(7,19,29,.94) !important;
    box-shadow:0 18px 45px rgba(0,0,0,.28) !important;
  }

  header.mobile-menu-open nav{
    display:flex !important;
  }

  header nav .pill,
  header nav a.pill{
    width:100% !important;
    height:42px !important;
    min-height:42px !important;
    padding:0 16px !important;
    justify-content:center !important;
    font-size:14px !important;
  }
}

/* V87: keep FAQ prev/next arrows centered on the book container on desktop */
@media(min-width:761px){
  .faq-book-wrap .book-frame{
    position:relative !important;
    overflow:visible !important;
  }

  .faq-book-wrap .book-page-arrow{
    position:absolute !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    z-index:50 !important;
    width:66px !important;
    height:66px !important;
    min-width:66px !important;
    min-height:66px !important;
    border-radius:999px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  .faq-book-wrap .book-page-arrow-prev{
    left:-34px !important;
    right:auto !important;
  }

  .faq-book-wrap .book-page-arrow-next{
    right:-34px !important;
    left:auto !important;
  }
}

@media(max-width:760px){
  .faq-book-wrap .book-page-arrow{
    position:fixed !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    z-index:80 !important;
  }

  .faq-book-wrap .book-page-arrow-prev{
    left:8px !important;
    right:auto !important;
  }

  .faq-book-wrap .book-page-arrow-next{
    right:8px !important;
    left:auto !important;
  }
}

/* V89: Terms, Privacy & Disclaimer page */
.legal-page{
  line-height:1.75;
  font-size:16px;
}
.legal-page h2{
  margin-top:28px;
  margin-bottom:10px;
  font-size:24px;
}
.legal-page p{
  margin:0 0 14px;
}
.legal-page a{
  font-weight:800;
}

/* V90: mobile menu is larger than the logo and all nav buttons stay inside dropdown only */
@media(max-width:760px){
  header{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    gap:12px !important;
    width:100% !important;
    max-width:100% !important;
    margin:14px auto 16px !important;
    padding:0 !important;
  }

  header .brand{
    order:1 !important;
    width:68px !important;
    min-width:68px !important;
    height:auto !important;
    margin:0 auto !important;
    justify-content:center !important;
  }

  header .logo,
  header .brand .logo,
  header .logo img,
  header .brand .logo img{
    width:68px !important;
    height:82px !important;
    max-width:68px !important;
    max-height:82px !important;
  }

  header .mobile-menu-toggle{
    order:2 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:min(86vw,320px) !important;
    height:56px !important;
    min-height:56px !important;
    margin:0 auto !important;
    border-radius:999px !important;
    border:1px solid rgba(255,255,255,.18) !important;
    background:rgba(255,255,255,.075) !important;
    color:var(--text) !important;
    font-size:18px !important;
    line-height:1 !important;
    font-weight:950 !important;
    letter-spacing:.04em !important;
    cursor:pointer !important;
    box-shadow:0 16px 36px rgba(0,0,0,.28) !important;
  }

  /* Hide all navigation buttons on mobile until the menu is opened */
  header nav{
    order:3 !important;
    display:none !important;
    width:min(86vw,320px) !important;
    margin:0 auto !important;
    padding:12px !important;
    gap:10px !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    border-radius:24px !important;
    border:1px solid rgba(255,255,255,.16) !important;
    background:rgba(7,19,29,.96) !important;
    box-shadow:0 20px 50px rgba(0,0,0,.34) !important;
  }

  header.mobile-menu-open nav{
    display:flex !important;
  }

  header nav .pill,
  header nav a.pill{
    display:flex !important;
    width:100% !important;
    height:50px !important;
    min-height:50px !important;
    padding:0 18px !important;
    align-items:center !important;
    justify-content:center !important;
    border-radius:999px !important;
    font-size:15px !important;
    line-height:1 !important;
    box-sizing:border-box !important;
  }
}

/* Desktop/tablet keeps normal visible nav */
@media(min-width:761px){
  header .mobile-menu-toggle{
    display:none !important;
  }

  header nav{
    display:flex !important;
  }
}

/* V91: mobile logo and menu button perfectly centered */
@media(max-width:760px){
  .wrap > header,
  header{
    width:100% !important;
    max-width:100% !important;
    margin:14px auto 16px !important;
    padding:0 !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    gap:12px !important;
  }

  header .brand{
    order:1 !important;
    width:68px !important;
    min-width:68px !important;
    max-width:68px !important;
    margin-left:auto !important;
    margin-right:auto !important;
    align-self:center !important;
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
  }

  header .logo,
  header .brand .logo{
    margin-left:auto !important;
    margin-right:auto !important;
    align-self:center !important;
  }

  header .mobile-menu-toggle{
    order:2 !important;
    margin-left:auto !important;
    margin-right:auto !important;
    align-self:center !important;
    text-align:center !important;
  }

  header nav{
    order:3 !important;
    margin-left:auto !important;
    margin-right:auto !important;
    align-self:center !important;
  }
}

/* V92: fixed mobile dropdown open/close behavior */
@media(max-width:760px){
  header .mobile-menu-toggle{
    display:flex !important;
    pointer-events:auto !important;
    position:relative !important;
    z-index:1000 !important;
  }

  header nav{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
    transform:translateY(-4px) !important;
    transition:opacity .18s ease, transform .18s ease !important;
  }

  header.mobile-menu-open nav{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
  }
}

@media(min-width:761px){
  header .mobile-menu-toggle{
    display:none !important;
  }

  header nav{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
  }
}

/* ======================================================================
   V100 — NSB101 "HOMETOWN" THEME LAYER
   A warm, coastal, postcard-style redesign that sits on top of the
   existing stylesheet. Appended last so it wins the cascade.
   Goal: friendlier hometown feel sitewide, a real "book" directory,
   and a clean, well-positioned FAQ book.
   ====================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@600;700&family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&display=swap');

:root{
  /* Warm dusk-over-the-inlet base */
  --bg:#0a1820;
  --panel:#12252e;
  --panel2:#173039;
  --text:#f5efe2;            /* warm sand-white */
  --muted:#c8bca4;           /* warm driftwood */
  --line:rgba(245,239,226,.14);
  --blue:#5ec8e0;            /* sea */
  --gold:#f2c14e;            /* warm sun */
  --green:#86dcb0;           /* sea-foam */
  --coral:#ff8c64;           /* sunset coral */
  --sand:#e9dcc2;
  --paper:#f7f1e4;           /* book paper */
  --ink:#173047;             /* book ink */
  --shadow:0 18px 48px rgba(2,10,16,.42);
  --radius:22px;
}

/* Warm the global background + give it a soft sunrise-photo wash */
body{
  background:
    radial-gradient(1100px 560px at 8% -12%, rgba(255,140,100,.16), transparent),
    radial-gradient(820px 520px at 94% -4%, rgba(242,193,78,.16), transparent),
    radial-gradient(900px 700px at 50% 116%, rgba(94,200,224,.10), transparent),
    linear-gradient(180deg,#081218,#0a1820 40%,#081a22) !important;
  color:var(--text);
}
body::before{
  background:
    linear-gradient(180deg,rgba(8,18,24,.74),rgba(10,24,30,.58),rgba(8,20,28,.80)),
    url('/assets/images/new-smyrna-beach-sunrise.webp') !important;
  background-size:cover !important;
  background-position:center !important;
  opacity:.24 !important;
  filter:sepia(.28) saturate(1.12) hue-rotate(-6deg) !important;
}
/* faint paper grain so surfaces feel printed, not glassy */
body::after{
  background:
    radial-gradient(60% 42% at 18% 16%, rgba(242,193,78,.07), transparent 66%),
    radial-gradient(56% 38% at 84% 10%, rgba(255,140,100,.07), transparent 64%),
    radial-gradient(60% 48% at 50% 100%, rgba(94,200,224,.06), transparent 70%) !important;
}

/* ---- Display type: a warm hometown headline face + script accents ---- */
.hero h1, h1,
.section-title,
.experience-feature h2,
.todo-body h2, .history-topic-body h2, .about-topic-body h2,
.detail-block h2, .book-page-header h2{
  font-family:'Fraunces','Bree Serif',Georgia,serif !important;
  letter-spacing:-.015em;
}
.kicker{
  font-family:'Caveat',cursive !important;
  font-size:22px !important;
  letter-spacing:.01em !important;
  text-transform:none !important;
  color:var(--coral) !important;
}

/* ---- Warm, friendlier nav pills + buttons ---- */
header nav .pill, header nav a.pill, .pill{
  background:rgba(245,239,226,.05) !important;
  border-color:var(--line) !important;
  color:var(--sand) !important;
}
header nav .pill:hover, header nav a.pill:hover, .pill:hover{
  color:#fff !important;
  border-color:rgba(255,140,100,.55) !important;
  background:rgba(255,140,100,.10) !important;
}
.btn.primary{
  border-color:rgba(255,140,100,.55) !important;
  background:linear-gradient(135deg,rgba(255,140,100,.32),rgba(242,193,78,.26)) !important;
  color:#fff8ef !important;
}
.btn.primary:hover{
  background:linear-gradient(135deg,rgba(255,140,100,.46),rgba(242,193,78,.36)) !important;
}

/* ---- Section titles get a little hand-drawn shoreline underline ---- */
.section-title{
  position:relative;
  padding-bottom:14px;
}
.section-title::after{
  content:"";
  display:block;
  width:74px;height:7px;
  margin:12px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--coral),var(--gold));
  opacity:.9;
}

/* ---- Warm every major surface (overrides the old cold V56/V57 fills) ---- */
.card,.biz,.notice,.pending-note,.callout-soft,.local-search-card,
.search-result-card,.faq-accordion details,.detail-block,.detail-hero,
.history-topic-card,.history-block,.about-topic-card,.rank-card,
.verified-card,.visual-card,.unique-photo-panel,.quick-nav,.homepage-note,
.experience-feature,.kpi,.todo-card,.thing-card,.history-row,form,.offer-bg,
.hometown-blog-widget,.feature{
  background:linear-gradient(180deg,rgba(24,42,50,.72),rgba(15,30,37,.70)) !important;
  border:1px solid rgba(245,239,226,.13) !important;
  box-shadow:0 16px 42px rgba(2,10,16,.34) !important;
}
.hero.no-photo{
  background:linear-gradient(180deg,rgba(24,42,50,.66),rgba(15,30,37,.66)) !important;
  border:1px solid rgba(245,239,226,.13) !important;
}
.experience-feature.transparent-box{
  background:linear-gradient(180deg,rgba(24,42,50,.70),rgba(15,30,37,.70)) !important;
}
.experience-feature.transparent-box .experience-option{
  background:rgba(10,24,30,.50) !important;
}

/* Photo hero overlay warmed */
.hero{
  background:linear-gradient(90deg,rgba(8,18,24,.82),rgba(8,18,24,.40)),var(--hero) !important;
  background-size:cover !important;background-position:center !important;
}
.hero.no-photo{background-image:none !important;}

/* ======================================================================
   DIRECTORY → "BOOK OF LOCAL BUSINESS"
   Names-only, but framed like a friendly hometown chapter book.
   ====================================================================== */

/* Cover banner inserted at top of /verified-directory/ */
.dir-book-cover{
  position:relative;
  border-radius:26px;
  overflow:hidden;
  margin:6px auto 22px;
  padding:40px 26px;
  text-align:center;
  border:1px solid rgba(245,239,226,.16);
  background:
    linear-gradient(180deg,rgba(8,18,24,.62),rgba(8,18,24,.78)),
    url('/assets/images/canal-street-jj-building-wikimedia.webp');
  background-size:cover;background-position:center;
  box-shadow:var(--shadow);
}
.dir-book-cover .dir-kicker{
  font-family:'Caveat',cursive;font-size:26px;color:var(--gold);display:block;margin-bottom:4px;
}
.dir-book-cover h2{
  font-family:'Fraunces',serif;font-size:clamp(30px,5vw,52px);line-height:1.02;margin:0 0 10px;
}
.dir-book-cover p{max-width:60ch;margin:0 auto;color:#e9dcc2}
.dir-book-cover .dir-spine-tag{
  display:inline-block;margin-top:16px;padding:8px 16px;border-radius:999px;
  border:1px solid rgba(242,193,78,.5);background:rgba(242,193,78,.12);
  font-weight:800;color:var(--gold);font-size:13px;letter-spacing:.05em;
}

/* Contents page styling for the category jump grid */
.category-jump{gap:14px}
.category-jump a{
  position:relative;
  background:linear-gradient(180deg,rgba(24,42,50,.72),rgba(15,30,37,.70)) !important;
  border:1px solid rgba(245,239,226,.13) !important;
  border-left:5px solid var(--coral) !important;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.category-jump a:nth-child(3n+2){border-left-color:var(--gold) !important;}
.category-jump a:nth-child(3n){border-left-color:var(--blue) !important;}
.category-jump a:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(2,10,16,.4);
}
.category-jump strong{font-family:'Fraunces',serif;font-size:19px;color:var(--text)}
.category-jump span{color:var(--gold);font-weight:700}

/* Chapter dividers for each category section */
.mega-section{
  margin-top:40px !important;
  text-align:center;
}
.mega-section::before{
  content:"❡ Local Chapter";
  display:block;
  font-family:'Caveat',cursive;
  font-size:20px;
  color:var(--coral);
  margin-bottom:2px;
  letter-spacing:.02em;
}

/* Business "name card" — clean, warm, with a quiet hover affordance */
.verified-grid{gap:14px}
.verified-card{
  position:relative;
  padding:18px 18px 18px 20px !important;
  border-left:4px solid rgba(255,140,100,.5) !important;
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.verified-card:hover{
  transform:translateY(-2px);
  border-left-color:var(--gold) !important;
  box-shadow:0 16px 38px rgba(2,10,16,.42) !important;
}
.verified-card h3{font-family:'Fraunces',serif;font-size:19px;line-height:1.25}
.verified-card h3 a{color:var(--text);text-decoration:none}
.verified-card h3 a:hover{color:#fff}
/* quiet, non-pushy cue that the page leads somewhere (marketing, softly) */
.verified-card::after{
  content:"View →";
  position:absolute;right:16px;bottom:14px;
  font-family:'Bree Serif',serif;font-size:12px;font-weight:800;
  color:var(--gold);opacity:0;transform:translateX(-4px);
  transition:opacity .16s ease, transform .16s ease;
  pointer-events:none;
}
.verified-card:hover::after{opacity:.95;transform:translateX(0)}

/* Soft upgrade strip styling (used in pending-note already) */
.pending-note{
  border:1px solid rgba(242,193,78,.30) !important;
  background:linear-gradient(180deg,rgba(242,193,78,.10),rgba(24,42,50,.66)) !important;
}

/* ======================================================================
   FAQ BOOK — clean, intentional positioning
   ====================================================================== */

/* Frame: a warm leather-bound book on the page */
.book-frame{
  background:linear-gradient(135deg,#10242e,#0c1d26) !important;
  border:1px solid rgba(242,193,78,.18) !important;
  box-shadow:0 26px 64px rgba(2,10,16,.42), inset 0 1px 0 rgba(255,255,255,.05) !important;
}
.book-spine{
  background:linear-gradient(180deg,rgba(242,193,78,.16),rgba(255,140,100,.08)) !important;
  border-right:1px solid rgba(242,193,78,.16) !important;
}
/* Paper page — keep warm, readable cream */
.book-page::before{
  background:linear-gradient(180deg,#fbf6ea 0%,#f5edda 100%) !important;
  box-shadow:0 22px 40px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.92), inset 0 -1px 0 rgba(188,165,132,.24) !important;
}
.book-page-header h2{color:var(--ink) !important}
.book-chapter-label{color:#a4622f !important;font-family:'Caveat',cursive !important;font-size:15px !important;letter-spacing:.02em !important}

/* Toolbar + cover layout: balanced, centered, less cramped */
.book-toolbar{align-items:stretch}
.book-cover-layout{align-items:center !important}
.book-cover-art img{max-width:240px !important}
.toc-grid{gap:14px}
.toc-item strong{font-family:'Fraunces',serif}

/* ---- Authoritative arrow positioning (overrides V64–V87 conflicts) ---- */
/* Desktop/tablet: circular buttons hugging the book frame, vertically centered */
@media(min-width:761px){
  .faq-book-wrap{position:relative !important;}
  .faq-book-wrap .book-frame{overflow:visible !important;}
  .faq-book-wrap .book-page-arrow{
    position:absolute !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    bottom:auto !important;
    width:62px !important;height:62px !important;
    border-radius:999px !important;
    display:grid !important;place-items:center !important;
    background:linear-gradient(135deg,rgba(255,140,100,.92),rgba(242,193,78,.86)) !important;
    color:#1a2a18 !important;
    border:1px solid rgba(255,255,255,.35) !important;
    font-size:34px !important;line-height:1 !important;
    box-shadow:0 14px 30px rgba(2,10,16,.42) !important;
    z-index:60 !important;
    opacity:1 !important;pointer-events:auto !important;
  }
  .faq-book-wrap .book-page-arrow-prev{left:-30px !important;right:auto !important;}
  .faq-book-wrap .book-page-arrow-next{right:-30px !important;left:auto !important;}
  .faq-book-wrap .book-page-arrow:hover{
    transform:translateY(-50%) scale(1.06) !important;
    background:linear-gradient(135deg,rgba(255,140,100,1),rgba(242,193,78,.96)) !important;
  }
  .faq-book-wrap .book-page-arrow:disabled{opacity:.35 !important;pointer-events:none !important;}
}
/* Mobile: keep them fixed and centered on the viewport, clearly tappable */
@media(max-width:760px){
  .faq-book-wrap .book-page-arrow{
    position:fixed !important;top:50% !important;transform:translateY(-50%) !important;
    width:54px !important;height:54px !important;font-size:30px !important;
    background:linear-gradient(135deg,rgba(255,140,100,.94),rgba(242,193,78,.9)) !important;
    color:#1a2a18 !important;border:1px solid rgba(255,255,255,.35) !important;
    box-shadow:0 12px 26px rgba(2,10,16,.4) !important;z-index:90 !important;
  }
  .faq-book-wrap .book-page-arrow-prev{left:8px !important;right:auto !important;}
  .faq-book-wrap .book-page-arrow-next{right:8px !important;left:auto !important;}
}
.book-page-arrow.book-arrow-visible{opacity:1 !important;pointer-events:auto !important;}

/* Footer: warm and tidy */
footer{
  background:linear-gradient(180deg,rgba(24,42,50,.40),rgba(10,24,30,.30)) !important;
  border-top:1px solid rgba(245,239,226,.12);
}
footer a{color:var(--sand)}
.ai-note{color:var(--muted)}

/* Friendly hometown sign-off line spacing */
.hometown-blog-widget .blog-cover{
  background:linear-gradient(180deg,rgba(8,18,24,.18),rgba(8,18,24,.5)),url('/assets/images/nsb-beach-morning-real.webp') !important;
  background-size:cover !important;background-position:center !important;
}
.book-mark{font-family:'Caveat',cursive;font-size:20px;letter-spacing:.04em}

/* V101: let the expanded primary nav wrap gracefully (more hubs in the menu) */
@media(min-width:761px){
  header{flex-wrap:wrap !important;row-gap:8px !important;}
  header nav{flex-wrap:wrap !important;max-width:900px !important;}
  header nav .pill,header nav a.pill{padding:0 14px !important;font-size:13.5px !important;}
}
/* Homepage explore hub */
.explore-hub{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:6px 0 8px}
@media(max-width:900px){.explore-hub{grid-template-columns:1fr}}
.explore-hub a{
  display:block;text-decoration:none;border-radius:20px;padding:20px;
  background:linear-gradient(180deg,rgba(24,42,50,.72),rgba(15,30,37,.70));
  border:1px solid rgba(245,239,226,.13);border-left:5px solid var(--coral);
  box-shadow:0 14px 36px rgba(2,10,16,.30);transition:transform .18s ease, box-shadow .18s ease;
}
.explore-hub a:nth-child(3n+2){border-left-color:var(--gold)}
.explore-hub a:nth-child(3n){border-left-color:var(--blue)}
.explore-hub a:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(2,10,16,.42)}
.explore-hub h3{font-family:'Fraunces',serif;margin:0 0 6px;font-size:21px;color:var(--text)}
.explore-hub p{margin:0;color:var(--muted)}


/* V70: FAQ page title row with book and directory buttons beside the heading */
.faq-title-action-row{
  display:grid;
  grid-template-columns:auto minmax(260px,1fr) auto;
  align-items:center;
  gap:14px;
  max-width:900px;
  margin:38px auto 13px;
}
.faq-title-action-row .section-title{
  margin:0;
  text-align:center;
}
.faq-title-action-row .faq-title-btn{
  justify-content:center;
  white-space:nowrap;
  min-width:160px;
}
.faq-title-action-row .faq-title-btn-left{justify-self:end;}
.faq-title-action-row .faq-title-btn-right{justify-self:start;}
@media(max-width:760px){
  .faq-title-action-row{
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin:26px auto 13px;
  }
  .faq-title-action-row .section-title{
    grid-column:1 / -1;
    order:-1;
    font-size:22px;
  }
  .faq-title-action-row .faq-title-btn{
    width:100%;
    min-width:0;
    padding:12px 10px;
    font-size:14px;
  }
  .faq-title-action-row .faq-title-btn-left,
  .faq-title-action-row .faq-title-btn-right{justify-self:stretch;}
}
@media(max-width:420px){
  .faq-title-action-row{grid-template-columns:1fr;}
  .faq-title-action-row .section-title{grid-column:1;}
}

/* V102: Final working mobile/tablet dropdown menu — all header buttons stay inside the menu */
@media(max-width:900px){
  body .wrap > header,
  body header{
    width:100% !important;
    max-width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    gap:12px !important;
    margin:14px auto 18px !important;
    padding:0 !important;
    position:relative !important;
    text-align:center !important;
  }

  body header .brand{
    order:1 !important;
    width:68px !important;
    min-width:68px !important;
    max-width:68px !important;
    margin:0 auto !important;
    align-self:center !important;
  }

  body header .logo,
  body header .brand .logo,
  body header .logo img,
  body header .brand .logo img{
    width:68px !important;
    height:82px !important;
    max-width:68px !important;
    max-height:82px !important;
  }

  body header .mobile-menu-toggle{
    order:2 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:min(88vw,340px) !important;
    height:56px !important;
    min-height:56px !important;
    margin:0 auto !important;
    padding:0 18px !important;
    border-radius:999px !important;
    border:1px solid rgba(245,239,226,.20) !important;
    background:linear-gradient(135deg,rgba(255,140,100,.24),rgba(242,193,78,.14)),rgba(15,30,37,.94) !important;
    color:var(--text) !important;
    font-family:'Bree Serif',Georgia,'Times New Roman',serif !important;
    font-size:18px !important;
    font-weight:950 !important;
    line-height:1 !important;
    letter-spacing:.02em !important;
    cursor:pointer !important;
    position:relative !important;
    z-index:1002 !important;
    pointer-events:auto !important;
    box-shadow:0 16px 36px rgba(0,0,0,.30) !important;
    -webkit-tap-highlight-color:transparent !important;
  }

  body header nav{
    order:3 !important;
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
    width:min(88vw,340px) !important;
    max-width:min(88vw,340px) !important;
    margin:0 auto !important;
    padding:12px !important;
    gap:10px !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:center !important;
    flex-wrap:nowrap !important;
    border-radius:24px !important;
    border:1px solid rgba(245,239,226,.18) !important;
    background:rgba(7,19,29,.98) !important;
    box-shadow:0 22px 56px rgba(0,0,0,.42) !important;
    transform:translateY(-4px) !important;
    transition:opacity .18s ease, transform .18s ease !important;
    overflow:hidden !important;
    z-index:1001 !important;
  }

  body header.mobile-menu-open nav{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:translateY(0) !important;
  }

  body header nav .pill,
  body header nav a.pill{
    display:flex !important;
    width:100% !important;
    max-width:100% !important;
    height:50px !important;
    min-height:50px !important;
    margin:0 !important;
    padding:0 18px !important;
    align-items:center !important;
    justify-content:center !important;
    border-radius:999px !important;
    box-sizing:border-box !important;
    color:var(--sand) !important;
    text-decoration:none !important;
    font-size:15px !important;
    line-height:1 !important;
    white-space:nowrap !important;
    pointer-events:auto !important;
    cursor:pointer !important;
  }

  body header nav .pill:active,
  body header nav a.pill:active{
    transform:scale(.98) !important;
  }
}

@media(min-width:901px){
  body header .mobile-menu-toggle{display:none !important;}
  body header nav{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
  }
}

/* SEO/accessibility support */
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.local-listing-value,.seo-support{margin-top:1.25rem}
