
:root{
  --maroon:#c90a0a;
  --maroon-dark:#a30808;
  --maroon-ink:#650505;
  --maroon-soft:#fff0f0;
  --maroon-glow:rgba(201,10,10,.14);
  --bg:#f4f1f3;
  --bg-accent:#fbf8f9;
  --card:#ffffff;
  --text:#17141a;
  --muted:#6f6770;
  --border:#eadde1;
  --border-strong:#dcc5cb;
  --danger:#b91c1c;
  --success:#166534;
  --warning:#92400e;
  --shadow-sm:0 8px 24px rgba(61,22,35,.06);
  --shadow-md:0 20px 40px rgba(61,22,35,.09);
  --shadow-lg:0 28px 70px rgba(61,22,35,.16);
  --radius:20px;
  --radius-sm:14px;
  --radius-xs:10px;
  --container:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at top left,#fbf6f7 0,#f6f1f3 32%,#f2eff1 100%);color:var(--text);line-height:1.5}
a{color:var(--maroon);text-decoration:none;transition:color .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease}
a:hover{text-decoration:none;color:var(--maroon-dark)}
img{max-width:100%}
h1,h2,h3,h4{margin:0 0 8px;line-height:1.15;letter-spacing:-.02em}
h1{font-size:clamp(1.8rem,1.2rem + 1.8vw,2.55rem)}
h2{font-size:clamp(1.4rem,1.1rem + 1vw,1.95rem)}
h3{font-size:1.08rem}
p{margin:0 0 10px}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.flex{display:flex}.between{justify-content:space-between}.center{align-items:center}.gap{gap:10px}

.topbar{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,rgba(163,8,8,.97),rgba(201,10,10,.96));color:#fff;backdrop-filter:blur(12px);box-shadow:0 10px 30px rgba(95,8,8,.22);border-bottom:1px solid rgba(255,255,255,.08)}
.topbar::after{content:"";position:absolute;inset:auto 0 0 0;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.08),rgba(255,255,255,.32),rgba(255,255,255,.08))}
.topbar{padding:12px 0}
.topbar-inner{max-width:none;padding:0 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.topbar-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1}
.topbar-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;justify-content:flex-end}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-copy{min-width:0}
.logo{width:46px;height:46px;border-radius:16px;background:linear-gradient(145deg,#fff,#ffe6e6);color:var(--maroon);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 8px 20px rgba(95,8,8,.18);border:1px solid rgba(255,255,255,.35);flex-shrink:0}
.brand-title{font-weight:800;font-size:1.02rem;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.brand-sub{font-size:12px;color:rgba(255,255,255,.78);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.brand-mark{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.64);margin-bottom:2px}
.nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.nav a{color:rgba(255,255,255,.9);padding:10px 12px;border-radius:12px;font-weight:600}
.nav a:hover{background:rgba(255,255,255,.09);color:#fff}
.nav .btn{margin-left:0}
.nav-toggle{display:none;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:9px 12px;border-radius:12px}
.nav-toggle:hover{background:rgba(255,255,255,.18)}

.footer{padding:20px 0;color:#fbeff2;background:linear-gradient(180deg,var(--maroon-dark),#48101c);margin-top:30px;border-top:1px solid rgba(255,255,255,.08)}
.footer .container{display:flex;justify-content:center}

.public-shell{padding:28px 0 34px}
.public-stack{display:flex;flex-direction:column;gap:20px}
.public-hero{position:relative;overflow:hidden;padding:28px;border-radius:30px;background:linear-gradient(135deg,#ffffff 0,#fff4f4 52%,#ffe1e1 100%);border:1px solid var(--border);box-shadow:var(--shadow-lg)}
.public-hero::before{content:"";position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,rgba(201,10,10,.12),transparent 70%)}
.public-hero::after{content:"";position:absolute;left:-40px;bottom:-70px;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(201,10,10,.08),transparent 70%)}
.hero-grid{display:grid;grid-template-columns:1.45fr .95fr;gap:18px;position:relative;z-index:1}
.hero-kicker{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--border);color:var(--maroon);font-weight:700;font-size:.79rem;letter-spacing:.06em;text-transform:uppercase;box-shadow:var(--shadow-sm)}
.hero-copy p{max-width:56ch}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.hero-panel{display:grid;gap:12px;align-content:start}
.hero-panel .card{background:rgba(255,255,255,.76);backdrop-filter:blur(10px)}
.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.hero-stat{padding:16px;border-radius:20px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.hero-stat-value{font-size:1.55rem;font-weight:800;color:var(--maroon)}
.hero-stat-label{font-size:.86rem;color:var(--muted)}

.app-shell{display:flex;align-items:flex-start;gap:clamp(14px,1.6vw,24px);min-height:calc(100dvh - 82px);padding:20px 20px 26px;max-width:1440px;margin:0 auto}
.sidebar{flex:0 1 clamp(240px,22vw,320px);width:clamp(240px,22vw,320px);min-width:220px;max-width:100%;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,251,252,.92));border:1px solid rgba(255,255,255,.62);box-shadow:var(--shadow-md);backdrop-filter:blur(10px);padding:clamp(14px,1.2vw,18px);border-radius:26px;position:sticky;top:98px;max-height:calc(100dvh - 118px);overflow:auto;overscroll-behavior:contain}
.app-main{flex:1;min-width:0;padding:0 4px 12px}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.page-title{display:flex;flex-direction:column;gap:6px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--maroon)}

.side-section{margin-bottom:18px}
.side-label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#9f6b6b;margin:0 0 10px;padding:0 8px;font-weight:800}
.side-group{display:grid;gap:4px}
.side-profile-card{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;padding:14px;border-radius:20px;background:linear-gradient(135deg,#fff7f8,#fff);border:1px solid var(--border);margin-bottom:18px;min-width:0}
.side-profile-avatar{width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff;font-weight:800;flex-shrink:0}
.side-profile-name,.side-profile-role{overflow-wrap:anywhere;word-break:break-word}
.side-profile-name{font-weight:800}
.side-profile-role{font-size:13px;color:var(--muted)}
.side-link{display:flex;align-items:center;gap:12px;padding:12px 13px;border-radius:16px;color:#2f2730;border:1px solid transparent;font-weight:600;position:relative;z-index:2}
.side-link:hover{background:#fff7f8;border-color:#f2dbe2;box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.side-link.active{background:linear-gradient(135deg,var(--maroon) 0,var(--maroon-dark) 100%);color:#fff;border-color:transparent;box-shadow:0 16px 30px rgba(163,8,8,.28)}
.side-link.active .side-icon{background:rgba(255,255,255,.16);color:#fff}
.side-icon{width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#fff0f0;border:1px solid #f3d1d1;color:var(--maroon);font-size:16px;flex-shrink:0}
.side-note{margin-top:16px;padding:14px;border-radius:18px;background:linear-gradient(135deg,#fff3f3,#fff);border:1px solid var(--border)}
.side-note .muted{font-size:12px}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.stack{display:flex;flex-direction:column;gap:14px;margin-top:16px}

.card{position:relative;background:linear-gradient(180deg,#ffffff 0,#fffdfd 100%);border:1px solid rgba(255,255,255,.72);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(201,10,10,.04);pointer-events:none}
.card + .card{margin-top:0}
.card-title{font-weight:800;font-size:1.02rem;margin-bottom:4px;letter-spacing:-.01em}
.card-subtitle,.muted{color:var(--muted);font-size:13px}
.card-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.card-section{margin-top:14px;padding-top:14px;border-top:1px solid rgba(201,10,10,.08)}
.mini-item{padding:12px 0;border-bottom:1px dashed #eadde1}
.mini-item:last-child{border-bottom:none}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.stat-card{min-height:126px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;background:linear-gradient(180deg,#fff,#fff8f9)}
.stat-card::before{content:"";position:absolute;right:-28px;top:-28px;width:120px;height:120px;border-radius:999px;background:radial-gradient(circle,rgba(201,10,10,.14),transparent 72%)}
.stat-label{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#9f6b6b;font-weight:700}
.stat-value{font-size:2rem;font-weight:800;margin-top:10px;color:var(--maroon);letter-spacing:-.03em}
.stat-foot{font-size:13px;color:var(--muted)}
.dashboard-cta{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}
.metric-list{display:grid;gap:10px;margin-top:12px}
.metric-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:#fffdfd}

.toolbar,.table-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;margin-bottom:10px}
.label{display:block;margin-top:12px;margin-bottom:6px;color:#735c63;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:#fff;outline:none;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;color:var(--text)}
.input:hover{border-color:var(--border-strong)}
.input:focus{border-color:#df9a9a;box-shadow:0 0 0 5px var(--maroon-glow);transform:translateY(-1px)}
.input-sm{padding:8px 10px;border-radius:12px}
textarea.input{resize:vertical;min-height:120px}
.helper-text{font-size:.85rem;color:#7a7076;margin-top:6px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:14px;padding:11px 14px;cursor:pointer;font-weight:700;text-decoration:none;line-height:1.2;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(38,12,18,.12)}
.btn-sm{padding:8px 11px;border-radius:12px;font-size:13px}
.btn-primary{background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff;box-shadow:0 14px 28px rgba(163,8,8,.2)}
.btn-primary:hover{color:#fff}
.btn-outline{background:rgba(255,255,255,.92);border:1px solid #f0c9c9;color:var(--maroon)}
.btn-outline:hover{background:#fff1f1}
.btn-danger{background:linear-gradient(135deg,#c12929,#991b1b);color:#fff}
.icon-btn{border:none;background:transparent;font-size:18px;cursor:pointer}

.badge{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;border:1px solid #f3d1d1;background:#fff0f0;color:var(--maroon);font-size:12px;font-weight:700}
.badge-neutral{background:#faf7f8;border-color:var(--border);color:#66545d}

.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:18px;background:#fff}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{border-bottom:1px solid #efe5e8;padding:12px 14px;vertical-align:top;background:#fff}
.table th{position:sticky;top:0;background:#fcf7f8;font-size:11px;color:#7e646c;text-transform:uppercase;letter-spacing:.12em;text-align:left}
.table tr:hover td{background:#fff4f4}
.table tbody tr:last-child td{border-bottom:none}

.auth-shell{padding:36px 0 52px}
.auth-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);gap:22px;align-items:stretch}
.auth-card{max-width:none;margin:0;padding:24px}
.auth-panel{position:relative;overflow:hidden;padding:26px;border-radius:28px;background:linear-gradient(140deg,var(--maroon) 0,var(--maroon-dark) 100%);color:#fff;box-shadow:var(--shadow-lg)}
.auth-panel::before{content:"";position:absolute;right:-70px;top:-70px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 65%)}
.auth-panel::after{content:"";position:absolute;left:-40px;bottom:-60px;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 65%)}
.auth-panel > *{position:relative;z-index:1}
.auth-features{display:grid;gap:12px;margin-top:18px}
.auth-feature{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14)}
.auth-form-head{margin-bottom:18px}
.auth-form-foot{margin-top:16px}

.alert{padding:12px 14px;border-radius:14px;margin:12px 0;font-size:14px}
.alert-danger{background:#feecec;border:1px solid #f7caca;color:#8e1d1d}
.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a}

.modal{position:fixed;inset:0;display:none;z-index:2147483647;pointer-events:none}
.modal.open{display:flex;align-items:center;justify-content:center;padding:18px;pointer-events:auto}
.modal-backdrop{position:fixed;inset:0;background:rgba(36,14,20,.62);backdrop-filter:blur(6px);z-index:2147483646}
.modal-card{position:relative;z-index:2147483647;width:min(860px,96vw);max-height:88vh;overflow:auto;background:#fff;border-radius:22px;border:1px solid rgba(255,255,255,.65);box-shadow:var(--shadow-lg)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff}
.modal-title{font-weight:800}
.modal-body{padding:16px}
body.modal-open{overflow:hidden}
body.modal-open .topbar,body.modal-open .sidebar,body.modal-open .app-shell,body.modal-open .app-main,body.modal-open .card,body.modal-open .table,body.modal-open .table thead,body.modal-open .table thead th{z-index:1!important;position:relative!important}

.toast-wrap{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:999}
.toast{background:#111827;color:#fff;padding:10px 12px;border-radius:14px;max-width:340px;box-shadow:0 14px 28px rgba(0,0,0,.22)}
.toast.ok{background:var(--maroon)}
.toast.bad{background:var(--danger)}

.prose{white-space:pre-wrap;line-height:1.6;overflow-wrap:anywhere;word-break:break-word}
.list{margin:10px 0 0 18px;padding:0}

.announcement-card{overflow:hidden;min-width:0}
.announcement-title,.announcement-body,.announcement-comment-body,.announcement-meta,.announcement-badges,.comment-item,.comment-item b,.announcement-comments .muted{min-width:0;overflow-wrap:anywhere;word-break:break-word}
.announcement-title{display:block}
.announcement-body,.announcement-comment-body,.announcement-card .prose{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}
.announcement-icon{width:48px;height:48px;border-radius:16px;background:#fff0f0;border:1px solid #f3d1d1;display:flex;align-items:center;justify-content:center;font-size:24px;flex:0 0 48px;box-shadow:var(--shadow-sm)}
.announcement-gallery{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;align-items:flex-start}
.announcement-gallery--single{justify-content:flex-start}
.announcement-image-link{display:block;position:relative;width:min(180px,100%);min-width:110px;max-width:100%;border:1px solid var(--border);border-radius:18px;background:#fbf7f8;overflow:hidden;text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .18s ease, box-shadow .18s ease}
.announcement-image-link::after{content:'Click to view';position:absolute;left:10px;right:10px;bottom:10px;padding:7px 10px;border-radius:999px;background:rgba(36,14,20,.62);color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;text-align:center;opacity:0;transform:translateY(6px);transition:opacity .18s ease, transform .18s ease;pointer-events:none}
.announcement-image-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.announcement-image-link:hover::after,.announcement-image-link:focus-visible::after{opacity:1;transform:translateY(0)}
.announcement-gallery:not(.announcement-gallery--single) .announcement-image-link,.announcement-gallery--single .announcement-image-link{aspect-ratio:4/3}
.announcement-image{width:100%;height:100%;display:block;background:#f8fafc;cursor:pointer;object-fit:cover}
.announcement-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.announcement-comments{margin-top:14px;padding-top:14px;border-top:1px dashed var(--border)}
.comment-item{padding:12px;border:1px solid var(--border);border-radius:16px;background:#fcfafb}
.announcement-image-fallback{display:flex;align-items:center;justify-content:center;min-height:180px;height:100%;width:100%;border:1px dashed var(--border);border-radius:16px;background:#fafafa;color:var(--muted);font-size:13px;padding:16px;text-align:center}
.lightbox-wrap{display:flex;align-items:center;justify-content:center;padding:6px}
.lightbox-image{max-width:min(92vw,1100px);max-height:78vh;width:auto;height:auto;border-radius:18px;display:block;background:#fff;object-fit:contain}

.search-suggest-wrap{position:relative;max-width:520px;flex:1 1 360px}
.search-suggest-list{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);max-height:280px;overflow:auto;z-index:50;padding:6px}
.search-suggest-item{padding:10px 12px;border-radius:12px;cursor:pointer}
.search-suggest-item:hover,.search-suggest-item.active{background:#fff0f0}

.user-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.user-form-grid .full-span{grid-column:1/-1}
.user-form-section{margin-top:14px;padding-top:14px;border-top:1px solid rgba(201,10,10,.08)}
.profile-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:16px}
.profile-grid > .card{min-height:100%}
.profile-hero{display:grid;grid-template-columns:170px 1fr;gap:16px;align-items:center}
.profile-photo-lg{width:160px;height:160px;border-radius:24px;object-fit:cover;background:#f2f2f2;display:flex;align-items:center;justify-content:center;font-size:64px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.profile-photo-placeholder{border:2px dashed rgba(201,10,10,.12)}
.profile-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.mini-stat,.profile-info-grid>div{padding:12px;border:1px solid rgba(201,10,10,.08);border-radius:16px;background:#fff}
.mini-label{display:block;color:#7a7a7a;font-size:.78rem;margin-bottom:4px}
.profile-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:10px}
.user-avatar{width:46px;height:46px;border-radius:14px;object-fit:cover;background:#f1f1f1;display:inline-flex;align-items:center;justify-content:center;font-size:20px;margin-right:10px;vertical-align:middle;border:1px solid var(--border)}
.user-name-cell{display:flex;align-items:center;gap:10px;min-width:220px}
.message-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}
.message-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.message-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.compose-form{display:grid;gap:0}
.compose-form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.compose-form-actions .btn{min-width:120px}
.compose-textarea{min-height:180px}
.recipient-picker{position:relative}
.recipient-suggestions{max-height:min(240px,32vh);overflow:auto;border:1px solid var(--border);border-radius:16px;margin-top:8px;background:#fff;box-shadow:var(--shadow-sm)}
.recipient-group-label{position:sticky;top:0;z-index:1;padding:8px 12px;background:#fcf7f8;border-top:1px solid #f1e7ea;border-bottom:1px solid #f1e7ea;color:var(--maroon);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.recipient-suggestions > .recipient-group-label:first-child{border-top:none;border-top-left-radius:16px;border-top-right-radius:16px}
.recipient-option{display:block;width:100%;text-align:left;border:0;background:#fff;padding:10px 12px;cursor:pointer}
.recipient-option + .recipient-option{border-top:1px solid #f1e7ea}
.recipient-option:hover,.recipient-option.active{background:#fff4f4}
.recipient-option-name{font-weight:700}
.recipient-option-meta{font-size:12px;color:var(--muted);margin-top:2px;overflow-wrap:anywhere;word-break:break-word}
.sidebar-overlay{display:none}

@media (max-width:1100px){
  .hero-grid,.auth-grid,.grid-4{grid-template-columns:1fr 1fr}
  .profile-grid{grid-template-columns:1fr}
}
@media (max-width:980px){
  .public-topbar-inner{align-items:flex-start}
  .public-nav{width:100%;justify-content:flex-start}
  .nav-toggle{display:inline-flex}
  .topbar-inner{padding:0 12px;gap:12px}
  .topbar-left{gap:10px}
  .topbar-actions{gap:8px}
  .app-shell{display:block;padding:14px 14px 24px}
  .sidebar{position:fixed;left:14px;top:82px;bottom:14px;width:min(340px,calc(100vw - 28px));min-width:0;height:auto;max-height:none;transform:translateX(calc(-100% - 18px));transition:transform .22s ease;box-shadow:var(--shadow-lg);z-index:2000}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay{position:fixed;inset:74px 0 0 0;background:rgba(20,8,11,.38);backdrop-filter:blur(4px);z-index:1999}
  .sidebar-overlay.open{display:block}
  .app-main{padding:4px 2px 0}
  .grid-3,.grid-4,.hero-grid,.auth-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .container{padding:0 16px}
  .public-topbar .brand{align-items:flex-start}
  .public-topbar .brand-copy{width:100%}
  .public-nav a{flex:1 1 calc(50% - 10px);text-align:center}
  .public-nav .btn{justify-content:center}

  .topbar-inner{align-items:flex-start;flex-direction:column}
  .topbar-left,.topbar-actions{width:100%}
  .topbar-actions{justify-content:stretch;flex-wrap:wrap}
  .topbar-actions > .btn{flex:1}
  .topbar-actions .topbar-profile,.topbar-actions .notification-wrap{flex:1 1 100%}
  .topbar-actions .topbar-profile-trigger,.topbar-actions .notification-btn{width:100%}
  .topbar-actions .topbar-profile-dropdown,.topbar-actions .notification-dropdown{left:0;right:auto;width:min(100%,280px)}
  .brand-sub{white-space:normal;line-height:1.35}
  .public-hero,.auth-panel,.card{padding:20px}
  .hero-stats,.grid-2,.profile-stat-row,.profile-info-grid{grid-template-columns:1fr}
  .profile-hero{grid-template-columns:1fr}
}
@media (max-width:560px){
  h1{font-size:1.7rem}
  .compose-form-actions > *{flex:1 1 100%}
  .logo{width:42px;height:42px;border-radius:14px}
  .public-topbar .brand{gap:10px}
  .public-logo{width:48px;height:48px;border-radius:16px;font-size:1.2rem}
  .public-nav a{flex:1 1 100%}

  .table th,.table td{padding:10px 12px}
  .announcement-gallery{grid-template-columns:repeat(auto-fit,minmax(min(140px,100%),1fr));gap:10px}
  .announcement-gallery:not(.announcement-gallery--single) .announcement-image-link{min-height:150px}
}

/* Modern UI upgrade */
.logo-seal{border-radius:18px;background:linear-gradient(160deg,#fff,#f7e9ed);box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 12px 24px rgba(95,8,8,.18);}
.public-topbar{position:sticky}
.public-topbar-inner{max-width:none;padding:0 18px}
.public-nav a.active{background:rgba(255,255,255,.12);color:#fff}
.app-topbar .topbar-chip{display:inline-flex;align-items:center;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);font-size:12px;color:#fff;font-weight:700}
.public-home-stack{gap:24px}
.public-hero--xl{padding:34px;border-radius:32px}
.public-hero--compact{padding:24px;border-radius:28px}
.hero-grid--modern{grid-template-columns:1.2fr .95fr;gap:22px;align-items:stretch}
.hero-copy--wide{display:flex;flex-direction:column;justify-content:center}
.hero-title{margin-top:16px;max-width:11.5ch;font-size:clamp(2.4rem,1.6rem + 2vw,4rem);line-height:.98}
.hero-lead{font-size:1.03rem;max-width:62ch;color:#5f535b;margin-top:12px}
.btn-ghost{background:transparent;border:1px dashed #d4b3bb;color:var(--maroon)}
.btn-ghost:hover{background:#fff7f9}
.btn-lg{padding:14px 16px;border-radius:16px}
.input-lg{padding:14px 16px;border-radius:16px}
.hero-feature-strip{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.hero-feature-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.74);border:1px solid var(--border);font-weight:700;color:#4a2732;box-shadow:var(--shadow-sm)}
.pill-dot{width:8px;height:8px;border-radius:999px;background:var(--maroon);display:inline-block}
.hero-panel--dashboard{display:flex;align-items:stretch}
.hero-surface{width:100%;padding:22px;border-radius:28px;background:linear-gradient(160deg,rgba(122,12,34,.98),rgba(92,8,25,.96));color:#fff;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:18px;overflow:hidden;position:relative}
.hero-surface::after{content:"";position:absolute;right:-80px;top:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.14),transparent 68%)}
.hero-surface > *{position:relative;z-index:1}
.surface-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.surface-kicker{font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.7);font-weight:800;margin-bottom:4px}
.surface-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.surface-stat{padding:14px;border-radius:20px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12)}
.surface-stat-value{font-size:1.7rem;font-weight:800;letter-spacing:-.03em}
.surface-stat-label{font-size:.85rem;color:rgba(255,255,255,.74)}
.surface-timeline{display:grid;gap:10px}
.surface-item{display:flex;gap:12px;padding:12px 0;border-top:1px solid rgba(255,255,255,.12)}
.surface-item:first-child{border-top:none;padding-top:0}
.surface-item-icon{width:40px;height:40px;border-radius:14px;background:rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}
.feature-band{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.feature-card{padding:20px;border-radius:24px;background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.7);box-shadow:var(--shadow-sm);display:flex;gap:14px;align-items:flex-start}
.feature-card--highlight{background:linear-gradient(160deg,#fff7f8,#fff);border-color:#f1d6dd}
.feature-icon,.news-icon,.empty-state-icon,.feed-item-icon{width:46px;height:46px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:#fff0f0;border:1px solid #efd6dd;flex-shrink:0;font-size:22px}
.card-section--split,.card-section--news,.card-section--programs{padding:22px}
.content-grid-loose{gap:18px}
.info-panel{padding:18px;border-radius:22px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.info-step{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:12px;background:#fff1f4;color:var(--maroon);font-weight:800;margin-bottom:12px}
.news-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:12px}
.news-card{padding:18px;border-radius:24px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;min-width:0}
.news-card-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.news-meta-block{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.news-date{font-size:.8rem;font-weight:700;color:#9f6b6b}
.news-title{line-height:1.2}.news-copy{margin-bottom:0}.news-foot{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}
.program-chip-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.program-chip{padding:16px 18px;border-radius:22px;background:linear-gradient(160deg,#fff,#fff6f7);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.program-chip-code{display:block;font-size:1.1rem;font-weight:800;color:var(--maroon)}
.program-chip-copy{display:block;margin-top:4px;color:var(--muted);font-size:.9rem}
.programs-showcase{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.program-showcase-card{padding:22px;border-radius:26px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.program-showcase-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}
.program-badge{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:#fff1f4;color:var(--maroon);font-weight:800}
.program-showcase-code{font-size:1.25rem;font-weight:800;color:var(--maroon)}
.program-showcase-name{font-size:1rem;font-weight:700;margin-top:8px}
.news-feed-stack{display:grid;gap:16px}
.announcement-card--rich{padding:20px;border-radius:24px}
.announcement-body--lead{font-size:1rem;line-height:1.7;color:#3f2f35}
.auth-grid--modern{grid-template-columns:minmax(0,1.15fr) minmax(390px,.85fr)}
.auth-panel--modern{padding:30px;border-radius:30px}
.auth-card--modern{padding:26px;border-radius:28px}
.auth-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:20px}
.auth-feature--glass{background:rgba(255,255,255,.09)}
.auth-form-foot--stack{display:grid;gap:14px}
.auth-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.side-profile-card{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;padding:14px 14px 16px;margin-bottom:16px;border-radius:20px;background:linear-gradient(160deg,#fff8f9,#fff);border:1px solid var(--border);min-width:0}
.side-profile-avatar{width:48px;height:48px;border-radius:16px;background:linear-gradient(160deg,var(--maroon),var(--maroon-dark));color:#fff;font-weight:800;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 24px rgba(92,8,25,.18);flex-shrink:0}
.side-profile-name{font-weight:800;color:#2f2730;overflow-wrap:anywhere;word-break:break-word}.side-profile-role{font-size:.85rem;color:#7a7076;overflow-wrap:anywhere;word-break:break-word}
.side-note--modern{background:linear-gradient(160deg,#fff8f9,#fff)}
.page-head--hero{padding:4px 4px 2px;margin-bottom:20px}.page-head-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.dashboard-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;margin-top:16px}
.dashboard-layout--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}
.dashboard-card{min-height:100%}.dashboard-card--feature{background:linear-gradient(180deg,#fff,#fffafc)}
.stat-card--premium{overflow:hidden;background:linear-gradient(180deg,#fff,#fff8f9)}
.feed-stack{display:grid;gap:10px;margin-top:8px}.feed-item{display:flex;gap:12px;padding:12px;border:1px solid var(--border);border-radius:18px;background:#fffdfd}.feed-item--schedule .feed-item-icon{font-size:18px}
.empty-state{display:flex;align-items:center;gap:14px;padding:18px;border:1px dashed var(--border);border-radius:20px;background:#fffdfd}.empty-state--small{padding:14px}
.card-toolbar--tight{margin-bottom:8px}
@media (max-width:1200px){.feature-band,.news-grid,.program-chip-grid,.programs-showcase{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:1100px){.hero-grid--modern,.dashboard-layout,.dashboard-layout--secondary,.auth-grid--modern{grid-template-columns:1fr}.auth-feature-grid{grid-template-columns:1fr 1fr}}
@media (max-width:760px){.public-topbar-inner{padding:0 12px}.topbar-actions .topbar-chip{display:none}.feature-band,.news-grid,.program-chip-grid,.programs-showcase,.grid-3,.auth-feature-grid,.auth-mini-grid{grid-template-columns:1fr}.hero-title{max-width:none}.surface-grid{grid-template-columns:1fr 1fr}.hero-actions,.page-head-actions{width:100%}.btn,.btn-lg{width:100%}.card-toolbar{align-items:flex-start}.program-showcase-card,.news-card,.feature-card{padding:18px}.surface-header{flex-direction:column}.news-meta-block{align-items:flex-start}.auth-grid--modern{gap:16px}}
.profile-photo-form{margin-top:16px;padding-top:16px;border-top:1px solid rgba(201,10,10,.08)}
.profile-photo-actions{display:flex;gap:10px;align-items:center;margin-top:8px;flex-wrap:wrap}
.profile-photo-actions .input{min-width:260px;flex:1 1 280px}

.profile-photo-preview-wrap{display:flex;align-items:center;gap:14px;margin-top:10px;padding:12px;border:1px dashed rgba(122,12,34,.16);border-radius:18px;background:#fffafb}
.profile-photo-preview,.profile-photo-preview-placeholder{width:86px;height:86px;border-radius:22px;object-fit:cover;background:#f5f5f5;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:34px;box-shadow:var(--shadow-sm);flex-shrink:0}
.profile-photo-preview-label{font-weight:700;margin-bottom:4px}


.landing-hero--department{background:linear-gradient(135deg,#fff 0,#fff6f7 42%,#f8e5ea 100%)}
.landing-hero-grid{grid-template-columns:1.12fr .88fr;gap:22px}
.landing-copy .hero-title{max-width:12ch}
.landing-hero-panel{gap:14px}
.landing-showcase-card{background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,248,250,.98));border:1px solid var(--border);border-radius:26px;overflow:hidden;box-shadow:var(--shadow-md)}
.landing-showcase-media{aspect-ratio:16/11;background:#f5eaed;display:flex;align-items:center;justify-content:center;padding:12px}
.landing-showcase-media img,.landing-showcase-media video{width:100%;height:100%;display:block;border-radius:18px}
.landing-showcase-media--image img{object-fit:contain;background:#fff}
.landing-showcase-media--video video{object-fit:cover}
.landing-showcase-copy{padding:16px 18px 18px}
.landing-gallery-card,.landing-story-card{overflow:hidden}
.landing-media-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.landing-media-tile{overflow:hidden;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,#fff,#fff8f9);box-shadow:var(--shadow-sm)}
.landing-media-frame{aspect-ratio:4/3;background:#f6ecef;display:flex;align-items:center;justify-content:center;padding:10px}
.landing-media-frame img,.landing-media-frame video{width:100%;height:100%;display:block;border-radius:16px}
.landing-media-frame--image img{object-fit:contain;background:#fff}
.landing-media-frame--video video{object-fit:cover}
.landing-media-copy{padding:14px 16px 16px}
.landing-admin-grid{align-items:start}
.landing-media-admin-list{display:grid;gap:16px}
.landing-media-admin-item{display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:18px;padding:14px;border:1px solid var(--border);border-radius:22px;background:#fff9fa}
.landing-media-admin-preview{border-radius:18px;overflow:hidden;background:#f6ecef;min-height:220px;display:flex;align-items:center;justify-content:center;padding:10px}
.landing-media-admin-preview img,.landing-media-admin-preview video{width:100%;height:100%;display:block;border-radius:14px}
.landing-media-admin-preview img{object-fit:contain;background:#fff}
.landing-media-admin-preview video{object-fit:cover}
.empty-state{display:flex;align-items:center;gap:14px;padding:18px;border:1px dashed var(--border);border-radius:18px;background:#fffafb}
.empty-state-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#fff0f0;font-size:24px}
.btn-ghost{background:transparent;border:1px dashed #e7c9d1;color:var(--maroon)}
.surface-kicker{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#9f6b6b;font-weight:800}
.surface-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.surface-stat{padding:14px 16px;border:1px solid rgba(201,10,10,.08);border-radius:18px;background:#fff}
.surface-stat-value{font-size:1.45rem;font-weight:800;color:var(--maroon)}
.surface-stat-label{font-size:.82rem;color:var(--muted)}
.surface-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.hero-surface{padding:18px;border-radius:24px;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.78);box-shadow:var(--shadow-sm)}
.info-panel{padding:18px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,#fff,#fff9fa)}
.info-step{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:12px;background:#fff1f4;border:1px solid #f3d1d1;color:var(--maroon);font-weight:800;margin-bottom:10px}
.news-grid,.program-chip-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.news-card,.feature-card,.program-chip{padding:18px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,#fff,#fff9fa);box-shadow:var(--shadow-sm)}
.news-card-top,.news-foot,.feature-card{display:flex;gap:12px;align-items:flex-start}
.news-icon,.feature-icon{width:42px;height:42px;border-radius:14px;background:#fff1f4;border:1px solid #f3d1d1;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.news-meta-block{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.program-chip-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.program-chip-code{display:block;font-size:1.15rem;font-weight:800;color:var(--maroon)}
.program-chip-copy{font-size:.83rem;color:var(--muted)}
@media (max-width:1200px){.landing-media-grid,.news-grid,.program-chip-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:980px){.landing-hero-grid,.landing-media-admin-item{grid-template-columns:1fr}}
@media (max-width:760px){.landing-media-grid,.news-grid,.program-chip-grid,.feature-band,.grid-3{grid-template-columns:1fr}.landing-copy .hero-title{max-width:none}}

.public-brand{gap:16px;min-width:0}
.public-logo{width:56px;height:56px;border-radius:18px;font-size:1.25rem;overflow:hidden}
.public-logo--image{padding:6px;background:#fff}
.public-logo--image img{width:100%;height:100%;object-fit:contain;display:block;border-radius:12px;background:#fff}
.public-topbar .brand-mark{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.public-topbar .brand-title{font-size:1.55rem;line-height:1.08;white-space:normal;overflow:visible;text-overflow:clip}
.public-topbar .brand-sub{font-size:.96rem;line-height:1.25;white-space:normal;overflow:visible;text-overflow:clip;max-width:58ch}
.landing-header-preview{display:grid;gap:12px}
.landing-header-preview-card{padding:16px 18px;border-radius:22px;background:linear-gradient(135deg,rgba(163,8,8,.97),rgba(201,10,10,.96));border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-md);color:#fff;overflow:hidden}
.brand--preview{align-items:center;gap:14px}
.brand--preview .brand-mark,.brand--preview .brand-title,.brand--preview .brand-sub{color:#fff;white-space:normal;overflow:visible;text-overflow:clip}
.brand--preview .brand-title{font-size:1.35rem;line-height:1.1}
.brand--preview .brand-sub{font-size:.94rem;opacity:.88}
.checkbox-row{display:inline-flex;align-items:center;gap:10px;color:#5e5259;font-size:.94rem}
.checkbox-row input{width:18px;height:18px}

@media (max-width:980px){
  .public-topbar-inner{align-items:flex-start}
  .public-topbar .brand-title{font-size:1.28rem}
}

@media (max-width:760px){
  .public-topbar{padding:10px 0}
  .public-topbar-inner{gap:12px}
  .public-brand{align-items:flex-start}
  .public-logo{width:52px;height:52px;border-radius:16px}
  .public-topbar .brand-mark{font-size:.7rem;letter-spacing:.16em}
  .public-topbar .brand-title{font-size:1.08rem}
  .public-topbar .brand-sub{font-size:.84rem}
}

.profile-doc-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.profile-doc-card{padding:16px;border:1px solid rgba(201,10,10,.08);border-radius:18px;background:#fff;box-shadow:0 8px 22px rgba(27,18,25,.04)}
@media (max-width: 980px){.profile-doc-grid{grid-template-columns:1fr}}


.public-footer-modern{margin-top:34px;padding:26px 0 16px;background:linear-gradient(180deg,#5f1422 0%,#48101c 100%);border-top:1px solid rgba(255,255,255,.08);color:#fdf3f5}
.public-footer-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(240px,.9fr) minmax(240px,1fr);gap:14px;align-items:stretch}
.public-footer-brand-card,.public-footer-links-card,.public-footer-note-card{background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:20px;box-shadow:var(--shadow-sm);backdrop-filter:blur(6px)}
.public-footer-title{font-size:1.28rem;font-weight:800;letter-spacing:-.01em;margin-top:4px}
.public-footer-tagline{margin:10px 0 0;color:rgba(253,243,245,.84);line-height:1.7}
.public-footer-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.public-footer-modern .badge{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.16)}
.public-footer-links{display:grid;gap:10px;margin-top:12px}
.public-footer-links a{display:block;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.08);color:#fff;text-decoration:none;font-weight:600;border:1px solid transparent;transition:all .18s ease}
.public-footer-links a:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.16);transform:translateY(-1px)}
.public-footer-modern .card-title,.public-footer-modern .eyebrow{color:#fff}
.public-footer-bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:14px;margin-top:14px;border-top:1px solid rgba(255,255,255,.08);color:rgba(253,243,245,.78);font-size:.92rem}
@media (max-width:960px){.public-footer-grid{grid-template-columns:1fr}.public-footer-bottom{flex-direction:column}}


.auth-shell--premium{padding:42px 0 60px}
.auth-grid--premium{grid-template-columns:minmax(0,1.12fr) minmax(420px,.88fr);gap:28px;align-items:stretch}
.auth-panel--premium{position:relative;padding:34px;border-radius:34px;background:linear-gradient(145deg,#c90a0a 0%,#b50707 38%,#d81a1a 70%,#ef4444 100%);border:1px solid rgba(255,255,255,.18);box-shadow:0 30px 80px rgba(163,8,8,.32);overflow:hidden;isolation:isolate}
.auth-panel--premium::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,255,255,.22),transparent 28%),radial-gradient(circle at bottom left,rgba(255,255,255,.12),transparent 24%);pointer-events:none}
.auth-orb{position:absolute;border-radius:999px;filter:blur(8px);opacity:.8;pointer-events:none}
.auth-orb--one{width:220px;height:220px;right:-70px;top:-60px;background:radial-gradient(circle,rgba(255,255,255,.26),rgba(255,255,255,0) 70%)}
.auth-orb--two{width:180px;height:180px;left:-40px;bottom:-50px;background:radial-gradient(circle,rgba(255,255,255,.16),rgba(255,255,255,0) 70%)}
.auth-premium-kicker{position:relative;z-index:1;display:inline-flex;align-items:center;padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.18);font-size:.78rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}
.auth-premium-title{position:relative;z-index:1;margin-top:18px;max-width:12ch;font-size:clamp(2.2rem,1.7rem + 2vw,4.2rem);line-height:.98;font-weight:900;letter-spacing:-.04em}
.auth-premium-copy{position:relative;z-index:1;max-width:58ch;margin-top:14px;color:rgba(255,255,255,.88);font-size:1.04rem;line-height:1.7}
.auth-feature-grid--premium{position:relative;z-index:1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:28px}
.auth-feature--premium{padding:18px;border-radius:24px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(8px);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.auth-feature--premium strong{display:block;font-size:1.05rem;margin-bottom:6px}
.auth-feature--premium div{color:rgba(255,255,255,.84);line-height:1.6}
.auth-premium-metrics{position:relative;z-index:1;display:flex;gap:22px;flex-wrap:wrap;margin-top:28px;padding-top:22px;border-top:1px solid rgba(255,255,255,.16)}
.auth-metric{display:flex;flex-direction:column;gap:2px}
.auth-metric strong{font-size:1.08rem;font-weight:900}
.auth-metric span{font-size:.88rem;color:rgba(255,255,255,.82)}
.auth-card--premium{position:relative;padding:30px;border-radius:34px;background:rgba(255,255,255,.84);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.72);box-shadow:0 34px 80px rgba(15,23,42,.14);overflow:hidden;isolation:isolate}
.auth-card-glow{position:absolute;border-radius:999px;filter:blur(28px);pointer-events:none;opacity:.6}
.auth-card-glow--one{width:160px;height:160px;right:-30px;top:-24px;background:rgba(254,202,202,.95)}
.auth-card-glow--two{width:150px;height:150px;left:-40px;bottom:-40px;background:rgba(254,226,226,.95)}
.auth-form-head--premium{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}
.auth-form-head--premium h2{font-size:clamp(2rem,1.55rem + 1vw,3rem);margin:8px 0 6px;font-weight:900;letter-spacing:-.04em}
.auth-status-pill{display:inline-flex;align-items:center;padding:10px 14px;border-radius:16px;background:#ecfdf5;border:1px solid #d1fae5;color:#047857;font-size:.8rem;font-weight:800;white-space:nowrap}
.auth-form--premium{position:relative;z-index:1;display:flex;flex-direction:column;gap:16px}
.field-stack{display:flex;flex-direction:column;gap:8px}
.label-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.input-premium{height:58px;border-radius:20px;border:1px solid #e7dce0;background:rgba(255,255,255,.9);box-shadow:inset 0 1px 0 rgba(255,255,255,.65);font-size:1rem;padding:0 18px;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}
.input-premium:focus{border-color:#e05c5c;background:#fff;box-shadow:0 0 0 5px rgba(201,10,10,.10)}
.password-wrap{position:relative}
.password-wrap .input-premium{padding-right:92px}
.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:#f8fafc;color:#475569;padding:9px 12px;border-radius:14px;font-weight:700;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}
.password-toggle:hover{background:#eef2f7;color:#0f172a;transform:translateY(-50%) scale(1.02)}
.auth-row--premium{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.remember-check{display:flex;align-items:center;gap:10px;color:#5f5960;font-size:.95rem}
.remember-check input{accent-color:var(--maroon)}
.auth-live-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#f8fafc;border:1px solid var(--border);font-size:.8rem;font-weight:700;color:#5b6475}
.auth-live-pill span{width:8px;height:8px;border-radius:999px;background:#22c55e;display:inline-block;box-shadow:0 0 0 4px rgba(34,197,94,.12)}
.btn-premium{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:58px;border:none;border-radius:20px;font-size:1.02rem;letter-spacing:-.01em;box-shadow:0 18px 36px rgba(163,8,8,.24)}
.btn-premium:hover{transform:translateY(-1px)}
.btn-premium.is-loading,.btn-premium:disabled{opacity:.82;cursor:not-allowed;transform:none}
.auth-form-foot--premium{position:relative;z-index:1;margin-top:22px;padding-top:22px;border-top:1px solid rgba(201,10,10,.08)}
.auth-mini-grid--premium{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:12px}
.mini-stat--premium{border-radius:22px;background:rgba(255,255,255,.72);border:1px solid var(--border);padding:16px}
.auth-trust-line{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:16px;color:#6b6570;font-size:.9rem}
@media (max-width:1100px){.auth-grid--premium{grid-template-columns:1fr}.auth-premium-title{max-width:18ch}}
@media (max-width:760px){.auth-shell--premium{padding:24px 0 42px}.auth-panel--premium,.auth-card--premium{padding:22px;border-radius:26px}.auth-feature-grid--premium,.auth-mini-grid--premium{grid-template-columns:1fr}.auth-premium-title{font-size:clamp(1.8rem,1.3rem + 2vw,2.6rem)}.auth-form-head--premium{flex-direction:column}.auth-status-pill{white-space:normal}.auth-trust-line span:nth-child(even){display:none}}

.btn-message-link{position:relative;padding-right:40px}.message-badge{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#dc2626;color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(220,38,38,.35)}


.notification-wrap{position:relative}
.notification-btn{position:relative;width:46px;height:46px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.12);color:#fff;border-radius:14px;cursor:pointer;transition:.2s ease;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(80,7,17,.18)}
.notification-btn:hover,.topbar-profile-trigger:hover{background:rgba(255,255,255,.18)}
.notification-bell{font-size:18px;line-height:1}
.notification-badge{position:absolute;top:5px;right:5px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#fff;color:var(--maroon);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(34,12,18,.18)}
.notification-dropdown,.topbar-profile-dropdown{position:absolute;top:56px;right:0;width:280px;background:#fff;border-radius:18px;box-shadow:0 20px 45px rgba(31,11,16,.14);border:1px solid rgba(201,10,10,.08);opacity:0;transform:translateY(-8px);pointer-events:none;transition:.18s ease;overflow:hidden;z-index:2200}
.notification-dropdown.show,.topbar-profile-dropdown.show{opacity:1;transform:translateY(0);pointer-events:auto}
.notification-header{padding:14px 16px;font-weight:800;color:#261f26;border-bottom:1px solid #f2e8ea;background:linear-gradient(180deg,#fff,#fff7f8)}
.notification-item{display:block;padding:12px 16px;color:#2f2730;border-bottom:1px solid #f7eff1}
.notification-item:hover{background:#fff7f8;color:#2f2730}
.notification-item strong{display:block;font-size:14px;margin-bottom:4px}
.notification-item span{display:block;font-size:12px;line-height:1.4;color:#756c74}
.notification-footer{padding:12px 16px;text-align:center;background:#fffafb}
.notification-footer a{font-weight:700}
.topbar-profile{position:relative}
.topbar-profile-trigger{display:flex;align-items:center;gap:10px;padding:8px 12px;border:none;border-radius:16px;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;min-width:220px;max-width:100%;box-shadow:0 8px 18px rgba(80,7,17,.18);transition:.2s ease;text-align:left}
.topbar-profile-avatar{width:40px;height:40px;border-radius:14px;background:linear-gradient(145deg,#fff,#ffe7e7);color:var(--maroon);display:inline-flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}
.topbar-profile-copy{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.topbar-profile-copy strong{font-size:14px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-profile-copy span{font-size:12px;color:rgba(255,255,255,.76);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-profile-arrow{margin-left:auto;font-size:11px;color:rgba(255,255,255,.8)}
.topbar-profile-dropdown a,.topbar-profile-logout{display:block;width:100%;padding:12px 16px;background:#fff;border:none;text-align:left;font:inherit;font-size:14px;color:#2f2730;cursor:pointer}
.topbar-profile-dropdown a:hover,.topbar-profile-logout:hover{background:#fff7f8;color:#2f2730}
.topbar-profile-dropdown .divider{height:1px;background:#f1e4e7;margin:4px 0}
.topbar-profile-logout{color:var(--maroon);font-weight:700}
.topbar-profile-logout-form{margin:0}
.side-profile-card{cursor:default}


/* Premium workspace refresh */
.topbar-inline-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);color:#fff;font-size:12px;font-weight:700;box-shadow:0 8px 18px rgba(80,7,17,.18)}
.topbar-inline-chip-dot{width:8px;height:8px;border-radius:999px;background:#7dd3fc;box-shadow:0 0 0 4px rgba(125,211,252,.18)}
.topbar-actions > *{flex-shrink:0}
.side-workspace-card{padding:16px;border-radius:22px;background:linear-gradient(160deg,#fffafc 0%,#fff 52%,#fff8f9 100%);border:1px solid rgba(201,10,10,.1);box-shadow:0 14px 28px rgba(35,13,19,.06);margin-bottom:18px}
.side-workspace-head{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}
.side-workspace-copy{min-width:0}
.side-workspace-title{font-weight:800;color:#241b23;letter-spacing:.01em}
.side-workspace-sub{font-size:12px;line-height:1.45;color:#7b7279;margin-top:3px}
.side-status-dot{width:10px;height:10px;border-radius:999px;background:#10b981;box-shadow:0 0 0 6px rgba(16,185,129,.12)}
.side-chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.side-chip{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;background:#fff;border:1px solid #f0dee3;color:#695f66;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.side-chip--solid{background:linear-gradient(135deg,var(--maroon),var(--maroon-dark));color:#fff;border-color:transparent;box-shadow:0 10px 20px rgba(163,8,8,.18)}
.side-group{gap:8px}
.side-link{display:flex;align-items:center;gap:12px;padding:12px 13px;border-radius:16px;color:#2f2730;border:1px solid transparent;font-weight:600;position:relative;z-index:2}
.side-link-text{min-width:0;flex:1}
.side-link-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:#fff2f3;color:var(--maroon);font-size:11px;font-weight:800;border:1px solid rgba(163,8,8,.12);box-shadow:0 6px 14px rgba(163,8,8,.08)}
.side-link.active .side-link-badge{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.2);color:#fff;box-shadow:none}
.notification-item{position:relative;display:block;padding:13px 16px;color:#2f2730;border-bottom:1px solid #f7eff1}
.notification-item--featured{background:linear-gradient(180deg,#fffdfd,#fff8f9)}
.notification-inline-badge{display:inline-flex;align-items:center;justify-content:center;margin-top:8px;padding:6px 10px;border-radius:999px;background:#fff1f2;border:1px solid rgba(163,8,8,.12);color:var(--maroon);font-style:normal;font-size:11px;font-weight:800}
.topbar-profile-dropdown{width:300px}
.topbar-profile-panel{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid #f2e7ea;background:linear-gradient(180deg,#fff,#fff8f9)}
.topbar-profile-panel-avatar{width:46px;height:46px;border-radius:16px;background:linear-gradient(145deg,var(--maroon),var(--maroon-dark));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;box-shadow:0 12px 24px rgba(92,8,25,.16)}
.topbar-profile-panel-copy{display:flex;flex-direction:column;min-width:0}
.topbar-profile-panel-copy strong{font-size:14px;color:#281f27;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-profile-panel-copy span{font-size:12px;color:#7b7279}
.topbar-profile-dropdown a,.topbar-profile-logout{padding:13px 16px}
.topbar-profile-logout{background:#fffafb}
.btn-message-link,.message-badge{display:none}
@media (max-width:980px){
  .topbar-inline-chip{display:none}
  .topbar-actions .topbar-profile,.topbar-actions .notification-wrap{flex:1 1 auto}
}
@media (max-width:760px){
  .topbar-actions{gap:8px;justify-content:flex-start}
  .topbar-actions .topbar-profile,.topbar-actions .notification-wrap{flex:1 1 calc(50% - 4px)}
}

.premium-profile-header{gap:16px;flex-wrap:wrap}
.profile-stack{display:grid;gap:16px}
.premium-profile-hero{grid-template-columns:170px 1fr;background:linear-gradient(180deg,#fff,#fffafb)}
.premium-profile-stat-row{grid-template-columns:repeat(6,minmax(0,1fr));margin-top:16px}
.profile-workspace-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.profile-section-card{background:linear-gradient(180deg,#fff,#fffdfd);border:1px solid rgba(201,10,10,.08);box-shadow:0 14px 32px rgba(31,11,16,.05)}
.section-header-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px;flex-wrap:wrap}
.profile-section-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:#fff4f5;color:var(--maroon);font-size:12px;font-weight:800;border:1px solid rgba(201,10,10,.10)}
.profile-section-chip-locked{background:#f7f7f8;color:#5d5660;border-color:#ece8ed}
.profile-edit-form{display:grid;gap:12px}
.profile-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.profile-form-grid .full-span{grid-column:1/-1}
.textarea{width:100%;border:1px solid var(--border);border-radius:16px;padding:12px 14px;background:#fff;min-height:108px;resize:vertical;font:inherit;outline:none;transition:border-color .18s ease, box-shadow .18s ease}
.textarea:focus{border-color:rgba(122,12,34,.35);box-shadow:0 0 0 4px rgba(201,10,10,.08)}
.profile-form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.profile-lock-card{padding:16px;border:1px dashed rgba(122,12,34,.16);border-radius:18px;background:#fff8f9;color:#5d5660}
.profile-locked-grid>div{background:#fcfcfd}
@media (max-width: 1180px){.premium-profile-stat-row{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width: 980px){.profile-workspace-grid,.profile-form-grid{grid-template-columns:1fr}.premium-profile-stat-row{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 640px){.premium-profile-stat-row{grid-template-columns:1fr}.section-header-row{align-items:stretch}}
.profile-request-list{display:grid;gap:12px;margin-top:14px}
.profile-request-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border:1px solid rgba(122,12,34,.08);border-radius:16px;background:#fff}
.request-status{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.request-status-pending{background:rgba(217,119,6,.12);color:#b45309}
.request-status-approved{background:rgba(22,163,74,.12);color:#15803d}
.request-status-rejected{background:rgba(220,38,38,.12);color:#b91c1c}

@media (max-width:640px){
  .announcement-gallery{gap:10px}
  .announcement-image-link{width:min(140px,calc(50% - 5px));min-width:0}
  .announcement-gallery--single .announcement-image-link{width:min(180px,100%)}
}


.announcement-stats-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.mini-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:#fff6f6;border:1px solid #f1d7d7;color:#7d4b55;font-size:12px;font-weight:700}
.notification-item--highlight{background:#fff3f3;border-color:#f0c5c5}


.announcement-title-btn{
  appearance:none;
  border:0;
  background:none;
  padding:0;
  margin:0;
  font:inherit;
  color:inherit;
  text-align:left;
  cursor:pointer;
}
.announcement-title-btn:hover{
  text-decoration:underline;
}


.landing-home-redesign{gap:26px}
.landing-hero--clean{padding-bottom:10px}
.landing-hero-grid--clean{grid-template-columns:minmax(0,1.12fr) minmax(320px,.88fr);align-items:stretch}
.landing-copy--clean .hero-title,.landing-title-wide{max-width:18ch}
.hero-actions--compact{flex-wrap:wrap}
.landing-value-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}
.landing-value-card{display:flex;gap:12px;align-items:flex-start;padding:16px 18px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,#fff,#fff9fa);box-shadow:var(--shadow-sm)}
.landing-value-icon,.landing-link-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#fff1f4;border:1px solid #f3d1d1;font-size:20px;flex-shrink:0}
.landing-hero-panel--clean{display:grid;gap:16px}
.landing-showcase-card--hero{height:100%}

.landing-showcase-card--placeholder{min-height:280px;display:grid;align-content:center}
.landing-showcase-placeholder{min-height:170px;border:1px dashed #e6b8c2;border-radius:22px;background:linear-gradient(135deg,#fff7f8,#fff);display:flex;align-items:center;justify-content:center}
.landing-showcase-placeholder span{font-size:58px;filter:drop-shadow(0 10px 20px rgba(122,24,24,.12))}
.landing-quick-panel{padding:18px;border-radius:24px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow-sm)}
.landing-link-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.landing-link-card{display:flex;gap:12px;align-items:center;padding:14px 15px;border:1px solid var(--border);border-radius:18px;background:#fff;color:inherit;text-decoration:none;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.landing-link-card strong{display:block;font-size:.96rem}
.landing-link-card small{display:block;color:var(--muted);font-size:.8rem}
.landing-link-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:#e6b8c2}
.feature-band--clean{margin-top:-4px}
.landing-focus-card{overflow:hidden}
.landing-focus-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.news-grid--featured{grid-template-columns:repeat(3,minmax(0,1fr))}
.program-chip-grid--landing{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:1200px){.landing-value-grid,.landing-focus-grid,.news-grid--featured,.program-chip-grid--landing{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:980px){.landing-hero-grid--clean{grid-template-columns:1fr}.landing-title-wide{max-width:none}}
@media (max-width:760px){.landing-value-grid,.landing-link-grid,.landing-focus-grid,.news-grid--featured,.program-chip-grid--landing{grid-template-columns:1fr}}
/* Global search UX */
.global-search-wrap{position:relative;min-width:260px;max-width:420px;flex:1 1 320px;margin-left:18px}
.global-search-input{width:100%;border:1px solid rgba(255,255,255,.38);background:rgba(255,255,255,.16);color:#fff;border-radius:999px;padding:11px 16px;font-weight:700;outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.global-search-input::placeholder{color:rgba(255,255,255,.8);font-weight:600}
.global-search-input:focus{background:#fff;color:#1f1720;border-color:#fff;box-shadow:0 10px 26px rgba(0,0,0,.16)}
.global-search-input:focus::placeholder{color:#8d6b6b}
.global-search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;color:#241b1b;border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:18px;padding:8px;z-index:100;max-height:380px;overflow:auto}
.global-search-item{display:block;width:100%;text-align:left;border:0;background:transparent;padding:10px 12px;border-radius:14px;cursor:pointer;color:inherit;text-decoration:none}
.global-search-item:hover,.global-search-item.active{background:#fff1f1}
.global-search-type{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;background:#f4eeee;color:#9f1a1a;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-right:6px}
.global-search-title{font-weight:800}.global-search-subtitle{font-size:12px;color:#7a6d6d;margin-top:2px}.global-search-empty{padding:12px;color:#7a6d6d}
@media (max-width:980px){.global-search-wrap{order:10;flex:1 1 100%;max-width:none;margin:10px 0 0}.topbar-inner{flex-wrap:wrap}}

/* Dashboard premium refresh */
.dashboard-hero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:18px;align-items:stretch;margin-bottom:18px;padding:26px;border-radius:30px;background:linear-gradient(135deg,rgba(122,12,34,.98),rgba(201,10,10,.95));color:#fff;box-shadow:var(--shadow-lg)}
.dashboard-hero::before{content:"";position:absolute;inset:auto -90px -120px auto;width:280px;height:280px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 68%)}
.dashboard-hero::after{content:"";position:absolute;inset:-80px auto auto 42%;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.13),transparent 70%)}
.dashboard-hero > *{position:relative;z-index:1}.dashboard-hero .eyebrow,.dashboard-hero .muted{color:rgba(255,255,255,.78)}
.dashboard-hero h1{font-size:clamp(2rem,1.25rem + 2.2vw,3.6rem);max-width:720px;color:#fff;margin:8px 0 10px}.dashboard-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.dashboard-hero-actions .btn-outline{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.24);color:#fff}.dashboard-hero-actions .btn-outline:hover{background:rgba(255,255,255,.18)}
.dashboard-hero-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.hero-mini-stat{padding:18px;border-radius:22px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.10)}.hero-mini-stat span{display:block;font-size:2rem;font-weight:900;letter-spacing:-.04em}.hero-mini-stat small{display:block;margin-top:4px;color:rgba(255,255,255,.72);font-weight:700}
.kpi-grid--dashboard{margin-top:0}.stat-card--interactive{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.stat-card--interactive:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#f0c9c9}.stat-topline{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.stat-icon{width:42px;height:42px;border-radius:16px;background:#fff0f0;border:1px solid #f3d1d1;display:flex;align-items:center;justify-content:center;font-size:20px}.stat-pulse{width:10px;height:10px;border-radius:999px;background:var(--maroon);box-shadow:0 0 0 6px rgba(201,10,10,.10)}
.dashboard-layout--primary{grid-template-columns:minmax(0,1fr) minmax(300px,.72fr)}.dashboard-focus-card{background:linear-gradient(160deg,#fff,#fff8f9)}.stack--compact{gap:10px}.metric-list--rich .metric-row strong{font-size:1.05rem;color:var(--maroon)}
.quick-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.quick-action{padding:14px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#fffafa);display:flex;align-items:center;gap:10px;color:#2f2730;font-weight:800}.quick-action:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);color:var(--maroon);border-color:#f0c9c9}.quick-action span{width:38px;height:38px;border-radius:14px;background:#fff0f0;border:1px solid #f3d1d1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.feed-stack--timeline .feed-item{position:relative;transition:transform .18s ease,box-shadow .18s ease}.feed-stack--timeline .feed-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.dashboard-card--wide{margin-top:16px}.notification-pill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.notification-pill{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 14px;border-radius:16px;background:#fffdfd;border:1px solid var(--border)}.notification-pill span{font-weight:700;color:#5f535b}.notification-pill strong{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:30px;padding:0 10px;border-radius:999px;background:#fff0f0;color:var(--maroon)}
@media (max-width:1100px){.dashboard-hero,.dashboard-layout--primary{grid-template-columns:1fr}.dashboard-hero-panel{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:760px){.dashboard-hero{padding:20px;border-radius:24px}.dashboard-hero-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-action-grid{grid-template-columns:1fr}.dashboard-hero-actions .btn{width:100%}}
