/* ================================================================
   DTTASA STAFF NEWS BOARD — Obsidian Command Aesthetic
   ================================================================ */
:root {
  --void:#0c1109; --deep:#111a0e; --base:#172213; --lift:#1e2e1b;
  --panel:rgba(255,255,255,0.07); --panel2:rgba(255,255,255,0.13);
  --border:rgba(255,255,255,0.08); --bord2:rgba(255,255,255,0.18);
  --gold:#f0c832; --gold2:#f7d94e;
  --gdim:rgba(212,175,55,0.12); --gglow:rgba(212,175,55,0.3);
  --green:#4cd657; --gndim:rgba(67,177,75,0.12);
  --red:#ff4848; --rdim:rgba(232,64,64,0.15);
  --amber:#f59e0b; --adim:rgba(245,158,11,0.12);
  --blue:#4a9eff;
  --text:#f2f7ee; --t2:rgba(242,247,238,0.88); --t3:rgba(242,247,238,0.55);
  --mono:'IBM Plex Mono',monospace;
  --disp:'Cinzel',serif;
  --body:'DM Sans',sans-serif;
  --hd:70px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  width:100%;min-height:100vh;
  background:var(--void);color:var(--text);
  font-family:var(--body);-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 900px 600px at 50% -80px,rgba(15,80,30,0.28),transparent),
    radial-gradient(ellipse at 85% 95%,rgba(212,175,55,0.03),transparent 55%),
    repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.022) 2px,rgba(0,0,0,0.022) 4px);
}

/* ================================================================
   AUTH OVERLAY
   ================================================================ */
#auth-overlay{
  position:fixed;inset:0;z-index:99999;
  background:var(--void);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
}
#auth-overlay.hide{opacity:0;pointer-events:none;transition:opacity .4s cubic-bezier(.16,1,.3,1);}
.auth-spin{
  width:44px;height:44px;border-radius:50%;
  border:2px solid rgba(240,200,50,0.15);border-top-color:var(--gold);
  animation:spin .8s linear infinite;
}
.auth-label{font-family:var(--mono);font-size:11px;color:var(--t3);letter-spacing:2px;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ================================================================
   HEADER
   ================================================================ */
#hdr{
  position:fixed;top:0;left:0;right:0;height:var(--hd);z-index:5000;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;
  background:rgba(4,8,4,.78);border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(36px) saturate(160%);-webkit-backdrop-filter:blur(36px) saturate(160%);
  animation:hdrDrop .6s cubic-bezier(.16,1,.3,1) both;
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.05),0 4px 24px rgba(0,0,0,.3);
}
@keyframes hdrDrop{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
#hdr::after{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(212,175,55,.04) 50%,transparent 100%);background-size:250% 100%;animation:hdrScan 7s linear infinite;}
@keyframes hdrScan{from{background-position:250% 0;}to{background-position:-250% 0;}}
.hdr-left{display:flex;align-items:center;gap:14px;}
.hdr-logo{
  font-family:var(--disp);font-size:18px;font-weight:900;letter-spacing:6px;
  background:linear-gradient(135deg,var(--green),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hdr-divider{width:1px;height:28px;background:var(--border);}
.hdr-page{
  font-family:var(--disp);font-size:11px;letter-spacing:3px;
  color:var(--t3);text-transform:uppercase;
}
.hdr-live{
  display:flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size: 11px;color:var(--green);letter-spacing:1.5px;
}
.live-dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);
  animation:livePulse 2s cubic-bezier(.16,1,.3,1) infinite;
}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(76,214,87,0.4);}50%{box-shadow:0 0 0 5px rgba(76,214,87,0);}}
.hdr-right{display:flex;align-items:center;gap:14px;}
.hdr-user{display:flex;align-items:center;gap:10px;}
.hdr-avatar{
  width:34px;height:34px;border-radius:50%;overflow:hidden;
  background:var(--gdim);border:1px solid rgba(240,200,50,0.3);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;color:var(--gold);
  font-family:var(--disp);
}
.hdr-name{font-size:12px;font-weight:600;color:var(--t2);}
.hdr-btn{
  width:36px;height:36px;border-radius:10px;
  background:var(--panel);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--t3);font-size:13px;
  transition:all .2s;
}
.hdr-btn:hover{background:var(--panel2);border-color:var(--bord2);color:var(--text);}
#hub-link{
  display:flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:10px;
  background:var(--gdim);border:1px solid rgba(240,200,50,0.25);
  color:var(--gold);font-size:11px;font-weight:700;letter-spacing:.8px;
  cursor:pointer;text-decoration:none;transition:all .2s;
}
#hub-link:hover{background:rgba(240,200,50,0.18);}
#hub-link i{font-size: 11px;}

/* ================================================================
   PAGE WRAP
   ================================================================ */
#page-wrap{
  padding-top:var(--hd);min-height:100vh;
  position:relative;z-index:1;
  opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1);
}
#page-wrap.revealed{opacity:1;}

/* ================================================================
   HERO
   ================================================================ */
#hero{
  padding:52px 28px 36px;max-width:960px;margin:0 auto;
  text-align:center;
}
.hero-eyebrow{
  font-family:var(--mono);font-size: 11px;letter-spacing:4px;
  color:var(--gold);opacity:.7;text-transform:uppercase;
  margin-bottom:16px;animation:fadeUp .6s cubic-bezier(.16,1,.3,1) .1s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.hero-title{
  font-family:var(--disp);font-size:clamp(26px,5vw,46px);font-weight:900;
  letter-spacing:6px;text-transform:uppercase;
  background:linear-gradient(135deg,var(--text) 0%,var(--gold) 50%,var(--green) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  min-height:1.2em;line-height:1.2;
  animation:fadeUp .6s cubic-bezier(.16,1,.3,1) .2s both;
}
.hero-cursor{
  display:inline-block;width:3px;background:var(--gold);
  animation:cursorBlink .9s step-end infinite;vertical-align:bottom;margin-left:3px;
}
@keyframes cursorBlink{0%,100%{opacity:1;}50%{opacity:0;}}
.hero-sub{
  font-size:13px;color:var(--t3);margin-top:14px;line-height:1.7;
  animation:fadeUp .6s cubic-bezier(.16,1,.3,1) .35s both;
}

/* ================================================================
   KPI STRIP
   ================================================================ */
#kpi-strip{
  max-width:960px;margin:0 auto 28px;padding:0 28px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  animation:fadeUp .5s cubic-bezier(.16,1,.3,1) .4s both;
}
.kpi-pill{
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:14px;padding:14px 16px;text-align:center;
  transition:border-color .3s,background .3s;
}
.kpi-pill.bump{animation:pillBump .4s cubic-bezier(.16,1,.3,1);}
@keyframes pillBump{0%,100%{transform:none;}40%{transform:scale(1.06);}}
.kpi-num{
  font-family:var(--mono);font-size:26px;font-weight:700;color:var(--gold);
  line-height:1;margin-bottom:5px;
}
.kpi-lbl{font-size: 11px;color:var(--t3);letter-spacing:1px;text-transform:uppercase;}

/* ================================================================
   EMERGENCY BANNER
   ================================================================ */
#emergency-banner{
  display:none;margin:0 auto 24px;max-width:960px;padding:0 28px;
}
#emergency-banner.show{display:block;animation:fadeUp .5s cubic-bezier(.16,1,.3,1) both;}
.emg-inner{
  background:linear-gradient(135deg,rgba(180,20,20,0.15),rgba(232,64,64,0.1));
  border:1px solid rgba(255,72,72,0.4);border-radius:16px;
  padding:18px 22px;position:relative;overflow:hidden;
}
.emg-inner::before{
  content:'';position:absolute;inset:0;border-radius:16px;pointer-events:none;
  animation:emgPulse 2s cubic-bezier(.16,1,.3,1) infinite;
}
@keyframes emgPulse{0%,100%{box-shadow:inset 0 0 0 0 rgba(255,72,72,0);}50%{box-shadow:inset 0 0 20px rgba(255,72,72,0.12);}}
.emg-top{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.emg-icon{
  width:32px;height:32px;border-radius:8px;flex-shrink:0;
  background:rgba(255,72,72,0.15);border:1px solid rgba(255,72,72,0.3);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--red);animation:emgIconPulse 1.5s cubic-bezier(.16,1,.3,1) infinite;
}
@keyframes emgIconPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.1);}}
.emg-label{
  font-family:var(--disp);font-size:11px;letter-spacing:3px;
  color:var(--red);text-transform:uppercase;font-weight:700;
}
.emg-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.4;}
.emg-body{font-size:12px;color:var(--t3);margin-top:6px;line-height:1.6;}
.emg-close{
  position:absolute;top:12px;right:14px;
  width:24px;height:24px;border-radius:6px;cursor:pointer;
  background:rgba(255,72,72,0.1);border:1px solid rgba(255,72,72,0.2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:var(--red);transition:all .15s;
}
.emg-close:hover{background:rgba(255,72,72,0.2);}

/* ================================================================
   PINNED STRIP
   ================================================================ */
#pinned-section{
  max-width:960px;margin:0 auto 28px;padding:0 28px;
}
.section-label{
  display:flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size: 11px;letter-spacing:2px;
  color:var(--gold);text-transform:uppercase;margin-bottom:12px;opacity:.8;
}
.section-label::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,rgba(240,200,50,0.25),transparent);
}
#pinned-scroll{
  display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;
  scrollbar-width:none;-ms-overflow-style:none;
}
#pinned-scroll::-webkit-scrollbar{display:none;}
.pinned-chip{
  flex-shrink:0;width:240px;
  background:rgba(240,200,50,0.05);
  border:1px solid rgba(240,200,50,0.2);border-radius:14px;
  padding:14px 16px;cursor:pointer;
  transition:border-color .2s,background .2s,transform .2s;
  position:relative;overflow:hidden;
}
.pinned-chip::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,200,50,0.6),transparent);
  animation:pinShimmer 2.5s cubic-bezier(.16,1,.3,1) infinite;
}
@keyframes pinShimmer{0%,100%{opacity:.3;}50%{opacity:1;}}
.pinned-chip:hover{border-color:rgba(240,200,50,0.4);background:rgba(240,200,50,0.09);transform:translateY(-2px);}
.pinned-chip-title{
  font-size:12px;font-weight:600;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin-bottom:8px;
}
.pinned-chip-meta{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size: 11px;color:var(--gold);letter-spacing:.5px;}

/* ================================================================
   SEARCH + FILTER BAR
   ================================================================ */
#filter-bar{
  max-width:960px;margin:0 auto 20px;padding:0 28px;
}
.filter-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px;}
.ann-search{
  flex:1;min-width:200px;
  background:rgba(255,255,255,0.05);border:1px solid var(--border);
  border-radius:10px;padding:9px 14px 9px 36px;
  color:var(--text);font-size:13px;font-family:var(--body);
  outline:none;transition:border-color .2s,box-shadow .2s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(242,247,238,0.3)' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-size:16px;background-position:12px center;
}
.ann-search:focus{border-color:rgba(240,200,50,0.35);box-shadow:0 0 0 3px rgba(240,200,50,0.08);}
.sort-select{
  padding:9px 12px;border-radius:10px;
  background:rgba(255,255,255,0.05);border:1px solid var(--border);
  color:var(--t2);font-size:12px;font-family:var(--body);
  outline:none;cursor:pointer;transition:border-color .2s;
}
.sort-select:focus{border-color:rgba(240,200,50,0.35);}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap;}
.fp{
  padding:5px 14px;border-radius:20px;
  border:1px solid var(--border);background:transparent;
  color:var(--t3);font-size:11px;font-weight:600;letter-spacing:.8px;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.fp:hover{color:var(--text);border-color:var(--bord2);}
.fp.active{background:var(--gdim);border-color:rgba(240,200,50,0.35);color:var(--gold);}
.fp.pri-urgent.active{background:rgba(255,72,72,0.1);border-color:rgba(255,72,72,0.35);color:var(--red);}

/* ================================================================
   ANNOUNCEMENT FEED
   ================================================================ */
#feed-wrap{max-width:960px;margin:0 auto;padding:0 28px 60px;}
#feed{display:flex;flex-direction:column;gap:12px;}

/* Card */
.ann-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);border-left:4px solid transparent;
  border-radius:16px;overflow:hidden;
  transition:border-color .25s,background .25s,box-shadow .25s,transform .25s cubic-bezier(.16,1,.3,1);
  backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07),0 8px 32px rgba(0,0,0,.3);
  animation:glassIn .65s cubic-bezier(.16,1,.3,1) both;
}
@keyframes glassIn{from{opacity:0;transform:translateY(20px) scale(.97);filter:blur(6px);}to{opacity:1;transform:none;filter:blur(0);}}
.ann-card:hover{background:rgba(255,255,255,0.065);border-color:rgba(255,255,255,0.13);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.3);}
.ann-card.new-card{animation:cardSlide .45s cubic-bezier(.16,1,.3,1) both;}
@keyframes cardSlide{from{opacity:0;transform:translateY(-14px);}to{opacity:1;transform:none;}}
.ann-card.pri-normal{border-left-color:rgba(76,214,87,0.5);}
.ann-card.pri-important{border-left-color:rgba(245,158,11,0.6);}
.ann-card.pri-urgent{border-left-color:rgba(255,72,72,0.7);}
.ann-card.pri-emergency{border-left-color:var(--red);background:rgba(232,64,64,0.05);}
.ann-card.pinned-card{background:rgba(240,200,50,0.03);}
.ann-card.pinned-card::before{
  content:'';display:block;height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,200,50,0.4),transparent);
  animation:pinShimmer 2.5s cubic-bezier(.16,1,.3,1) infinite;
}
.ann-card.is-read .ann-title{color:var(--t2);}
/* Card body */
.ann-card-inner{padding:18px 20px 16px;}
.ann-card-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;}
.ann-pri-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px;
}
.ann-title{
  flex:1;font-size:15px;font-weight:700;color:var(--text);
  line-height:1.4;word-break:break-word;
}
.ann-pinbadge{
  font-size: 11px;font-family:var(--mono);letter-spacing:.8px;
  color:var(--gold);background:var(--gdim);
  border:1px solid rgba(240,200,50,0.2);border-radius:4px;
  padding:2px 6px;flex-shrink:0;margin-top:2px;
}
/* Meta row */
.ann-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;}
.ann-tag{
  font-size: 11px;font-family:var(--mono);letter-spacing:.6px;
  padding:2px 8px;border-radius:4px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);color:var(--t3);
}
.ann-tag.cat{color:var(--blue);}
.ann-tag.pri-normal{color:var(--green);}
.ann-tag.pri-important{color:var(--amber);}
.ann-tag.pri-urgent,.ann-tag.pri-emergency{color:var(--red);}
.ann-time{font-size:11px;color:var(--t3);font-family:var(--mono);margin-left:auto;}
.ann-sender{font-size:11px;color:var(--t3);}
/* Body text */
.ann-body{
  font-size:13px;color:var(--t2);line-height:1.7;
  white-space:pre-line;margin-bottom:12px;
}
.ann-body.collapsed{
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.ann-expand{
  font-size:11px;font-family:var(--mono);color:var(--gold);
  cursor:pointer;letter-spacing:.5px;background:none;border:none;padding:0;
  margin-bottom:12px;transition:opacity .2s;
}
.ann-expand:hover{opacity:.7;}
/* Attachment */
.ann-attachment{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:10px;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  margin-bottom:12px;text-decoration:none;color:var(--t2);
  transition:border-color .2s,background .2s;font-size:12px;
}
.ann-attachment:hover{border-color:rgba(240,200,50,0.3);background:var(--gdim);color:var(--gold);}
.ann-attachment i{font-size:14px;color:var(--gold);}
/* Footer row */
.ann-footer{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding-top:10px;border-top:1px solid rgba(255,255,255,0.05);
}
.ann-read-status{
  display:flex;align-items:center;gap:5px;
  font-size: 11px;font-family:var(--mono);color:var(--t3);letter-spacing:.5px;
}
.ann-read-status.seen{color:var(--green);}
.ann-read-status i{font-size:11px;}
/* Ack button */
.ack-btn{
  display:flex;align-items:center;gap:6px;
  padding:7px 16px;border-radius:20px;
  border:1px solid rgba(245,158,11,0.35);
  background:var(--adim);color:var(--amber);
  font-size:11px;font-weight:700;letter-spacing:.8px;
  cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);
  position:relative;overflow:hidden;white-space:nowrap;
  font-family:var(--body);
}
.ack-btn:hover{background:rgba(245,158,11,0.2);border-color:rgba(245,158,11,0.5);}
.ack-btn.ack-loading{
  width:36px;padding:7px;border-radius:50%;
  justify-content:center;pointer-events:none;
}
.ack-btn.ack-loading .ack-label{display:none;}
.ack-btn.ack-loading::after{
  content:'';width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(245,158,11,0.3);border-top-color:var(--amber);
  animation:spin .6s linear infinite;
}
.ack-btn.ack-done{
  border-color:rgba(76,214,87,0.35);background:rgba(76,214,87,0.1);color:var(--green);
  pointer-events:none;
}
.ack-spacer{flex:1;}
.ann-new-badge{
  font-size: 11px;font-family:var(--mono);letter-spacing:1px;padding:2px 7px;
  border-radius:4px;background:rgba(76,214,87,0.12);
  border:1px solid rgba(76,214,87,0.25);color:var(--green);
  animation:newBadgePulse 2s cubic-bezier(.16,1,.3,1) 3;
}
@keyframes newBadgePulse{0%,100%{opacity:1;}50%{opacity:.4;}}

/* ================================================================
   EMPTY STATE
   ================================================================ */
#empty-state{
  display:none;text-align:center;padding:80px 20px;
}
#empty-state.show{display:block;}
.empty-envelope{
  width:80px;height:80px;margin:0 auto 24px;
  animation:envelopeFloat 3.5s cubic-bezier(.16,1,.3,1) infinite;
}
@keyframes envelopeFloat{
  0%,100%{transform:translateY(0) rotate(-2deg);}
  50%{transform:translateY(-14px) rotate(2deg);}
}
.empty-title{font-family:var(--disp);font-size:18px;letter-spacing:3px;color:var(--t3);margin-bottom:8px;}
.empty-sub{font-size:13px;color:var(--t3);opacity:.6;}

/* ================================================================
   ARCHIVE SECTION
   ================================================================ */
#archive-toggle-wrap{max-width:960px;margin:0 auto 16px;padding:0 28px;}
.archive-toggle-btn{
  width:100%;padding:12px;border-radius:12px;
  background:rgba(255,255,255,0.03);border:1px solid var(--border);
  color:var(--t3);font-size:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .2s;letter-spacing:.5px;
}
.archive-toggle-btn:hover{background:rgba(255,255,255,0.07);color:var(--text);}
.archive-toggle-btn .chevron{transition:transform .3s cubic-bezier(.16,1,.3,1);}
.archive-toggle-btn.open .chevron{transform:rotate(180deg);}
#archive-feed{
  max-width:960px;margin:0 auto;padding:0 28px 60px;
  display:none;
}
#archive-feed.show{display:flex;flex-direction:column;gap:12px;}
.archive-label-row{
  font-family:var(--mono);font-size: 11px;letter-spacing:2px;
  color:var(--t3);text-transform:uppercase;padding:6px 0;
  border-bottom:1px solid var(--border);margin-bottom:4px;
}

/* ================================================================
   TOAST
   ================================================================ */
#toast-wrap{
  position:fixed;bottom:24px;left:24px;z-index:999998;
  display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:12px;
  background:rgba(18,28,16,0.96);border:1px solid var(--border);
  font-size:12px;color:var(--t2);letter-spacing:.3px;
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);max-width:340px;
  animation:toastIn .35s cubic-bezier(.16,1,.3,1) both;
  pointer-events:all;
}
.toast.success{border-color:rgba(76,214,87,0.3);color:var(--green);}
.toast.error{border-color:rgba(255,72,72,0.3);color:var(--red);}
@keyframes toastIn{from{opacity:0;transform:translateX(-20px);}to{opacity:1;transform:none;}}
@keyframes toastOut{from{opacity:1;}to{opacity:0;transform:translateX(-20px);}}

/* ================================================================
   RESPONSIVE
   ================================================================ */

/* ── 860px ─────────────────────────────────────────────────────── */
@media(max-width:860px){
  #kpi-strip{grid-template-columns:repeat(2,1fr);}
  .hero-title{font-size:clamp(22px,4.5vw,38px);letter-spacing:4px;}
}

/* ── 700px: main mobile breakpoint ───────────────────────────── */
@media(max-width:700px){
  /* ─ Header ─ */
  #hdr{padding:0 14px;}
  .hdr-logo{font-size:16px;letter-spacing:4px;}
  .hdr-divider{display:none;}
  .hdr-page{display:none;}
  .hdr-name{display:none;}
  #hub-link span{display:none;}
  #hub-link{padding:6px 10px;}
  .back-dash-label{display:none;}

  /* ─ Hero ─ */
  #hero{padding:36px 16px 24px;}
  .hero-title{font-size:clamp(20px,7vw,30px);letter-spacing:3px;}
  .hero-sub{font-size:12px;}

  /* ─ KPI strip ─ */
  #kpi-strip{
    grid-template-columns:repeat(2,1fr);
    gap:8px;padding:0 16px;
  }
  .kpi-pill{padding:12px 10px;}
  .kpi-num{font-size:22px;}
  .kpi-lbl{font-size:9px;}

  /* ─ Emergency banner ─ */
  #emergency-banner{padding:0 16px;}
  .emg-inner{padding:14px 16px;}
  .emg-title{font-size:13px;}

  /* ─ Pinned strip ─ */
  #pinned-section{padding:0 16px;}
  .pinned-chip{width:200px;}
  .pinned-chip-title{font-size:11px;}

  /* ─ Filter bar ─ */
  #filter-bar{padding:0 16px;}
  .filter-row{flex-direction:column;align-items:stretch;}
  .ann-search{min-width:unset;width:100%;}
  .sort-select{width:100%;}
  .filter-pills{gap:5px;}
  .fp{font-size:10px;padding:5px 10px;}

  /* ─ Feed ─ */
  #feed-wrap{padding:0 16px 60px;}
  .ann-card-inner{padding:14px 14px 12px;}
  .ann-title{font-size:13px;}
  .ann-body{font-size:12px;}
  .ann-meta{gap:5px;}
  .ann-time{margin-left:0;width:100%;margin-top:2px;}
  .ann-footer{flex-wrap:wrap;gap:8px;}
  .ann-attachment{padding:9px 12px;font-size:11px;}

  /* ─ Archive ─ */
  #archive-toggle-wrap{padding:0 16px;}
  #archive-feed{padding:0 16px 60px;}

  /* ─ Empty state ─ */
  .empty-title{font-size:15px;letter-spacing:2px;}
}

/* ── 420px: very small phones ─────────────────────────────────── */
@media(max-width:420px){
  #kpi-strip{grid-template-columns:repeat(2,1fr);gap:6px;}
  .kpi-num{font-size:18px;}
  .kpi-pill{padding:10px 8px;}
  .hero-title{font-size:clamp(18px,6vw,26px);letter-spacing:2px;}
  .ann-card-inner{padding:12px 12px 10px;}
  .ann-title{font-size:12px;}
  .ann-tag{font-size:9px;padding:2px 6px;}
  .ack-btn{font-size:10px;padding:6px 12px;}
  .pinned-chip{width:180px;}
  #hero{padding:28px 14px 20px;}
  .hero-eyebrow{font-size:9px;letter-spacing:3px;}
}
/* ── LIGHT THEME ── */
[data-theme="light"]{--void:#ffffff;--deep:#f4f6f4;--base:#e8ede8;--lift:#dce4dc;--panel:rgba(4,80,30,0.05);--panel2:rgba(4,80,30,0.09);--border:rgba(4,80,30,0.16);--bord2:rgba(4,80,30,0.26);--gold:#04501e;--gold2:#065a23;--gdim:rgba(4,80,30,0.10);--gglow:rgba(4,80,30,0.22);--gsoft:rgba(4,80,30,0.04);--green:#43b14b;--gndim:rgba(67,177,75,0.12);--gnsoft:rgba(67,177,75,0.05);--red:#c42020;--rdim:rgba(196,32,32,0.10);--text:#000000;--t2:rgba(0,0,0,0.80);--t3:rgba(0,0,0,0.52);}
[data-theme="light"] body{background:#ffffff;}[data-theme="light"] body::before{display:none;}
[data-theme="light"] #hdr{background:rgba(255,255,255,0.96)!important;border-color:rgba(4,80,30,0.14)!important;}
[data-theme="light"] .ann-card,[data-theme="light"] .pinned-strip,[data-theme="light"] .filter-bar{background:rgba(255,255,255,0.88)!important;border-color:rgba(4,80,30,0.13)!important;}
[data-theme="light"] #hero{background:linear-gradient(160deg,#e8ede8 0%,#f4f6f4 100%)!important;}
[data-theme="light"] .btn-green{background:#43b14b;}
#test-mode-banner{display:none;position:fixed;top:0;left:0;right:0;height:36px;z-index:999999;background:linear-gradient(90deg,rgba(160,0,0,.97),rgba(220,40,40,.97));border-bottom:2px solid rgba(255,100,100,.5);align-items:center;justify-content:center;gap:12px;font-size: 11px;font-weight:900;letter-spacing:2px;color:#fff;text-transform:uppercase;-webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);}
#test-mode-banner.show{display:flex;animation:tmBIn .45s cubic-bezier(.16,1,.3,1) both;}
@keyframes tmBIn{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
.test-toggle-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.45);color:#fff;padding:4px 14px;border-radius:20px;cursor:pointer;font-size: 11px;font-weight:900;letter-spacing:1.5px;white-space:nowrap;transition:background .2s,transform .2s;}
.test-toggle-btn:hover{background:rgba(255,255,255,.32);transform:scale(1.05);}
#maint-banner{display:none;position:fixed;top:0;left:0;right:0;height:36px;z-index:999998;background:linear-gradient(90deg,rgba(180,120,0,.97),rgba(220,160,0,.97));border-bottom:2px solid rgba(255,200,50,.5);align-items:center;justify-content:center;gap:12px;font-size: 11px;font-weight:900;letter-spacing:2px;color:#fff;text-transform:uppercase;-webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);}
#maint-banner.show{display:flex;animation:tmBIn .45s cubic-bezier(.16,1,.3,1) both;}
.maint-toggle-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.45);color:#fff;padding:4px 14px;border-radius:20px;cursor:pointer;font-size: 11px;font-weight:900;letter-spacing:1.5px;white-space:nowrap;transition:background .2s,transform .2s;}
.maint-toggle-btn:hover{background:rgba(255,255,255,.32);transform:scale(1.05);}
#maint-overlay{display:none;position:fixed;inset:0;z-index:999997;background:rgba(5,9,5,.96);align-items:center;justify-content:center;flex-direction:column;gap:16px;color:#fff;text-align:center;padding:32px;}
#maint-overlay.show{display:flex;}
#maint-overlay i{font-size:48px;color:var(--gold);margin-bottom:8px;}
#maint-overlay h2{font-family:var(--disp);font-size:28px;letter-spacing:4px;margin:0;}
#maint-overlay p{color:rgba(255,255,255,.6);font-size:13px;max-width:440px;line-height:1.7;}

/* ── ANNOUNCEMENTS — extra mobile fixes ── */
@media(max-width:540px){
  .modal-box{max-width:calc(100vw - 20px)!important;padding:20px 14px!important;border-radius:14px;}
  .pinned-chip{width:100%;max-width:100%;justify-content:center;}
  .kpi-strip{grid-template-columns:repeat(2,1fr);}
  .ann-card-inner{padding:14px 12px;}
}
@media(max-width:400px){
  .kpi-strip{grid-template-columns:1fr;}
  .kpi-val{font-size:20px;}
  .hdr-left{gap:8px;}
}
/* ── Touch targets + table scroll ── */
@media(max-width:640px){
  .btn,.btn-green,.btn-gold,.btn-red,.btn-outline{min-height:44px;}
  .rota-scroll,.table-scroll,.dtbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
}
