:root{
  --bg:#f6f8fb;
  --bg-soft:#eef3f9;
  --card:#ffffff;
  --card-2:rgba(255,255,255,0.82);
  --text:#0f172a;
  --muted:#64748b;
  --line:rgba(148,163,184,0.22);
  --primary:#0f172a;
  --accent:#f5b942;
  --accent-2:#f59e0b;
  --success:#16a34a;
  --danger:#dc2626;
  --shadow:0 18px 55px rgba(15,23,42,0.10);
  --shadow-soft:0 10px 30px rgba(15,23,42,0.07);
  --radius:28px;
  --radius-sm:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top, rgba(245,185,66,.18), transparent 22%),
    radial-gradient(circle at right, rgba(15,23,42,.08), transparent 26%),
    linear-gradient(to bottom, #ffffff, var(--bg));
}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
.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}
.skip-link{position:absolute;left:16px;top:10px;z-index:999;transform:translateY(-140%);background:#fff;color:var(--primary);border:2px solid var(--accent);border-radius:8px;padding:10px 14px;font-weight:800}
.skip-link:focus{transform:translateY(0)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid rgba(255,159,26,.75);outline-offset:3px}
.site-shell{min-height:100vh}
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(18px);background:rgba(255,255,255,.74);border-bottom:1px solid rgba(255,255,255,.72)}
.topbar-inner,.utility-inner,.container,.footer-inner,.hero-inner{width:min(1180px, calc(100% - 32px));margin:0 auto}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0}
.brand{display:flex;align-items:center;gap:14px;min-width:240px}
.brand-mark{position:relative;width:56px;height:56px;border-radius:999px;background:linear-gradient(145deg,#176b7c,#0b4857);color:#fff;font-weight:900;display:grid;place-items:center;box-shadow:0 12px 24px rgba(15,23,42,.18);isolation:isolate;overflow:hidden}
.brand-mark::before{content:"";position:absolute;inset:6px;border:1px solid rgba(255,255,255,.24);border-radius:999px}
.brand-mark::after{content:"";position:absolute;right:-3px;bottom:-3px;width:24px;height:24px;border-radius:999px 0 999px 0;background:var(--accent-2)}
.brand-mark span{position:relative;z-index:1;letter-spacing:-.02em;font-size:1.12rem}
.brand strong{display:block;font-size:1.02rem}.brand small{display:block;color:var(--muted);margin-top:2px}
.main-nav{display:flex;align-items:center;gap:8px;padding:6px;background:rgba(255,255,255,.85);border:1px solid rgba(148,163,184,.18);border-radius:999px;box-shadow:var(--shadow-soft)}
.main-nav a{padding:10px 16px;border-radius:999px;color:#334155;font-weight:600;font-size:.95rem}
.main-nav a.active,.main-nav a:hover{background:#eef2f7;color:var(--primary)}
.nav-actions{display:flex;gap:10px;align-items:center;margin-left:auto}
.utility-bar{border-bottom:1px solid var(--line);background:rgba(255,255,255,.55)}
.utility-inner{display:flex;justify-content:space-between;gap:18px;padding:11px 0;color:var(--muted);font-size:.92rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 16px;border-radius:18px;border:1px solid transparent;font-weight:700;cursor:pointer;transition:.18s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:var(--primary);box-shadow:0 12px 24px rgba(245,185,66,.35)}
.btn-dark{background:var(--primary);color:#fff;box-shadow:0 12px 24px rgba(15,23,42,.2)}
.btn-soft{background:rgba(255,255,255,.85);border-color:var(--line);color:var(--text)}
.btn-danger{background:var(--danger);color:#fff}
.container{padding:34px 0 60px}
.hero{position:relative;overflow:hidden;padding:34px 0 14px}
.hero::before{content:"";position:absolute;left:50%;top:38px;transform:translateX(-50%);width:320px;height:320px;border-radius:999px;background:rgba(245,185,66,.22);filter:blur(65px)}
.hero-inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center}
.hero-panel,.glass-card,.card,.auth-card,.admin-card,.chat-shell,.list-card{background:var(--card-2);border:1px solid rgba(255,255,255,.7);backdrop-filter:blur(18px);box-shadow:var(--shadow)}
.hero-panel{padding:40px;border-radius:36px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.76);border:1px solid rgba(245,185,66,.28);color:#a16207;font-weight:700;font-size:.9rem}
.hero h1{margin:18px 0 14px;font-size:clamp(2.4rem, 5vw, 4.5rem);line-height:.98;font-weight:900;letter-spacing:-0.04em}.hero h1 span{color:var(--accent-2)}
.hero p{color:#475569;font-size:1.06rem;line-height:1.7;max-width:760px}
.hero-actions,.actions{display:flex;flex-wrap:wrap;gap:12px}.hero-actions{margin-top:24px}
.search-card{margin-top:24px;padding:14px;border-radius:28px;background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow-soft)}
.search-row{display:flex;gap:12px}.search-row input{flex:1;border:0;background:#f8fafc;border-radius:20px;padding:15px 16px;color:var(--text)}
.chips,.filters,.stat-grid{display:flex;flex-wrap:wrap;gap:10px}
.chip,.filter{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.75);border:1px solid var(--line);color:#334155;font-weight:600}
.filter.active{background:var(--primary);color:#fff}
.hero-aside{display:grid;gap:18px}
.stat-card,.feature-card{border-radius:30px;padding:24px}
.stat-card.dark{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff}
.stat-card.light{background:linear-gradient(135deg,#fff8e8,#fff1c9);color:var(--primary)}
.stat-card h3,.feature-card h3{margin:0 0 8px;font-size:1.25rem}.stat-card p,.feature-card p{margin:0;color:inherit;opacity:.88;line-height:1.6}
.big-stat{font-size:2.8rem;font-weight:900;line-height:1;margin-bottom:10px}
.section{padding:18px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:18px}
.section-head h2{margin:0;font-size:1.9rem;letter-spacing:-.03em}.section-head p{margin:8px 0 0;color:var(--muted);max-width:640px;line-height:1.7}
.grid{display:grid;gap:18px;grid-template-columns:repeat(4,minmax(0,1fr))}
.card,.list-card,.feature-card,.auth-card,.admin-card{border-radius:30px;padding:24px}
.card:hover,.list-card:hover{transform:translateY(-3px);transition:.2s ease}
.card-image{width:100%;aspect-ratio:16/9;object-fit:contain;border-radius:20px;margin-bottom:16px;background:#eef4f5}
.admin-thumb{display:block;width:100%;max-width:220px;aspect-ratio:16/9;object-fit:cover;border-radius:16px;margin:8px 0 10px;background:#e2e8f0}
.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);color:var(--muted);font-size:.84rem;font-weight:700}
.title{font-size:1.22rem;font-weight:800;line-height:1.35;margin:14px 0 10px}.body{color:#475569;line-height:1.7}
.card-detail-link{display:block}
.card-main-link{display:block;color:inherit}
.card-main-link:hover .title{color:var(--primary)}
.card-main-link:hover .body{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
a.card-detail-link.title:hover{color:var(--primary)}
a.card-detail-link.body:hover{color:#102534;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;color:var(--muted);font-size:.92rem}.meta .hot{color:var(--danger);font-weight:800}
.event-row{display:grid;grid-template-columns:74px 1fr;gap:18px;align-items:flex-start}
.datebox{border-radius:22px;background:var(--primary);color:#fff;padding:12px 8px;text-align:center;box-shadow:0 12px 24px rgba(15,23,42,.18)}
.datebox .day{font-size:1.8rem;font-weight:900;line-height:1}.datebox .mon{font-size:.72rem;letter-spacing:.16em;opacity:.78;margin-top:4px}
.notice,.empty-state{padding:16px 18px;border-radius:22px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}.notice.error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.auth-wrap{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.auth-card h1,.auth-card h2,.admin-card h2{margin-top:0}
.form label{display:block;font-weight:700;margin:15px 0 7px}
.form input,.form textarea,.form select{width:100%;padding:14px 15px;border-radius:18px;border:1px solid var(--line);background:#fff;color:var(--text)}
.form .hp-field{display:none}
.form textarea{min-height:150px;resize:vertical}.form-help{color:var(--muted);font-size:.92rem;line-height:1.6}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:8px}
.checkbox-grid label{display:flex;align-items:center;gap:8px;margin:0;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#fff;font-weight:700}
.checkbox-grid input{width:auto}
.badge-row{display:flex;flex-wrap:wrap;gap:8px}
.suggest-field{position:relative}
.suggest-box{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:30;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.suggest-item{display:block;width:100%;padding:12px 14px;border:0;border-bottom:1px solid var(--line);background:#fff;text-align:left;cursor:pointer;color:var(--text)}
.suggest-item:last-child{border-bottom:0}
.suggest-item:hover,.suggest-item:focus{background:#f8fafc;outline:0}
.suggest-item strong,.suggest-item span,.suggest-item em{display:block}
.suggest-item span{margin-top:3px;color:var(--muted);font-size:.88rem;line-height:1.35}
.suggest-item em{margin-top:4px;color:var(--primary);font-size:.84rem;font-style:normal;font-weight:700}
.suggest-message{padding:12px 14px;color:var(--muted);font-weight:700}
.chat-shell{padding:18px;border-radius:24px}
.chat-shell .notice{padding:12px 14px;border-radius:16px;font-size:.92rem}
.chat-shell .chip{padding:7px 10px;font-size:.88rem}
.chat-shell .form label{margin:10px 0 6px}
.chat-shell .form-help{font-size:.86rem}
.chat-shell .actions{gap:8px}
.messages{display:flex;flex-direction:column;gap:9px;min-height:150px;max-height:320px;overflow:auto;padding-right:4px;margin:14px 0}
#chatForm textarea{min-height:48px;max-height:90px}
.msg{display:flex;gap:9px;align-items:flex-end}.avatar{width:32px;height:32px;border-radius:12px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.88rem;flex:0 0 32px;overflow:hidden}
.avatar img,.chat-shell .avatar img,.admin-avatar img{display:block;width:100% !important;height:100% !important;object-fit:cover;border-radius:inherit}
.bubble{max-width:min(78%,700px);border-radius:16px 16px 16px 5px;background:#eef2ff;padding:9px 11px;line-height:1.45;color:#1e293b;font-size:.95rem}.msg.mine{justify-content:flex-end}.msg.mine .bubble{border-radius:16px 16px 5px 16px;background:#fff7e0}
.msg.new-message .bubble{animation:newMessagePulse 2.4s ease-out;border:1px solid rgba(245,158,11,.45)}
.account-grid,.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.site-footer{margin-top:20px;background:linear-gradient(135deg,#0f172a,#1e293b);color:rgba(255,255,255,.82)}
.footer-inner{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;padding:34px 0}.footer-brand{font-size:1.2rem;font-weight:800;margin-bottom:10px}
.footer-links{display:flex;flex-wrap:wrap;gap:14px 18px;justify-content:flex-end}.footer-links a{color:rgba(255,255,255,.76)}
.admin-layout{width:min(1180px, calc(100% - 32px));margin:34px auto 60px}.admin-nav{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.admin-nav a{padding:11px 15px;border-radius:16px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);font-weight:700}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table th{font-size:.9rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;padding:0 10px 10px}
.table td{background:#fff;padding:16px 14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.table td:first-child{border-left:1px solid var(--line);border-radius:18px 0 0 18px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 18px 18px 0}
.inline-links{display:flex;gap:12px;flex-wrap:wrap}
.user-cell{display:flex;align-items:center;gap:10px}
.admin-avatar{width:36px;height:36px;flex-basis:36px}
.profile-avatar{--avatar-x:50%;--avatar-y:50%;position:relative;width:128px;height:128px;border-radius:28px;margin:0 0 18px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.8rem;overflow:hidden;line-height:1;flex:none}
.profile-avatar img,.avatar-crop-stage img{display:block;position:absolute;left:0;top:0;width:auto;height:auto;max-width:none;max-height:none;object-fit:initial;border-radius:0;pointer-events:none}
.avatar-editor{position:fixed;inset:0;z-index:9999;background:rgba(15,23,42,.82);display:grid;place-items:center;padding:24px}
.avatar-editor-panel{position:relative;width:min(760px,calc(100vw - 32px));border-radius:26px;background:#242629;color:#fff;padding:28px;box-shadow:0 30px 90px rgba(0,0,0,.45)}
.avatar-editor-panel h3{margin:0 0 22px;text-align:center;font-size:1.35rem}
.avatar-editor-close{position:absolute;right:18px;top:16px;width:36px;height:36px;border:0;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;font-size:1.8rem;line-height:1;cursor:pointer}
.avatar-crop-stage{position:relative;width:min(470px,72vw);aspect-ratio:1;margin:0 auto 24px;background:#111;overflow:hidden;cursor:grab;touch-action:none;user-select:none}
.avatar-crop-stage::after{content:"";position:absolute;inset:0;border-radius:0;box-shadow:inset 0 0 0 999px rgba(0,0,0,.45);clip-path:circle(50% at 50% 50%);pointer-events:none}
.avatar-crop-stage::before{content:"";position:absolute;inset:0;border-radius:999px;border:2px solid rgba(255,255,255,.9);z-index:2;pointer-events:none}
.avatar-crop-stage.is-dragging{cursor:grabbing}
.avatar-zoom-row{display:flex;align-items:center;gap:14px;width:min(520px,80vw);margin:0 auto 22px;color:#d1d5db;font-size:1.9rem}
.avatar-zoom-row input{flex:1;accent-color:#1877f2}
.avatar-controls{display:grid;gap:8px;margin-top:12px}
.avatar-controls label{margin:8px 0 0}
.avatar-controls input[type=range]{padding:0;border:0;background:transparent;accent-color:var(--accent-2)}
.kicker{margin-top:12px;padding:14px 18px;border-radius:24px;background:rgba(15,23,42,.92);color:#fff;display:flex;gap:16px;overflow:auto}.kicker strong{color:var(--accent);white-space:nowrap}
@keyframes newMessagePulse{0%{background:#fef3c7;box-shadow:0 0 0 0 rgba(245,158,11,.32)}100%{box-shadow:0 0 0 14px rgba(245,158,11,0)}}
@media (max-width: 980px){.hero-inner,.auth-wrap{grid-template-columns:1fr}.main-nav{display:none}.utility-inner,.topbar-inner,.footer-inner{flex-direction:column;align-items:flex-start}.nav-actions{width:100%}}
@media (max-width: 680px){.topbar-inner,.utility-inner,.container,.hero-inner,.footer-inner,.admin-layout{width:min(100% - 20px, 1180px)}.hero-panel,.chat-shell,.card,.list-card,.auth-card,.admin-card,.feature-card{padding:20px}.search-row{flex-direction:column}.hero h1{font-size:2.4rem}.section-head{align-items:flex-start;flex-direction:column}.event-row{grid-template-columns:1fr}.datebox{width:74px}}

.chat-message-wrap{display:flex;flex-direction:column;gap:5px;max-width:min(78%,700px)}
.chat-actions{display:flex;gap:8px;flex-wrap:wrap;padding-left:2px;font-size:.9rem}
.link-btn{appearance:none;border:0;background:transparent;color:#475569;font-weight:700;padding:0;cursor:pointer}
.link-btn:hover{text-decoration:underline}
.link-btn.danger{color:var(--danger)}
.hidden{display:none !important}
#chatStatus{transition:all .2s ease}
#chatStatus.offline{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.link-btn[disabled]{opacity:.5;pointer-events:none}
.chat-actions form{margin:0}

/* Lovable-style layout refresh */
:root{
  --bg:#f7f8f7;
  --bg-soft:#eef4f5;
  --card:#ffffff;
  --card-2:#ffffff;
  --text:#081b2a;
  --muted:#496174;
  --line:#cbd9df;
  --primary:#15586b;
  --primary-2:#1f8297;
  --accent:#ff9f1a;
  --accent-2:#ff8a00;
  --shadow:0 14px 34px rgba(8,27,42,.08);
  --shadow-soft:0 8px 20px rgba(8,27,42,.06);
  --radius:10px;
  --radius-sm:8px;
}
body{background:#f7f8f7;color:var(--text)}
.topbar{position:sticky;background:#fff;border-bottom:1px solid #d8e3e8;backdrop-filter:none;box-shadow:0 1px 0 rgba(8,27,42,.04)}
.topbar-inner,.utility-inner,.container,.footer-inner,.hero-inner{width:min(1420px,calc(100% - 32px))}
.topbar-inner{padding:10px 0;gap:18px}
.brand{min-width:330px;gap:10px}
.brand-mark{width:50px;height:50px;border-radius:999px;background:linear-gradient(145deg,#176b7c,#0b4857);box-shadow:0 8px 18px rgba(8,27,42,.16)}
.brand-mark::before{inset:5px;border-radius:999px}
.brand-mark::after{right:-2px;bottom:-2px;width:20px;height:20px}
.brand-mark span{font-size:1rem;letter-spacing:0}
.brand strong{font-size:1rem;white-space:nowrap}.brand strong::first-letter{color:inherit}.brand small{display:none}
.main-nav{background:transparent;border:0;box-shadow:none;border-radius:0;padding:0;gap:18px;white-space:nowrap;flex:1;justify-content:center}
.main-nav a{padding:8px 0;border-radius:0;background:transparent;color:#334756;font-weight:700;font-size:.9rem}
.main-nav a.active,.main-nav a:hover{background:transparent;color:var(--primary)}
.nav-toggle{display:none}
.nav-message-link{display:inline-flex;align-items:center;gap:6px}
.nav-message-button{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;border-color:var(--accent);background:var(--accent);color:#071b2a;font-weight:900}
.nav-message-button.active,.nav-message-button:hover{background:#fff;color:#071b2a;border-color:var(--accent)}
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--accent);color:#071b2a;font-size:.78rem;font-weight:900;line-height:1}
.nav-message-button .nav-badge{background:#071b2a;color:#fff}
.nav-actions{white-space:nowrap;flex:0 0 auto}
.nav-actions .btn{padding:8px 12px;border-radius:8px;white-space:nowrap}
.nav-admin-button{position:relative}
.admin-alert-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--accent);color:#071b2a;font-size:.78rem;font-weight:900;line-height:1}
.nav-logout-button{order:99}
.utility-bar{display:none}
.btn{border-radius:8px;padding:10px 16px;box-shadow:none}
.btn:hover{transform:none}
.btn-primary{background:var(--accent);color:#071b2a;box-shadow:none}
.btn-dark{background:var(--primary);color:#fff;box-shadow:none}
.btn-soft{background:#fff;border-color:#d5e1e6;color:#102534}
.container{padding:44px 0 72px}
.hero{background:linear-gradient(135deg,#15586b,#21889c);padding:64px 0;color:#fff;overflow:hidden}
.hero::before{display:none}
.hero-inner{grid-template-columns:1.22fr .78fr;gap:48px}
.hero-panel,.glass-card,.card,.auth-card,.admin-card,.chat-shell,.list-card{background:#fff;border:1px solid #cbd9df;backdrop-filter:none;box-shadow:none}
.hero-panel{padding:0;border:0;border-radius:0;background:transparent;color:#fff;box-shadow:none}
.eyebrow{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.18);color:#e8f7fb;border-radius:999px;padding:7px 11px}
.hero h1{font-size:clamp(2.15rem,3.2vw,3rem);letter-spacing:-.03em;line-height:1.05;color:#fff;white-space:nowrap}
.hero h1 span{color:var(--accent);white-space:nowrap}
.hero p{color:#ecf8fb;line-height:1.65;font-size:1rem}
.search-card{background:#fff;border:1px solid #cbd9df;border-radius:8px;box-shadow:none}
.search-row input{border:1px solid #d4e0e5;background:#fff;border-radius:8px;padding:12px 14px}
.chip,.filter{border-radius:8px;background:#fff;border-color:#d5e1e6;color:#15586b}
.filter.active{background:var(--primary);color:#fff}
.hero-aside{grid-template-columns:1fr 1fr;gap:14px}
.home-feature-tile{display:block;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.12);border-radius:8px;padding:18px 20px;color:#fff;min-height:92px}
.home-feature-tile strong{display:block;margin:8px 0 4px;font-size:1rem}
.home-feature-tile small{display:block;color:#dff3f7;font-weight:600}
.home-feature-icon{color:var(--accent);font-size:1.25rem}
.home-search{margin-top:22px;display:flex;gap:10px;width:min(520px,100%)}
.home-search input{flex:1;border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.12);color:#fff;border-radius:8px;padding:12px 14px}
.home-search input::placeholder{color:#d8edf2}
.home-search .btn{background:#fff;color:var(--primary)}
.home-signal-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:18px;width:min(700px,100%)}
.home-signal-row a{border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.1);border-radius:8px;padding:12px 14px;color:#fff}
.home-signal-row strong{display:block;font-size:1.35rem;line-height:1}
.home-signal-row span{display:block;margin-top:5px;color:#dff3f7;font-size:.82rem;font-weight:700}
.stat-card,.feature-card{border-radius:8px;padding:22px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;box-shadow:none}
.stat-card.dark,.stat-card.light{background:rgba(255,255,255,.1);color:#fff}
.stat-card p,.feature-card p{color:#dff3f7;opacity:1}
.big-stat{font-size:2.3rem}
.section{padding:28px 0}
.section-head{justify-content:center;text-align:center;margin-bottom:28px}
.section-head h2{font-size:1.7rem}
.section-head p{margin-left:auto;margin-right:auto}
.grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}
.card,.list-card,.feature-card,.auth-card,.admin-card{border-radius:8px;padding:24px;background:#fff;border:1px solid #cbd9df}
.card:hover,.list-card:hover{transform:none;box-shadow:var(--shadow-soft)}
.card-image{border-radius:8px}
.badge{border-radius:8px;background:#eef6f8;color:var(--primary);border-color:#d5e4e8}
.datebox{border-radius:8px;background:var(--primary);box-shadow:none}
.notice,.empty-state{border-radius:8px}
.auth-wrap,.account-grid{gap:24px}
.site-footer{margin-top:80px;background:#f0f4f5;color:#335064;border-top:1px solid #d5e1e6}
.footer-inner{padding:34px 0}.footer-brand{color:#123044}.footer-links a{color:#335064}
.kicker{border-radius:8px;background:#0f4f62}
.home-main{padding-top:46px;min-height:0}
.home-main + .site-footer{margin-top:24px}
.home-overview .section-head h2{font-size:1.7rem}
.home-overview .section-head p{font-size:.92rem;max-width:540px}
.home-category-grid{grid-template-columns:repeat(3,1fr)}
.home-category-card{min-height:150px;color:inherit}
.home-category-card .badge{width:34px;height:34px;justify-content:center;padding:0}
.home-category-card .title{font-size:1.05rem;margin:18px 0 8px}
.home-category-card .body{font-size:.9rem}
.home-category-card .meta{color:var(--primary);font-size:.86rem}
.home-current{padding-top:12px}
.home-current-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.home-current-column{background:#fff;border:1px solid #cbd9df;border-radius:8px;padding:22px}
.home-current-head{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:14px}
.home-current-head h3{margin:0;font-size:1.1rem}
.home-current-head a{color:var(--primary);font-weight:800;font-size:.9rem}
.home-ads-stack{display:grid;gap:14px;margin:12px 0 22px}
.home-ad-band{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:22px;align-items:center;background:linear-gradient(135deg,#ffffff,#f4f9fa);border:1px solid #cbd9df;border-radius:10px;padding:20px 26px;position:relative;overflow:hidden}
.home-ad-band::before{content:"";position:absolute;left:-80px;top:-80px;width:220px;height:220px;border-radius:999px;background:rgba(21,88,107,.08)}
.home-ad-copy,.home-ad-actions{position:relative;z-index:1}
.home-ad-copy .badge{margin-bottom:10px;background:#fff4de;border-color:#ffe0a6;color:#9a5b00}
.home-ad-copy h2{margin:0 0 8px;font-size:1.2rem;line-height:1.15}
.home-ad-copy p{margin:0;color:var(--muted);line-height:1.55;max-width:760px}
.home-ad-domain{display:inline-flex;align-items:center;gap:8px;margin-top:10px;color:var(--primary);font-weight:800;font-size:.9rem}
.home-ad-domain::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--accent)}
.home-ad-actions{display:flex;align-items:center;gap:12px}
.home-ad-actions .btn{white-space:nowrap}
.home-current-item{display:block;padding:14px 0;border-top:1px solid #edf2f4}
.home-current-item strong{display:block;line-height:1.35}
.home-current-item span{display:block;margin-top:5px;color:var(--muted);font-size:.9rem}
.home-current-card{display:grid;gap:9px;padding:12px 0;border-top:1px solid #edf2f4}
.home-current-card img{width:100%;aspect-ratio:16/9;object-fit:contain;background:#eef4f5;border-radius:8px}
.home-current-card strong{display:block;line-height:1.35}
.home-current-card span{display:block;color:var(--muted);font-size:.9rem}
.trust-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;color:var(--primary);font-size:.82rem;font-weight:800}
.trust-meta span{display:inline-flex;align-items:center;padding:6px 9px;border-radius:8px;background:#eef6f8;border:1px solid #d5e4e8}
.rating-line{margin-top:12px;color:#9a5b00;font-weight:900}
.empty-state-strong{grid-column:1 / -1;text-align:center;background:#fff;border-color:#cbd9df;color:var(--text);padding:34px}
.empty-state-strong h3{margin:0 0 10px;font-size:1.35rem}
.empty-state-strong p{margin:0 auto 18px;max-width:620px;color:var(--muted);line-height:1.65}
.past-events-section{opacity:.78}
.past-events-section .card{background:#fbfcfc}
.recommendation-comments{max-width:860px;margin:34px auto 0}
.recommendation-comment-form{margin-bottom:18px}
.comment-list{display:grid;gap:12px}
.comment-card{background:#fff;border:1px solid #cbd9df;border-radius:8px;padding:18px}
.comment-card .meta{margin-top:0;margin-bottom:8px}
.reviewer-link{color:var(--primary);font-weight:900}
.reviewer-link:hover{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.member-review-head{display:flex;align-items:center;gap:18px;max-width:860px;margin:0 auto 22px}
.member-review-head h1{margin:0 0 8px;font-size:1.8rem}
.member-review-head p{margin:0;color:var(--muted);line-height:1.6}
.member-review-avatar{width:62px;height:62px;border-radius:16px;flex:0 0 62px}
.member-review-list{max-width:860px;margin:0 auto}
.settings-form{max-width:1180px}
.settings-jump-nav{position:sticky;top:0;z-index:4;display:flex;flex-wrap:wrap;gap:8px;margin:18px -4px 20px;padding:12px 4px;background:#fff;border-bottom:1px solid #edf2f4}
.settings-jump-nav .btn{padding:8px 10px;font-size:.9rem}
.settings-jump-nav .btn.active{background:var(--accent);border-color:var(--accent);color:#071b2a}
.settings-group{display:none;padding:18px 0;border-top:1px solid #edf2f4}
.settings-group.active{display:block}
.settings-group h3{margin:0 0 14px}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px}
.settings-group-ads .settings-grid{grid-template-columns:1fr}
.settings-ad-block{padding:18px 0 22px;border-top:1px solid #edf2f4}
.settings-ad-block:first-of-type{padding-top:4px;border-top:0}
.settings-ad-block h4{margin:0 0 14px;font-size:1.05rem;color:var(--primary)}
.settings-field.wide{grid-column:1 / -1}
.settings-field label{margin-top:0}
.toggle-field{display:inline-flex !important;align-items:center;gap:10px;margin:0 !important;padding:12px 14px;border:1px solid #d5e1e6;border-radius:8px;background:#fff;font-weight:800}
.toggle-field input{width:auto !important;accent-color:var(--accent)}
.share-links{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid #edf2f4;font-size:.86rem}
.share-links span{color:var(--muted);font-weight:700}
.share-links a,.share-links .share-copy{border:1px solid #d5e1e6;background:#fff;border-radius:8px;padding:7px 9px;color:var(--primary);font-weight:800;font-size:.84rem;line-height:1}
.share-links a:hover,.share-links .share-copy:hover{background:var(--accent);border-color:var(--accent);color:#071b2a}
.detail-article{background:#fff;border:1px solid #cbd9df;border-radius:10px;overflow:hidden;max-width:860px;margin:0 auto}
.detail-image{display:block;width:100%;max-height:460px;object-fit:cover;background:#e8f0f3}
.detail-content{padding:34px 38px}
.detail-content h1{margin:16px 0 14px;font-size:clamp(2rem,4vw,3rem);line-height:1.08}
.detail-lead{font-size:1.16rem;line-height:1.65;color:#335064;margin:20px 0}
.detail-article .body{font-size:1rem;line-height:1.78}
.detail-article .share-links{margin:0 38px 34px}
.detail-more{margin-top:42px}
.detail-more h2{text-align:center;margin-bottom:22px}
.home-submit-band{margin:28px 0;background:#fff;border:1px solid #cbd9df;border-radius:10px;padding:34px 40px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:28px}
.home-submit-band .eyebrow{display:inline-flex;background:#eef6f8;border-color:#d5e4e8;color:var(--primary);margin-bottom:12px}
.home-submit-band h2{margin:0 0 10px;font-size:1.45rem}
.home-submit-band p{margin:0;max-width:660px;line-height:1.6;color:var(--muted)}
.home-submit-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}
.home-submit-actions .btn{background:var(--accent);border-color:var(--accent);color:#071b2a}
.home-submit-actions .btn:hover{background:#fff;border-color:#d5e1e6;color:#071b2a}
.home-community-band{margin:28px 0 28px;background:linear-gradient(135deg,#ff9f1a,#ff8500);border-radius:10px;padding:34px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;color:#071b2a}
.home-community-band h2{margin:0 0 10px;font-size:1.45rem}
.home-community-band p{margin:0;max-width:620px;line-height:1.6}
.home-community-band .btn{background:#0f4f62;color:#fff}

.chat-page{width:100%;padding:0 0 72px}
.chat-page .section-head{background:linear-gradient(135deg,#15586b,#21889c);color:#fff;text-align:left;justify-content:flex-start;margin-bottom:48px;padding:64px max(16px,calc((100vw - 1080px)/2))}
.chat-page .section-head h2{font-size:2.45rem;color:#fff}.chat-page .section-head p{color:#e9f7fa;margin-left:0}
.chat-page .section-head .btn{background:#fff;color:var(--primary)}
.chat-shell{width:min(720px,calc(100% - 32px));margin:0 auto;border-radius:10px;padding:18px;background:#fff}
.messages{min-height:220px;max-height:320px;border-bottom:1px solid #d8e3e8;padding:14px;margin:8px 0 14px}
.bubble{background:#eaf4f7;border-radius:12px;color:#102534}
.msg.mine .bubble{background:var(--primary);color:#fff}
.private-chat-layout{display:grid;grid-template-columns:300px 1fr;gap:22px;align-items:start}
.private-member-list,.private-conversation{background:#fff;border:1px solid #cbd9df;border-radius:10px;padding:18px}
.private-member-list h3,.private-conversation h3{margin-top:0}
.private-member-list{display:grid;gap:8px}
.private-member-list a{display:flex;align-items:center;gap:12px;border:1px solid transparent;border-radius:10px;padding:10px;color:var(--text)}
.private-member-list a.active,.private-member-list a:hover{background:#eef6f8;border-color:#d5e4e8}
.private-member-list small{display:block;color:var(--muted);margin-top:2px}
.private-member-badge{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:var(--accent);color:#071b2a;font-size:.78rem;font-weight:900}
.private-conversation-head{border-bottom:1px solid #edf2f4;margin:-4px 0 16px;padding-bottom:14px}
.private-conversation-head p{margin:4px 0 0;color:var(--muted)}
.private-messages{display:flex;flex-direction:column;gap:10px;min-height:200px;max-height:300px;overflow:auto;padding:4px 4px 12px}
.private-message{max-width:76%;align-self:flex-start}
.private-message.mine{align-self:flex-end;text-align:right}
.private-message .meta{font-size:.82rem;color:var(--muted);margin-bottom:4px}
.private-message .bubble{display:inline-block;text-align:left;background:#eaf4f7;border-radius:12px;padding:10px 12px;line-height:1.5}
.private-message.mine .bubble{background:var(--primary);color:#fff}
.private-message-form{border-top:1px solid #edf2f4;margin-top:12px;padding-top:14px}
.private-message-form textarea{min-height:54px;max-height:100px}
.char-count{font-weight:800;color:var(--primary)}

.admin-page{background:#f7f8f7}
.admin-page .admin-layout{width:auto;margin:0 0 0 280px;padding:48px 64px}
.admin-page .admin-layout>.section-head{display:block;text-align:left;margin:0 0 38px}
.admin-page .admin-layout>.section-head h2{font-size:2.2rem}
.admin-page .admin-layout>.section-head .actions{display:none}
.admin-page .admin-nav{position:fixed;left:0;top:0;bottom:0;width:280px;box-sizing:border-box;margin:0;padding:66px 14px 14px;background:#124f63;border-right:1px solid rgba(255,255,255,.12);display:grid;grid-template-rows:repeat(10,min-content) 1fr min-content min-content;align-content:start;gap:6px;overflow-y:auto;overflow-x:hidden}
.admin-page .admin-nav::before{content:"Admin";position:absolute;left:20px;top:14px;color:#fff;font-weight:900;font-size:1.15rem}
.admin-page .admin-nav a{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;box-sizing:border-box;background:transparent;color:#fff;border:0;box-shadow:none;border-radius:9px;padding:10px 14px;white-space:normal;font-size:.95rem;line-height:1.2}
.admin-page .admin-nav a:hover,.admin-page .admin-nav a.active{background:var(--accent);color:#071b2a}
.admin-menu-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:var(--accent);color:#071b2a;font-size:.78rem;font-weight:900;line-height:1;flex:0 0 auto}
.admin-page .admin-nav a.active .admin-menu-badge,.admin-page .admin-nav a:hover .admin-menu-badge{background:#071b2a;color:#fff}
.admin-nav-spacer{min-height:8px}
.admin-page .admin-nav a.admin-nav-action{background:rgba(255,255,255,.08);text-align:center}
.admin-page .admin-nav a.admin-nav-action:hover{background:#fff;color:#102534}
.admin-page .admin-stats{grid-template-columns:repeat(3,minmax(220px,1fr));gap:22px}
.admin-page .admin-card{border-radius:10px;box-shadow:none}
.admin-page .admin-card .big-stat{color:#071b2a}
.admin-filter{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:14px 0 18px}
.admin-filter input,.admin-filter select{margin:0;padding:10px 12px;border-radius:8px}
.table td:first-child{border-radius:8px 0 0 8px}.table td:last-child{border-radius:0 8px 8px 0}
.admin-card{max-width:100%}

@media (max-width: 980px){
  .hero-inner,.hero-aside{grid-template-columns:1fr}
  .hero h1{white-space:normal}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .home-category-grid{grid-template-columns:1fr}
  .home-current-grid{grid-template-columns:1fr}
  .home-submit-band{grid-template-columns:1fr;padding:26px 24px}
  .home-submit-actions{justify-content:flex-start}
  .home-search{flex-direction:column}
  .home-signal-row{grid-template-columns:1fr 1fr}
  .home-ads-stack{margin:10px 0 18px}
  .home-ad-band{grid-template-columns:1fr;padding:18px 20px}
  .home-ad-actions{justify-content:flex-start}
  .home-community-band{align-items:flex-start;flex-direction:column;margin-bottom:80px}
  .main-nav{display:none}
  .admin-page .admin-layout{margin:0;padding:28px 16px}
  .admin-page .admin-nav{position:static;width:auto;padding:16px;margin-bottom:24px;border-radius:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));overflow:visible}
  .admin-page .admin-nav::before{display:none}
  .admin-page .admin-layout>.section-head .actions{position:static;display:flex}
  .admin-page .admin-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .settings-grid{grid-template-columns:1fr}
  .settings-field.wide{grid-column:auto}
}

@media (max-width: 1180px){
  .topbar-inner{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}
  .brand{min-width:0;width:auto}
  .brand strong{font-size:.95rem}
  .nav-toggle{display:grid;width:44px;height:40px;place-content:center;gap:5px;border:1px solid #d5e1e6;border-radius:8px;background:#fff;color:var(--primary);cursor:pointer}
  .nav-toggle span:not(.sr-only){display:block;width:20px;height:2px;background:currentColor;border-radius:999px}
  .main-nav,.nav-actions{display:none}
  .topbar.nav-open .main-nav,.topbar.nav-open .nav-actions{display:flex;grid-column:1 / -1;width:100%}
  .topbar.nav-open .main-nav{flex-direction:column;gap:0;padding:8px 0;border-top:1px solid #e3ecef;border-bottom:1px solid #e3ecef}
  .topbar.nav-open .main-nav a{width:100%;padding:13px 0;white-space:normal}
  .topbar.nav-open .nav-actions{flex-wrap:wrap;gap:8px;padding-bottom:8px}
  .nav-actions .btn{flex:1 1 auto;text-align:center}
}

@media (max-width: 760px){
  html,body{overflow-x:hidden}
  .topbar{position:static}
  .topbar-inner,.hero-inner{width:calc(100% - 24px)}
  .brand{min-width:0;overflow:hidden}
  .brand-mark{flex:0 0 44px;width:44px;height:44px}
  .brand strong{white-space:normal;overflow-wrap:anywhere;line-height:1.12;font-size:.9rem}
  .container{padding:28px 0 56px}
  .hero{padding:42px 0;overflow:hidden}
  .hero-panel{text-align:center}
  .hero h1{font-size:clamp(1.95rem,9vw,2.35rem);text-align:center;max-width:100%;overflow-wrap:break-word}
  .hero h1 span{display:block;white-space:normal;overflow-wrap:break-word}
  .hero p{max-width:100%;margin-left:auto;margin-right:auto;text-align:center;overflow-wrap:break-word}
  .hero-actions,.home-search,.home-signal-row{margin-left:auto;margin-right:auto}
  .hero-actions,.actions{width:100%}
  .hero-actions .btn,.home-submit-actions .btn,.home-community-band .btn{width:100%;justify-content:center;text-align:center}
  .home-ad-actions,.home-ad-actions .btn{width:100%}
  .home-search{width:100%;max-width:100%}
  .home-search input{min-width:0;width:100%}
  .home-feature-tile{min-height:auto}
  .home-submit-band,.home-community-band{padding:24px 20px}
  .detail-content{padding:24px 20px}
  .detail-article .share-links{margin:0 20px 24px}
  .detail-image{max-height:300px}
  .section-head{text-align:left;align-items:flex-start}
  .section-head p{margin-left:0;margin-right:0}
  .auth-wrap,.account-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .chat-page .section-head{padding:38px 16px;margin-bottom:28px}
  .chat-page .section-head h2{font-size:2rem}
  .chat-shell{width:calc(100% - 20px);padding:12px}
  .messages{min-height:220px;max-height:340px;padding:12px}
  .private-messages{min-height:220px;max-height:340px}
  .private-chat-layout{grid-template-columns:1fr}
  .private-member-list{max-height:280px;overflow:auto}
  .private-message{max-width:92%}
  .admin-page .admin-layout{padding:16px 10px 44px;margin:0;width:100%;max-width:100%;overflow:hidden}
  .admin-page .admin-layout>.section-head{margin-bottom:18px}
  .admin-page .admin-layout>.section-head h2{font-size:1.8rem}
  .admin-page .admin-layout>.section-head .actions{width:100%;gap:8px}
  .admin-page .admin-layout>.section-head .actions .btn{flex:1 1 auto;text-align:center}
  .admin-page .admin-nav{margin-left:-10px;margin-right:-10px;padding:12px 10px;gap:8px;border-radius:0;grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-page .admin-nav a{width:100%;white-space:normal;padding:10px 12px;font-size:.9rem;min-width:0}
  .admin-page .admin-stats{grid-template-columns:1fr;gap:14px}
  .admin-page .admin-card{padding:18px;overflow:hidden}
  .admin-page .auth-wrap{grid-template-columns:1fr}
  .admin-filter{grid-template-columns:1fr;gap:8px}
  .table,.table tbody,.table tr,.table td{display:block;width:100%;min-width:0}
  .table{border-collapse:separate;border-spacing:0}
  .table th{display:none}
  .table tr{border:1px solid var(--line);border-radius:8px;background:#fff;margin:0 0 12px;overflow:hidden}
  .table td{border:0 !important;border-radius:0 !important;padding:12px 14px}
  .table td+td{border-top:1px solid #edf2f4 !important}
  .table .inline-links{align-items:flex-start;flex-direction:column}
  .table select,.table input[type=file],.table .btn{max-width:100% !important;width:100%}
  .user-cell{align-items:flex-start}
  .filters{display:flex;flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity}
  .filters .filter{flex:0 0 auto;scroll-snap-align:start}
  .home-signal-row{grid-template-columns:1fr}
  .home-current-column{padding:16px}
  .settings-form{padding:16px}
  .settings-jump-nav{position:static}
  .settings-jump-nav .btn{flex:1 1 100%;justify-content:center}
  .settings-group{padding:16px 0}
}
