/* ============================================================
   Island Realtors, Inc. — app-extra.css
   Shared styles for the new modules: modals, auth, account,
   admin, blog, ratings/feedback, listings filter sidebar,
   welcome/thank-you. Pairs with styles.css (uses its tokens).
   ============================================================ */

/* ---------- accessibility: visible focus + skip link ---------- */
:focus-visible{outline:3px solid var(--gold,#c8a24a);outline-offset:2px;border-radius:4px}
.btn:focus-visible,.pill:focus-visible,.chip:focus-visible{outline:3px solid var(--ink,#15201b);outline-offset:2px}
[data-theme="dark"] .btn:focus-visible{outline-color:#fff}
.area:focus-visible{outline:3px solid var(--gold,#c8a24a);outline-offset:2px}
.skip-link{position:fixed;left:.6rem;top:-60px;z-index:400;background:var(--green,#0b6e4f);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 10px 10px;font-weight:700;transition:top .2s ease}
.skip-link:focus{top:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- generic inputs for new pages ---------- */
.ir-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.ir-label{font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.ir-input,.ir-select,.ir-textarea{
  width:100%;border:1.5px solid var(--line);background:var(--bg);color:var(--ink);
  border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:.95rem;font-family:inherit}
.ir-textarea{min-height:110px;resize:vertical}
.ir-input:focus,.ir-select:focus,.ir-textarea:focus{outline:none;border-color:var(--green)}
.ir-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.ir-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.btn-danger{background:linear-gradient(120deg,#d4543a,#b23a24);box-shadow:0 8px 24px rgba(178,58,36,.35)}
.btn-gold{background:linear-gradient(120deg,var(--gold),#e7c977);color:#3a2c08;box-shadow:0 8px 24px rgba(200,162,74,.4)}
.muted{color:var(--ink-soft)}
.tag-pill{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.25rem .6rem;border-radius:999px;background:var(--surface-2);color:var(--ink-soft)}
.tag-pill.green{background:rgba(11,110,79,.15);color:var(--green)}
.tag-pill.gold{background:rgba(200,162,74,.2);color:#9a7a1f}
.tag-pill.red{background:rgba(212,84,58,.16);color:#b23a24}

/* ---------- account button in nav ---------- */
.acct-btn{display:inline-flex;align-items:center;gap:.5rem;border:1.5px solid var(--line);background:var(--surface);
  color:var(--ink);border-radius:999px;padding:.45rem .9rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:.25s}
.acct-btn:hover{border-color:var(--green)}
.acct-btn .av{width:24px;height:24px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:.7rem;font-weight:700}
/* language selector must stay legible (solid bg + dark text) even over the transparent hero nav */
#irLang.acct-btn{background:var(--surface)!important;color:var(--ink)!important;border:1px solid var(--line)!important}
.hero-on .nav:not(.scrolled) .acct-btn{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.3);color:#fff}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:1rem;
  background:rgba(8,20,15,.55);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
.modal.open{opacity:1;pointer-events:auto}
.modal-card{background:var(--surface);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-lg);
  width:min(460px,100%);max-height:92vh;overflow:auto;padding:1.8rem;transform:translateY(16px) scale(.97);transition:transform .3s var(--ease)}
.modal.open .modal-card{transform:none}
.modal-card.wide{width:min(720px,100%)}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.2rem}
.modal-head h3{font-size:1.5rem}
.modal-close{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;flex-shrink:0;font-size:1rem}
.modal-close:hover{border-color:var(--green);color:var(--green)}

/* ---------- auth tabs ---------- */
.auth-tabs{display:flex;background:var(--surface-2);border-radius:999px;padding:.25rem;margin-bottom:1.4rem}
.auth-tabs button{flex:1;border:none;background:transparent;color:var(--ink-soft);padding:.55rem;border-radius:999px;cursor:pointer;font-weight:600;transition:.25s}
.auth-tabs button.active{background:var(--surface);color:var(--green);box-shadow:var(--shadow)}
.auth-error{background:rgba(212,84,58,.12);color:#b23a24;border-radius:var(--radius-sm);padding:.6rem .8rem;font-size:.88rem;margin-bottom:1rem}
.auth-note{font-size:.78rem;color:var(--ink-soft);margin-top:.8rem;text-align:center}

/* ---------- toast ---------- */
.ir-toast{position:fixed;bottom:1.4rem;left:50%;transform:translate(-50%,140%);z-index:300;
  background:var(--green);color:#fff;font-weight:600;padding:.8rem 1.4rem;border-radius:999px;box-shadow:var(--shadow-lg);
  transition:transform .4s var(--ease);max-width:90vw}
.ir-toast.show{transform:translate(-50%,0)}

/* ---------- ratings ---------- */
.stars-inline{color:var(--gold);letter-spacing:.08em;font-size:.95rem}
.stars-inline .num{color:var(--ink-soft);font-size:.8rem;margin-left:.35rem}
.rate-input{display:inline-flex;flex-direction:row-reverse;gap:.15rem;font-size:1.8rem}
.rate-input input{display:none}
.rate-input label{color:var(--line);cursor:pointer;transition:color .15s}
.rate-input input:checked ~ label,.rate-input label:hover,.rate-input label:hover ~ label{color:var(--gold)}

/* ---------- welcome / thank-you ---------- */
.welcome-card{text-align:center}
.welcome-card .wm-art{font-size:2.6rem;margin-bottom:.4rem}
.welcome-card h3{font-size:1.7rem;margin-bottom:.5rem}
.welcome-card p{color:var(--ink-soft);margin-bottom:1.3rem}
.welcome-actions{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center}

/* ---------- inner page hero (legal/blog/account) ---------- */
.page-hero{padding:8rem clamp(1.2rem,4vw,2.5rem) 3rem;background:var(--grad);color:#fff;text-align:center}
.page-hero h1{font-size:clamp(2rem,5vw,3.2rem)}
.page-hero p{color:rgba(255,255,255,.9);max-width:60ch;margin:.6rem auto 0}
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:1.5rem;margin:2rem 0 .6rem}
.prose h3{font-size:1.2rem;margin:1.4rem 0 .5rem}
.prose p,.prose li{color:var(--ink-soft);margin-bottom:.8rem}
.prose ul{padding-left:1.3rem;margin-bottom:1rem}
.prose a{color:var(--green);text-decoration:underline}
.legal-updated{font-size:.85rem;color:var(--ink-soft);margin-bottom:2rem;font-style:italic}

/* ---------- blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.6rem}
.blog-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.blog-card .cover{aspect-ratio:16/10;object-fit:cover;width:100%}
.blog-card .bc-body{padding:1.2rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.blog-card h3{font-size:1.2rem}
.blog-card .meta{font-size:.78rem;color:var(--ink-soft)}
.blog-card p{font-size:.92rem;color:var(--ink-soft);flex:1}
.post-cover{width:100%;max-height:420px;object-fit:cover;border-radius:var(--radius);margin-bottom:1.5rem}
.post-body{max-width:760px;margin:0 auto}
.post-body h3{font-family:Fraunces,serif;font-size:1.3rem;margin:1.6rem 0 .5rem}
.post-body p{color:var(--ink-soft);margin-bottom:1rem}

/* ---------- listings: filter sidebar ---------- */
.search-layout{display:grid;grid-template-columns:280px 1fr;gap:2rem;align-items:start}
.filter-side{position:sticky;top:90px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow);max-height:calc(100vh - 110px);overflow:auto}
.filter-side h3{font-size:1.1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}
.fg{border-top:1px solid var(--line);padding:1rem 0}
.fg:first-of-type{border-top:none;padding-top:0}
.fg h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:.6rem}
.checks{display:flex;flex-direction:column;gap:.45rem}
.checks label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer}
.checks input{accent-color:var(--green);width:16px;height:16px}
.results-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.4rem}
.results-head .count{font-weight:600}
.filter-toggle{display:none}
@media(max-width:880px){
  .search-layout{grid-template-columns:1fr}
  .filter-side{position:fixed;inset:0 auto 0 0;z-index:120;width:min(320px,86vw);max-height:none;border-radius:0;transform:translateX(-105%);transition:transform .35s var(--ease)}
  .filter-side.open{transform:none}
  .filter-toggle{display:inline-flex}
}

/* ---------- admin shell ---------- */
.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:#08251c;color:#cfe0d7;padding:1.4rem 1rem;display:flex;flex-direction:column;gap:.3rem;position:sticky;top:0;height:100vh;overflow:auto}
.admin-side .brand{margin-bottom:1.4rem}
.admin-side .brand-text,.admin-side .brand-text small{color:#fff}
.admin-nav a{display:flex;align-items:center;gap:.6rem;padding:.7rem .9rem;border-radius:10px;color:#cfe0d7;font-weight:500;font-size:.92rem;cursor:pointer;transition:.2s}
.admin-nav a:hover{background:rgba(255,255,255,.08)}
.admin-nav a.active{background:var(--green);color:#fff}
.admin-side .side-foot{margin-top:auto;font-size:.78rem;color:#7f998d}
.admin-main{padding:1.6rem clamp(1rem,3vw,2.4rem);background:var(--bg);overflow:auto}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.6rem;flex-wrap:wrap;gap:1rem}
.admin-topbar h1{font-size:1.7rem}
.admin-view{display:none;animation:pop .35s var(--ease)}
.admin-view.active{display:block}
.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1rem;margin-bottom:1.8rem}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)}
.stat-card b{font-family:Fraunces,serif;font-size:2rem;color:var(--green);display:block;line-height:1}
.stat-card span{font-size:.85rem;color:var(--ink-soft)}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow);margin-bottom:1.4rem}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.panel-head h2{font-size:1.25rem}

/* tables */
.data-table{width:100%;border-collapse:collapse;font-size:.9rem}
.data-table th,.data-table td{text-align:left;padding:.7rem .6rem;border-bottom:1px solid var(--line);vertical-align:middle}
.data-table th{font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.data-table tr:hover td{background:var(--surface-2)}
.data-table .thumb{width:54px;height:40px;object-fit:cover;border-radius:6px}
.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}
.icon-btn{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:8px;padding:.35rem .6rem;cursor:pointer;font-size:.8rem;transition:.2s}
.icon-btn:hover{border-color:var(--green);color:var(--green)}
.icon-btn.danger:hover{border-color:#d4543a;color:#d4543a}
.table-wrap{overflow-x:auto}

/* marketing / social */
.channel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.7rem;margin-bottom:1rem}
.channel{display:flex;align-items:center;gap:.5rem;border:1.5px solid var(--line);border-radius:12px;padding:.7rem;cursor:pointer;font-weight:600;font-size:.88rem;transition:.2s;user-select:none}
.channel:hover{border-color:var(--green)}
.channel.on{border-color:var(--green);background:rgba(11,110,79,.08)}
.channel .ico{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;color:#fff;font-size:.85rem;font-weight:700}
.composer-grid{display:grid;grid-template-columns:1fr 320px;gap:1.4rem}
@media(max-width:880px){.composer-grid{grid-template-columns:1fr}}
.preview-phone{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;padding:1rem}
.preview-post{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.9rem;font-size:.88rem;white-space:pre-wrap}
.ai-row{display:flex;gap:.5rem;flex-wrap:wrap;margin:.6rem 0}

@media(max-width:880px){
  .admin-shell{grid-template-columns:1fr}
  .admin-side{position:fixed;z-index:130;transform:translateX(-105%);transition:transform .3s var(--ease);width:240px}
  .admin-side.open{transform:none}
  .ir-grid-2,.ir-grid-3{grid-template-columns:1fr}
}

/* account dashboard */
.acct-layout{display:grid;grid-template-columns:220px 1fr;gap:2rem;align-items:start}
.acct-side{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);position:sticky;top:90px}
.acct-side a{display:block;padding:.6rem .8rem;border-radius:10px;cursor:pointer;font-weight:500;font-size:.92rem}
.acct-side a.active{background:var(--green);color:#fff}
.acct-view{display:none}.acct-view.active{display:block}

/* ---------- watch button, maps, announcement (added) ---------- */
.icon-btn.on{border-color:var(--green);color:var(--green);background:rgba(11,110,79,.08)}
.watch-btn{display:inline-flex;align-items:center;gap:.35rem;border:1.5px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:.4rem .8rem;font-size:.82rem;font-weight:600;cursor:pointer;transition:.2s}
.watch-btn:hover{border-color:var(--green);color:var(--green)}
.watch-btn.on{border-color:var(--green);color:var(--green);background:rgba(11,110,79,.1)}
.map-embed{width:100%;aspect-ratio:16/9;border:0;border-radius:var(--radius-sm);margin-top:.6rem}
.announce{position:fixed;left:50%;bottom:1.2rem;transform:translateX(-50%);z-index:120;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;justify-content:center;background:linear-gradient(120deg,var(--green),#0a4a37);color:#fff;font-weight:600;font-size:.9rem;padding:.7rem 1.1rem;border-radius:14px;box-shadow:var(--shadow-lg);max-width:min(680px,92vw)}
.announce .btn{padding:.4rem .9rem;font-size:.82rem;box-shadow:none}
.announce .x{background:none;border:none;color:#fff;font-size:1.15rem;cursor:pointer;line-height:1;opacity:.85}
.announce .x:hover{opacity:1}
@media(max-width:560px){.announce{left:.6rem;right:.6rem;transform:none;max-width:none;bottom:.6rem}}

/* scheduler board */
.sched-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:start}
@media(max-width:880px){.sched-grid{grid-template-columns:1fr}}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:.5rem}
.slot{border:1.5px solid var(--line);background:var(--surface);color:var(--ink);border-radius:10px;padding:.55rem;cursor:pointer;font-weight:600;font-size:.85rem;transition:.2s}
.slot:hover{border-color:var(--green)}
.slot.on{background:var(--green);color:#fff;border-color:var(--green)}
.board-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:880px){.board-cols{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.board-cols{grid-template-columns:1fr}}
.board-col{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:.8rem;min-height:120px}
.board-col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:.6rem}
.board-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.7rem;margin-bottom:.6rem;font-size:.85rem;box-shadow:var(--shadow)}
.board-card b{display:block}
.board-card .meta{color:var(--ink-soft);font-size:.78rem}
@media(max-width:880px){.acct-layout{grid-template-columns:1fr}.acct-side{position:static}}
