/*
Theme Name: Omar Sells the Bay
Theme URI: https://omarsellsthebay.com
Author: Omar Murillo / Built with Claude
Description: Custom editorial theme for omarsellsthebay.com. East Bay real estate content engine: video hero, rings coverage navigator, city hub templates, podcast and review sections. SEO-first markup.
Version: 1.0.1
Requires PHP: 7.4
License: Proprietary
Text Domain: osb
*/

:root{
  --ivory:#FAF7F1;
  --stone:#EAE5DA;
  --ink:#2A2937;
  --navy:#3C3A51;
  --teal:#108FA3;
  --teal-deep:#0A6675;
  --hairline:rgba(60,58,81,.16);
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--ink);font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:'Fraunces',Georgia,serif;font-weight:520;line-height:1.08;letter-spacing:-0.015em}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.skip{position:absolute;left:-9999px;top:0;background:var(--teal);color:#fff;padding:10px 16px;z-index:99}
.skip:focus{left:12px;top:12px}

/* top utility bar */
.topbar{background:var(--navy);color:rgba(255,255,255,.82);font-size:12.5px;letter-spacing:.06em}
.topbar .wrap{display:flex;justify-content:space-between;gap:16px;padding-top:8px;padding-bottom:8px}
.topbar span b{color:#fff;font-weight:600}
.topbar .right{color:rgba(255,255,255,.6)}

/* nav */
header.site{position:sticky;top:0;background:rgba(250,247,241,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--hairline);z-index:50}
.navrow{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;max-width:var(--maxw);margin:0 auto}
.wordmark{font-family:'Fraunces',serif;font-size:21px;font-weight:600;letter-spacing:.01em;text-decoration:none;display:flex;align-items:baseline;gap:8px}
.wordmark em{font-style:italic;color:var(--teal)}
nav.main{display:flex;align-items:center;gap:28px}
nav.main a{text-decoration:none;font-size:14px;font-weight:500;color:var(--ink);opacity:.85}
nav.main a:hover{opacity:1;color:var(--teal-deep)}
.cta-btn{background:var(--teal);color:#fff !important;padding:10px 20px;border-radius:999px;font-weight:600;opacity:1 !important;transition:background .2s}
.cta-btn:hover{background:var(--teal-deep)}
.menu-toggle{display:none;background:none;border:1px solid var(--hairline);border-radius:8px;padding:8px 12px;font-size:14px;cursor:pointer}

/* video hero */
.vhero{position:relative;min-height:78vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:var(--navy)}
.vhero video,.vhero .vposter{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vhero .vposter{background:linear-gradient(160deg,#54516f 0%,#3C3A51 45%,#22212e 100%);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.vhero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,33,46,.25) 0%,rgba(34,33,46,.78) 78%)}
.vhero .wrap{position:relative;z-index:2;padding-bottom:72px;padding-top:140px;width:100%}
.vhero .eyebrow{color:#7FD4C1}
.vhero .eyebrow::before{background:#7FD4C1}
.vhero h1{font-size:clamp(42px,6vw,76px);max-width:14ch;color:#fff}
.vhero h1 em{font-style:italic;color:#7FD4C1}
.vhero p.lede{font-size:18px;max-width:48ch;margin:22px 0 30px;color:rgba(255,255,255,.88)}
.vhero .btn.primary{background:#fff;color:var(--navy)}
.vhero .btn.primary:hover{background:var(--teal);color:#fff}
.vhero .btn.ghost{border-color:rgba(255,255,255,.7);color:#fff}
.vhero .btn.ghost:hover{border-color:#7FD4C1;color:#7FD4C1}
.vcredit{position:absolute;right:22px;bottom:16px;z-index:2;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* photo bands */
.photoband{position:relative;height:54vh;min-height:340px;background:linear-gradient(135deg,var(--stone),#cfc6b2);display:flex;align-items:flex-end;overflow:hidden}
.photoband.alt{background:linear-gradient(135deg,#d8d1c1,#b9b2a0)}
.photoband .label{position:relative;z-index:2;margin:0 auto;width:100%;max-width:var(--maxw);padding:0 28px 26px;display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.photoband .label .serif{font-size:clamp(22px,3vw,32px);color:var(--navy)}
.photoband .label small{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(60,58,81,.55)}
.photoband .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(60,58,81,.4);font-size:13px;letter-spacing:.14em;text-transform:uppercase}

/* rings section */
.hero{padding:72px 0 56px}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h2.ringtitle{font-size:clamp(30px,3.8vw,46px);max-width:14ch}
.hero h2.ringtitle em{font-style:italic;color:var(--teal)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:22px}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--teal)}
.hero p.lede{font-size:17px;max-width:46ch;margin:20px 0 30px;color:rgba(42,41,55,.85)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;text-decoration:none;font-weight:600;font-size:15px;padding:14px 26px;border-radius:999px;transition:all .2s}
.btn.primary{background:var(--navy);color:#fff}
.btn.primary:hover{background:var(--teal-deep)}
.btn.ghost{border:1.5px solid var(--navy);color:var(--navy)}
.btn.ghost:hover{border-color:var(--teal);color:var(--teal-deep)}

/* rings navigator */
.rings-card{position:relative}
.rings-card figcaption{text-align:center;font-size:12.5px;color:rgba(42,41,55,.6);margin-top:10px;letter-spacing:.04em}
.rings-svg{width:100%;height:auto}
.ring-chip{cursor:pointer}
.ring-chip rect{transition:all .2s}
.ring-chip:hover rect{fill:var(--teal)}
.ring-chip:hover text{fill:#fff}
@media (prefers-reduced-motion: no-preference){
  .orbit{transform-origin:300px 300px;animation:spin 90s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
  .orbit text, .orbit .ring-chip{transform-origin:center}
}

/* pulse ticker */
.pulse{background:var(--navy);color:#fff;overflow:hidden;border-top:3px solid var(--teal)}
.pulse .inner{display:flex;align-items:center}
.pulse .tag{flex:none;background:var(--teal);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:14px 18px}
.tickerwrap{overflow:hidden;flex:1}
.ticker{display:flex;gap:56px;white-space:nowrap;padding:13px 0;font-size:14px}
.ticker span b{color:#fff;font-weight:600}
.ticker span{color:rgba(255,255,255,.72)}
.ticker .up{color:#7FD4C1}
@media (prefers-reduced-motion: no-preference){
  .ticker{animation:slide 38s linear infinite}
  @keyframes slide{to{transform:translateX(-50%)}}
}

/* section scaffolding */
section{padding:76px 0}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:38px;border-bottom:1px solid var(--hairline);padding-bottom:18px}
.sec-head h2{font-size:clamp(28px,3.4vw,40px)}
.sec-head a.more{font-size:14px;font-weight:600;color:var(--teal-deep);text-decoration:none;flex:none}
.sec-head a.more:hover{text-decoration:underline}

/* featured story */
.featured{display:grid;grid-template-columns:1.2fr .8fr;gap:44px;align-items:center}
.kicker{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-deep)}
.featured h3{font-size:clamp(28px,3.6vw,44px);margin:14px 0 18px}
.featured h3 a{text-decoration:none}
.featured h3 a:hover{color:var(--teal-deep)}
.featured p{color:rgba(42,41,55,.82);max-width:54ch}
.byline{margin-top:20px;font-size:13px;color:rgba(42,41,55,.6)}
.thumb{aspect-ratio:4/3;background:linear-gradient(135deg,var(--stone),#dcd5c6);border-radius:14px;display:flex;align-items:center;justify-content:center;color:rgba(60,58,81,.5);font-size:13px;letter-spacing:.06em}

/* city hubs */
.cities{background:var(--stone)}
.ringlabel{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-deep);margin:34px 0 14px;display:flex;align-items:center;gap:12px}
.ringlabel::after{content:"";flex:1;height:1px;background:var(--hairline)}
.citygrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.citygrid.five{grid-template-columns:repeat(5,1fr)}
.citycard{background:var(--ivory);border:1px solid var(--hairline);border-radius:14px;padding:22px;text-decoration:none;transition:all .2s;display:block}
.citycard:hover{border-color:var(--teal);transform:translateY(-3px)}
.citycard h3{font-size:21px;margin-bottom:6px}
.citycard p{font-size:13.5px;color:rgba(42,41,55,.68);line-height:1.5}
.citycard .go{display:inline-block;margin-top:12px;font-size:13px;font-weight:600;color:var(--teal-deep)}
.fortress{grid-column:1 / -1;display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:center;background:var(--navy);color:#fff;border:none}
.fortress:hover{border:none}
.fortress h3{font-size:34px;color:#fff}
.fortress p{color:rgba(255,255,255,.78)}
.fortress .go{color:#7FD4C1}
.hoods{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.hoods span{font-size:12.5px;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:5px 12px;color:rgba(255,255,255,.85)}

/* latest articles */
.articlerow{display:grid;grid-template-columns:110px 1fr auto;gap:26px;align-items:baseline;padding:24px 0;border-bottom:1px solid var(--hairline);text-decoration:none}
.articlerow:hover h3{color:var(--teal-deep)}
.articlerow .cat{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-deep)}
.articlerow h3{font-size:clamp(19px,2.2vw,25px);transition:color .2s}
.articlerow time{font-size:13px;color:rgba(42,41,55,.55);flex:none}

/* podcast */
.podcast{background:var(--navy);color:#fff}
.podcast .sec-head{border-color:rgba(255,255,255,.18)}
.podcast .sec-head a.more{color:#7FD4C1}
.pod-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.pod-art{aspect-ratio:1/1;border-radius:18px;background:linear-gradient(150deg,var(--teal),#0A5260);display:flex;flex-direction:column;justify-content:flex-end;padding:30px}
.pod-art .serif{font-size:30px;color:#fff;line-height:1.1}
.pod-art small{color:rgba(255,255,255,.75);font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.ep{display:flex;gap:18px;align-items:center;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.14);text-decoration:none}
.ep:hover .play{background:var(--teal)}
.play{flex:none;width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;transition:all .2s}
.play::after{content:"";border-left:11px solid #fff;border-top:7px solid transparent;border-bottom:7px solid transparent;margin-left:3px}
.ep h3{font-size:18px;color:#fff}
.ep p{font-size:13px;color:rgba(255,255,255,.62)}
.pod-note{margin-top:18px;font-size:13px;color:rgba(255,255,255,.55)}

/* video */
.vidgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vid{border-radius:14px;overflow:hidden;border:1px solid var(--hairline);text-decoration:none;background:var(--ivory);transition:all .2s;display:block}
.vid:hover{border-color:var(--teal);transform:translateY(-3px)}
.vid .frame{aspect-ratio:16/9;background:linear-gradient(135deg,var(--navy),#54516f);display:flex;align-items:center;justify-content:center}
.vid .frame .play{border-color:rgba(255,255,255,.6)}
.vid h3{font-size:16.5px;padding:16px 18px 4px}
.vid p{font-size:13px;color:rgba(42,41,55,.6);padding:0 18px 18px}

/* about */
.about .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center}
.portrait{aspect-ratio:4/5;border-radius:16px;background:linear-gradient(160deg,var(--stone),#d8d1c1);display:flex;align-items:center;justify-content:center;color:rgba(60,58,81,.5);font-size:13px;letter-spacing:.06em}
.about h2{font-size:clamp(30px,3.6vw,44px);margin-bottom:20px}
.about h2 em{font-style:italic;color:var(--teal)}
.about p{color:rgba(42,41,55,.84);margin-bottom:16px;max-width:56ch}
.creds{display:flex;gap:34px;margin-top:26px;flex-wrap:wrap}
.cred b{display:block;font-family:'Fraunces',serif;font-size:30px;font-weight:560;color:var(--navy)}
.cred span{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(42,41,55,.6)}

/* reviews */
.reviews{background:var(--stone)}
.revgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rev{background:var(--ivory);border:1px solid var(--hairline);border-radius:14px;padding:26px;display:flex;flex-direction:column;gap:14px}
.stars{color:var(--teal);font-size:15px;letter-spacing:3px}
.rev p{font-size:15px;color:rgba(42,41,55,.85);font-family:'Fraunces',serif;font-size:17px;line-height:1.5}
.rev .who{margin-top:auto;display:flex;justify-content:space-between;align-items:center;gap:10px}
.rev .who b{font-size:13.5px;font-family:'Plus Jakarta Sans',sans-serif}
.srcbadge{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--hairline);border-radius:999px;padding:4px 11px;color:var(--teal-deep)}
.revfoot{margin-top:26px;display:flex;gap:22px;flex-wrap:wrap;align-items:center;font-size:14px}
.revfoot a{font-weight:600;color:var(--teal-deep);text-decoration:none}
.revfoot a:hover{text-decoration:underline}
.revfoot .note{color:rgba(42,41,55,.55);font-size:13px}

/* cta band */
.band{background:var(--teal);color:#fff;text-align:center;padding:70px 28px}
.band h2{font-size:clamp(30px,4vw,46px);max-width:22ch;margin:0 auto 18px}
.band p{max-width:48ch;margin:0 auto 30px;color:rgba(255,255,255,.88)}
.band .btn{background:#fff;color:var(--navy)}
.band .btn:hover{background:var(--navy);color:#fff}

/* footer */
footer{background:var(--navy);color:rgba(255,255,255,.75);padding:60px 0 34px;font-size:14px}
.footgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
footer h4{color:#fff;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}
footer a{display:block;text-decoration:none;margin-bottom:9px;color:rgba(255,255,255,.7)}
footer a:hover{color:#7FD4C1}
.legal{border-top:1px solid rgba(255,255,255,.16);padding-top:22px;font-size:12.5px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}

/* responsive */
@media(max-width:980px){
  .hero .wrap,.featured,.pod-grid,.about .wrap{grid-template-columns:1fr}
  .citygrid,.citygrid.five{grid-template-columns:repeat(2,1fr)}
  .fortress{grid-template-columns:1fr}
  .vidgrid{grid-template-columns:1fr}
  .footgrid{grid-template-columns:1fr 1fr}
  nav.main{display:none;position:absolute;top:100%;left:0;right:0;background:var(--ivory);flex-direction:column;align-items:flex-start;padding:20px 28px;border-bottom:1px solid var(--hairline);gap:18px}
  nav.main.open{display:flex}
  .menu-toggle{display:block}
  .articlerow{grid-template-columns:1fr;gap:6px}
  .topbar .right{display:none}
}

/* === WordPress content styles === */
.entry-content{max-width:760px;margin:0 auto}
.entry-content p{margin-bottom:20px;font-size:17px;line-height:1.75}
.entry-content h2{font-size:30px;margin:40px 0 16px}
.entry-content h3{font-size:23px;margin:32px 0 12px}
.entry-content ul,.entry-content ol{margin:0 0 20px 24px}
.entry-content li{margin-bottom:8px}
.entry-content img{border-radius:14px;margin:28px 0}
.entry-content blockquote{border-left:3px solid var(--teal);padding:6px 0 6px 22px;margin:28px 0;font-family:'Fraunces',serif;font-size:20px;color:var(--navy)}
.entry-content a{color:var(--teal-deep)}
.entry-content figure{margin:28px 0}
.entry-content figcaption{font-size:13px;color:rgba(42,41,55,.55);margin-top:8px}
.entry-content iframe{max-width:100%;border-radius:14px}

/* article header */
.article-hero{padding:64px 0 36px;text-align:center}
.article-hero .kicker{justify-content:center}
.article-hero h1{font-size:clamp(34px,4.6vw,56px);max-width:20ch;margin:14px auto 18px}
.article-hero .byline{font-size:14px;color:rgba(42,41,55,.6)}
.article-featimg{max-width:1000px;margin:0 auto 44px;padding:0 28px}
.article-featimg img{border-radius:16px;width:100%}
article.single-body{padding-bottom:70px}

/* author box */
.authorbox{max-width:760px;margin:50px auto 0;border-top:1px solid var(--hairline);padding-top:30px;display:flex;gap:20px;align-items:center}
.authorbox .av{flex:none;width:72px;height:72px;border-radius:50%;background:linear-gradient(160deg,var(--stone),#d8d1c1)}
.authorbox b{font-family:'Fraunces',serif;font-size:19px;display:block}
.authorbox p{font-size:14px;color:rgba(42,41,55,.7)}

/* city hub */
.cityhero{background:var(--navy);color:#fff;padding:80px 0 60px}
.cityhero .eyebrow{color:#7FD4C1}
.cityhero .eyebrow::before{background:#7FD4C1}
.cityhero h1{font-size:clamp(40px,5.6vw,68px);color:#fff}
.cityhero p.lede{color:rgba(255,255,255,.85);font-size:18px;max-width:52ch;margin-top:18px}
.citystats{background:var(--teal);color:#fff;padding:26px 0}
.citystats .wrap{display:flex;gap:44px;flex-wrap:wrap}
.citystats .cred b{color:#fff}
.citystats .cred span{color:rgba(255,255,255,.8)}
.cityposts{padding:64px 0}

/* pagination, archives */
.pagebody{padding:64px 0}
.archive-head{padding:64px 0 0}
nav.pagination{display:flex;gap:10px;justify-content:center;padding:30px 0}
nav.pagination a,nav.pagination span{padding:8px 14px;border:1px solid var(--hairline);border-radius:8px;text-decoration:none;font-size:14px}
nav.pagination .current{background:var(--navy);color:#fff;border-color:var(--navy)}

/* wp niceties */
.screen-reader-text{position:absolute;left:-9999px}
.aligncenter{margin-left:auto;margin-right:auto}
