:root{
--accent-purple:#6B21A8;
--accent-gold:#D97706;
--indigo:#4338CA;
--radius:16px;
--card-shadow:0 4px 16px rgba(0,0,0,.18);
--transition:all .25s ease;
}
[data-theme="dark"]{
--bg:#0F172A;
--card-bg:#1E293B;
--text:#E2E8F0;
--text-muted:#94A3B8;
--nav-bg:rgba(15,23,42,.7);
--ad-bg:#1e293b;
--border:#334155;
}
[data-theme="light"]{
--bg:#FFFBF5;
--card-bg:#FFFFFF;
--text:#1E293B;
--text-muted:#64748B;
--nav-bg:rgba(255,255,255,.7);
--ad-bg:#f1f5f9;
--border:#E2E8F0;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;transition:background .3s ease,color .3s ease;padding-bottom:70px;}
/* NAV */
.nav{position:sticky;top:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.5rem;background:var(--nav-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);flex-wrap:wrap;}
.nav-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;}
.brand-mark{width:40px;height:40px;flex:0 0 auto;}
.brand-text{display:flex;flex-direction:column;line-height:1.15;}
.brand-title{font-weight:800;font-size:1.1rem;color:var(--accent-purple);}
[data-theme="dark"] .brand-title{color:#C084FC;}
.brand-sub{font-size:.75rem;color:var(--text-muted);}
.nav-tabs{list-style:none;display:flex;gap:.5rem;flex-wrap:wrap;}
.nav-tab{text-decoration:none;color:var(--text);font-weight:600;padding:.4rem .8rem;border-radius:999px;transition:var(--transition);}
.nav-tab:hover,.nav-tab:focus-visible{background:var(--accent-purple);color:#fff;outline:none;}
.nav-tab.active{background:linear-gradient(135deg,var(--accent-purple),var(--accent-gold));color:#fff;}
.theme-toggle{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:999px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);}
.theme-toggle:hover{border-color:var(--accent-gold);color:var(--accent-gold);}
[data-theme="dark"] .icon-sun{display:block;}
[data-theme="dark"] .icon-moon{display:none;}
[data-theme="light"] .icon-sun{display:none;}
[data-theme="light"] .icon-moon{display:block;}
/* HERO */
.hero{position:relative;min-height:clamp(420px,70vh,720px);display:flex;align-items:center;justify-content:center;text-align:center;padding:clamp(3rem,8vw,6rem) 1.5rem;background-image:url('https://image.royaleastside.com/images/hero-bloomington.webp');background-size:cover;background-position:center 45%;background-repeat:no-repeat;color:#fff;overflow:hidden;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(76,33,168,.78),rgba(67,56,202,.5) 45%,rgba(217,119,6,.6));z-index:1;}
.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;max-width:760px;}
.hero-logo{width:clamp(240px,40vw,420px);height:auto;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45));margin-bottom:.25rem;}
.hero-title{font-size:clamp(2rem,6vw,3.5rem);font-weight:800;text-shadow:0 2px 12px rgba(0,0,0,.3);}
.hero-sub{font-size:clamp(1rem,2.5vw,1.4rem);margin-top:.25rem;opacity:.97;font-weight:600;text-shadow:0 2px 10px rgba(0,0,0,.55);}
.hero-note{max-width:680px;margin:1rem auto 0;font-size:.92rem;line-height:1.55;opacity:.95;text-shadow:0 1px 6px rgba(0,0,0,.55);}
@media(max-width:640px){.hero{background-image:url('https://image.royaleastside.com/images/hero-bloomington-mobile.webp');}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
/* AD SLOTS */
.ad-slot{min-height:90px;width:100%;background:var(--ad-bg);border:1px dashed #94a3b8;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;}
/* SECTIONS */
.section{max-width:1200px;margin:0 auto;padding:clamp(2rem,5vw,4rem) 1.5rem;scroll-margin-top:90px;}
.section-title{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:800;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--accent-purple),var(--accent-gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;}
/* CARD */
.card{position:relative;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--card-shadow);transition:var(--transition);opacity:0;transform:translateY(30px);}
.card.visible{opacity:1;transform:translateY(0);}
.card:hover{transform:translateY(-8px);box-shadow:0 12px 30px rgba(107,33,168,.45);}
.rank-badge{position:absolute;top:12px;left:12px;z-index:2;background:linear-gradient(135deg,var(--accent-gold),#F59E0B);color:#1E293B;font-weight:800;padding:.25rem .65rem;border-radius:999px;font-size:.85rem;box-shadow:0 2px 8px rgba(0,0,0,.3);}
.card-img{width:100%;height:180px;object-fit:cover;display:block;background:#334155;}
.card-img.img-placeholder{display:flex;align-items:center;justify-content:center;}
.card-img.img-placeholder::after{content:attr(data-initial);display:flex;align-items:center;justify-content:center;width:100%;height:180px;font-size:3rem;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--accent-purple),var(--indigo));}
.card-body{padding:1.25rem;}
.card-name{font-size:1.2rem;font-weight:700;margin-bottom:.35rem;}
.card-rating{color:var(--accent-gold);font-weight:600;margin-bottom:.35rem;}
.card-address{color:var(--text-muted);font-size:.9rem;margin-bottom:.9rem;}
.visit-btn{display:inline-block;background:linear-gradient(135deg,var(--accent-purple),var(--indigo));color:#fff;text-decoration:none;padding:.5rem 1.1rem;border-radius:999px;font-weight:600;transition:var(--transition);}
.visit-btn:hover{filter:brightness(1.15);transform:translateY(-2px);}
.card-review{margin-top:1rem;padding:.9rem 1rem;border-left:3px solid var(--accent-gold);background:rgba(217,119,6,.08);border-radius:8px;font-style:italic;font-size:.92rem;color:var(--text);}
/* SPONSORED CARD (Slot B) */
.sponsored-card{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:flex;align-items:center;justify-content:center;min-height:120px;opacity:1;transform:none;border:2px solid var(--accent-gold);background:rgba(217,119,6,.06);}
.sponsored-card:hover{transform:none;box-shadow:var(--card-shadow);}
.sponsored-badge{background:linear-gradient(135deg,var(--accent-gold),#F59E0B);color:#1E293B;}
.sponsored-inner{font-weight:700;font-size:1.05rem;color:var(--text);text-align:center;}
/* FOOTER */
.site-footer{text-align:center;padding:2.5rem 1.5rem;border-top:1px solid var(--border);margin-top:2rem;}
.advertise-link a{color:var(--accent-gold);font-weight:600;text-decoration:none;}
.advertise-link a:hover{text-decoration:underline;}
.methodology{max-width:760px;margin:1rem auto 0;color:var(--text-muted);font-size:.82rem;line-height:1.55;}
.copyright{color:var(--text-muted);font-size:.85rem;margin-top:.6rem;}
/* FOOTER AD BAR (Slot C) */
.ad-footer-bar{position:fixed;bottom:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:1rem;padding:.6rem 1rem;min-height:50px;background:var(--ad-bg);border-top:1px dashed #94a3b8;color:var(--text-muted);font-size:.85rem;}
.ad-footer-bar.dismissed{display:none;}
.ad-footer-text{text-transform:uppercase;letter-spacing:.05em;}
.ad-footer-close{position:absolute;right:1rem;background:transparent;border:none;color:var(--text);font-size:1.4rem;line-height:1;cursor:pointer;padding:0 .3rem;}
.ad-footer-close:hover{color:var(--accent-gold);}
@media(max-width:600px){.card-grid{grid-template-columns:1fr;}.nav-tabs{order:3;width:100%;justify-content:center;}}
