/* static/css/ngy.css */

/* ---------- Theme tokens (GoldenCarePro palette) ---------- */
:root{
  /* Background gradient */
  --bg0:#162f2b;  /* deepest */
  --bg1:#1f3f3a;  /* dark teal */
  --bg2:#2f5f58;  /* primary teal */

  /* Surfaces */
  --card:rgba(0,0,0,.18);              /* glassy dark */
  --cardBorder:rgba(230,193,90,.18);   /* gold-tinted border */

  /* Text */
  --text:#f4f6f5;                       /* warm white */
  --muted:rgba(244,246,245,.72);

  /* Accents */
  --accent:#e6c15a;     /* gold */
  --accent2:#d7b24d;    /* deeper gold */
  --danger:#ff1744;
  --ok:#00e676;

  /* Effects / layout */
  --shadow:0 10px 25px rgba(0,0,0,.35);
  --radius:18px;
  --gap:14px;
  --max:1400px;
}

/* ---------- Base ---------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:Arial, sans-serif;
  background:
    radial-gradient(1200px 800px at 25% 0%,
      var(--bg2) 0%,
      var(--bg1) 55%,
      var(--bg0) 100%
    );
  background-attachment:fixed;
  color:var(--text);
}
a{ color:inherit; text-decoration:none; }
.container{
  max-width:var(--max);
  margin:0 auto;
  padding:28px;
}

/* ---------- Header ---------- */
.page-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
  flex-wrap:wrap;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
}
.brand img{
  height:54px;
  width:auto;
  display:block;
}
.page-title{
  font-size:2.1rem;
  font-weight:900;
  letter-spacing:.3px;
  margin:0;
}
.page-subtitle{
  margin:6px 0 0;
  color:var(--muted);
  font-size:1.05rem;
}
.header-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.badge{
  padding:10px 14px;
  border-radius:999px;
  font-weight:900;
  background:rgba(0,0,0,.18);
  border:1px solid var(--cardBorder);
}

/* ---------- Layout blocks ---------- */
.grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}
@media(max-width:1200px){ .grid{ grid-template-columns:repeat(2,1fr);} }
@media(max-width:780px){ .grid{ grid-template-columns:1fr;} }

/* ---------- Cards ---------- */
.card{
  background:var(--card);
  border:1px solid var(--cardBorder);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  backdrop-filter: blur(6px);
}
.card-title{
  margin:0 0 6px;
  font-size:1.45rem;
  font-weight:900;
}
.card-sub{
  margin:0 0 14px;
  color:var(--muted);
  font-size:1.05rem;
  line-height:1.35;
}

/* ---------- Buttons ---------- */
.btn{
  appearance:none;
  border:none;
  border-radius:16px;
  padding:14px 16px;
  font-size:1.05rem;
  font-weight:900;
  cursor:pointer;
  background:rgba(0,0,0,.18);
  color:var(--text);
  box-shadow:0 6px 16px rgba(0,0,0,.28);
  transition:transform .12s ease, filter .12s ease, background .12s ease;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  border:1px solid rgba(255,255,255,.10);
}
.btn:hover{ filter:brightness(1.08); transform:translateY(-1px); }
.btn:active{ transform:translateY(0px) scale(.99); }
.btn[disabled]{ opacity:.45; cursor:not-allowed; transform:none; }

/* Gold primary */
.btn-primary{
  background:linear-gradient(135deg, var(--accent2), var(--accent));
  color:#132722;
  border:1px solid rgba(230,193,90,.45);
}
.btn-primary:hover{ filter:brightness(1.06); }

/* Gold accent */
.btn-accent{
  background:rgba(230,193,90,.18);
  border:1px solid rgba(230,193,90,.45);
  color:var(--text);
}
.btn-accent:hover{ background:rgba(230,193,90,.24); filter:brightness(1.04); }

.btn-danger{ background:rgba(255,23,68,.18); border:1px solid rgba(255,23,68,.35); }
.btn-danger:hover{ filter:brightness(1.15); }

.btn-ok{ background:rgba(0,230,118,.16); border:1px solid rgba(0,230,118,.35); }

/* ---------- Inputs ---------- */
.input{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.20);
  color:var(--text);
  outline:none;
  font-size:1.02rem;
}
.input::placeholder{ color:rgba(244,246,245,.55); }
.input:focus{
  border-color:rgba(230,193,90,.45);
  box-shadow:0 0 0 3px rgba(230,193,90,.12);
}
.input::-webkit-calendar-picker-indicator{ filter: invert(1); opacity:.85; }

/* ---------- Tables ---------- */
.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0 10px;
}
.table th{
  text-align:left;
  color:rgba(244,246,245,.75);
  font-weight:900;
  padding:0 10px 8px;
  font-size:.95rem;
}
.table td{
  padding:12px 10px;
  background:rgba(0,0,0,.18);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.table tr td:first-child{
  border-left:1px solid rgba(255,255,255,.08);
  border-top-left-radius:14px;
  border-bottom-left-radius:14px;
}
.table tr td:last-child{
  border-right:1px solid rgba(255,255,255,.08);
  border-top-right-radius:14px;
  border-bottom-right-radius:14px;
}

/* ---------- Flash messages ---------- */
.flash-wrap{ margin:12px 0 18px; display:flex; flex-direction:column; gap:10px; }
.flash{
  border-radius:14px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  box-shadow:0 6px 16px rgba(0,0,0,.22);
}
.flash.success{ border-color:rgba(0,230,118,.35); background:rgba(0,230,118,.12); }
.flash.error{ border-color:rgba(255,23,68,.35); background:rgba(255,23,68,.12); }
.flash.info{ border-color:rgba(230,193,90,.35); background:rgba(230,193,90,.10); }

/* ---------- Utility ---------- */
.row{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.spacer{ height:16px; }
.small{ font-size:.95rem; color:var(--muted); }

/* =========================================================
   DASHBOARD: SECTION HEADERS + THEMES (buttons + borders)
   ========================================================= */

/* Full-row section headers */
.section-header{
  grid-column:1 / -1;
  margin-top:1.25rem;
  padding:0.75rem 1rem;

  display:flex;
  align-items:center;
  gap:0.6rem;

  font-size:1.1rem;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;

  background:rgba(0,0,0,.12);
  border-radius:14px;

  /* default accent */
  color:var(--accent);
  border-left:6px solid rgba(230,193,90,.65);
}

.section-header .section-icon{
  font-size:1.15rem;
  line-height:1;
  opacity:.95;
}

/* Per-section accent variables */
.section-menu        { --accent1:#ff9800; --accent2:#ffb74d; --btnText:#132722; }
.section-staff       { --accent1:#2196f3; --accent2:#64b5f6; --btnText:#0f1f1d; }
.section-events      { --accent1:#9c27b0; --accent2:#ba68c8; --btnText:#132722; }
.section-visitors    { --accent1:#009688; --accent2:#4db6ac; --btnText:#0f1f1d; }
.section-maintenance { --accent1:#fbc02d; --accent2:#ffe082; --btnText:#132722; }
.section-security    { --accent1:#d32f2f; --accent2:#ef5350; --btnText:#1b0b10; }
.section-calendar    { --accent1:#a4db08; --accent2:#cdf268; --btnText:#132722; }

/* Header accent coloring */
.section-header.section-menu,
.section-header.section-staff,
.section-header.section-events,
.section-header.section-visitors,
.section-header.section-maintenance,
.section-header.section-security,
.section-header.section-calendar{
  color:var(--accent2);
  border-left-color:var(--accent2);
}

/* Section-colored card borders (left accent) */
.card.section-menu,
.card.section-staff,
.card.section-events,
.card.section-visitors,
.card.section-maintenance,
.card.section-security,
.card.section-calendar{
  border:1px solid rgba(230,193,90,.16);
  border-left:6px solid var(--accent1);
}

/* Optional subtle hover polish */
.card.section-menu:hover,
.card.section-staff:hover,
.card.section-events:hover,
.card.section-visitors:hover,
.card.section-maintenance:hover,
.card.section-security:hover,
.card.section-calendar:hover{
  filter:brightness(1.02);
}

/* Per-section button color on dashboard cards only */
.card.section-menu .btn,
.card.section-staff .btn,
.card.section-events .btn,
.card.section-visitors .btn,
.card.section-maintenance .btn,
.card.section-security .btn,
.card.section-calendar .btn{
  background:linear-gradient(135deg, var(--accent1), var(--accent2));
  color:var(--btnText);
  border:1px solid rgba(0,0,0,.10);
}

/* Keep your global .btn hover behavior; just a bit softer here */
.card.section-menu .btn:hover,
.card.section-staff .btn:hover,
.card.section-events .btn:hover,
.card.section-visitors .btn:hover,
.card.section-maintenance .btn:hover,
.card.section-security .btn:hover,
.card.section-calendar .btn:hover{
  filter:brightness(1.06);
}
/* =========================
   Footer
========================= */

.footer-credits{
  margin-top: 32px;
  padding: 28px 16px;
  text-align: center;
  border-top: 1px solid rgba(0,0,0,.08);
}

.footer-title{
  font-weight: 600;
  font-size: 1.35rem;
}

.footer-divider{
  width: 60px;
  height: 2px;
  background: rgba(0,0,0,.15);
  margin: 14px auto;
}

.footer-copy{
  opacity: .85;
}

.ops-status-strip{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
  margin-bottom:12px;
}

.ops-stat{
  background:#1d2733;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:14px 16px;
  box-shadow:0 8px 20px rgba(0,0,0,.12);
}

.ops-stat-label{
  font-size:.82rem;
  opacity:.75;
  margin-bottom:6px;
}

.ops-stat-value{
  font-size:1.6rem;
  font-weight:800;
  line-height:1.1;
}

.ops-bell-sev-critical{
  border:3px solid #ff3b3b !important;
  background:linear-gradient(180deg, rgba(110,20,20,.98), rgba(45,12,12,.98)) !important;
  box-shadow:
    0 0 0 1px rgba(255,59,59,.35),
    0 0 16px rgba(255,59,59,.28),
    0 0 34px rgba(255,59,59,.18) !important;
}

.ops-bell-sev-warn{
  border:3px solid #ffb020 !important;
  background:linear-gradient(180deg, rgba(95,60,10,.98), rgba(42,27,8,.98)) !important;
  box-shadow:
    0 0 0 1px rgba(255,176,32,.32),
    0 0 14px rgba(255,176,32,.22),
    0 0 28px rgba(255,176,32,.14) !important;
}

.ops-bell-sev-info{
  border:3px solid #4aa3ff !important;
  background:linear-gradient(180deg, rgba(20,45,82,.98), rgba(12,24,45,.98)) !important;
}

.ops-state-normal{
  border-color:rgba(70,180,90,.45);
}

.ops-state-warning{
  border-color:rgba(255,190,60,.55);
}

.ops-state-critical{
  border-color:rgba(255,80,80,.65);
  box-shadow:0 0 0 1px rgba(255,80,80,.18), 0 10px 26px rgba(255,80,80,.14);
}

.ops-last-updated{
  margin:8px 0 18px;
  font-size:.9rem;
  opacity:.8;
}

.ops-main-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:18px;
  align-items:start;
}

.ops-panel{
  background:#1d2733;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:18px;
  min-height:280px;
}

.ops-panel-critical{
  border-color:rgba(255,90,90,.18);
}

.ops-panel-header{
  font-size:1rem;
  font-weight:800;
  margin-bottom:14px;
}

.ops-panel-body{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.ops-empty{
  opacity:.7;
  padding:12px 0;
}

.ops-bell-card,
.ops-list-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:12px 14px;
}

.ops-bell-active{
  border-left:5px solid #ff5a5a;
  animation: opsPulse 1.4s ease-in-out infinite;
}

.ops-bell-ack{
  border-left:5px solid #d5a43d;
}

.ops-item-title{
  font-weight:800;
  margin-bottom:4px;
}

.ops-item-meta{
  font-size:.9rem;
  opacity:.82;
  margin-top:2px;
}

.ops-item-badge{
  margin-top:8px;
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
}

.ops-maint-summary{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:10px;
  font-size:.9rem;
}

@keyframes opsPulse{
  0%{ box-shadow:0 0 0 0 rgba(255,90,90,.22); }
  70%{ box-shadow:0 0 0 10px rgba(255,90,90,0); }
  100%{ box-shadow:0 0 0 0 rgba(255,90,90,0); }
}

@media (max-width: 1280px){
  .ops-status-strip{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .ops-main-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 800px){
  .ops-status-strip,
  .ops-main-grid,
  .ops-maint-summary{
    grid-template-columns:1fr;
  }
}

.ops-console{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.ops-command-bar{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:12px;
  padding:12px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(18,31,45,.98), rgba(13,24,35,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.ops-command-item{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:12px 14px;
  min-height:86px;
}

.ops-command-label{
  font-size:.82rem;
  opacity:.76;
  margin-bottom:8px;
}

.ops-command-value{
  font-size:1.7rem;
  font-weight:900;
  letter-spacing:.02em;
  line-height:1.05;
}

.ops-command-time{
  font-size:1.15rem;
}

.ops-state-normal{
  border-color:rgba(70,180,90,.50);
  box-shadow:0 0 0 1px rgba(70,180,90,.14), 0 10px 26px rgba(70,180,90,.08);
}

.ops-state-warning{
  border-color:rgba(255,190,60,.55);
  box-shadow:0 0 0 1px rgba(255,190,60,.14), 0 10px 26px rgba(255,190,60,.08);
}

.ops-state-critical{
  border-color:rgba(255,80,80,.68);
  box-shadow:0 0 0 1px rgba(255,80,80,.18), 0 12px 30px rgba(255,80,80,.15);
}

.ops-section-title{
  font-size:1rem;
  font-weight:900;
  letter-spacing:.03em;
  text-transform:uppercase;
  opacity:.95;
  margin-bottom:10px;
}

.ops-bell-wall-wrap{
  background:linear-gradient(180deg, rgba(28,12,12,.20), rgba(20,10,10,.10));
  border:1px solid rgba(255,90,90,.16);
  border-radius:22px;
  padding:16px;
}

.ops-bell-wall{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(270px,1fr));
  gap:16px;
  align-items:stretch;
}

.ops-bell-wall-card{
  min-height:180px;
  border-radius:22px;
  padding:18px 18px 16px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  background:linear-gradient(180deg, rgba(32,41,52,.98), rgba(21,29,38,.98));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}

.ops-bell-wall-active{
  border:2px solid rgba(255,90,90,.8);
  animation: opsBellPulse .8s ease-in-out infinite;
}

.ops-bell-wall-priority{
  min-height:220px;
}

.ops-bell-wall-ack{
  border:2px solid rgba(214,165,63,.60);
  opacity:.86;
}

.ops-bell-wall-room{
  font-size:2rem;
  font-weight:900;
  line-height:1;
  letter-spacing:.02em;
}

.ops-bell-wall-type{
  margin-top:8px;
  font-size:1.15rem;
  font-weight:700;
  opacity:.96;
}

.ops-bell-wall-meta{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:.95rem;
  opacity:.82;
  margin-top:12px;
}

.ops-bell-wall-badge{
  margin-top:14px;
  align-self:flex-start;
  padding:8px 12px;
  border-radius:999px;
  font-size:.85rem;
  font-weight:900;
  letter-spacing:.04em;
  background:rgba(255,255,255,.08);
}

.ops-secondary-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  align-items:start;
}

.ops-panel{
  background:#1d2733;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:18px;
  min-height:280px;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}

.ops-panel-header{
  font-size:1rem;
  font-weight:900;
  margin-bottom:14px;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.ops-panel-body{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.ops-list-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:12px 14px;
}

.ops-item-title{
  font-weight:800;
  margin-bottom:4px;
}

.ops-item-meta{
  font-size:.9rem;
  opacity:.82;
  margin-top:2px;
}

.ops-empty{
  opacity:.72;
  padding:12px 0;
}

.ops-empty-large{
  min-height:140px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
  font-weight:700;
}

.ops-maint-summary{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:10px;
  font-size:.92rem;
}

@keyframes opsBellPulse{
  0%{ box-shadow:0 0 0 0 rgba(255,90,90,.28), 0 14px 32px rgba(255,50,50,.18); }
  50%{ box-shadow:0 0 0 12px rgba(255,90,90,0), 0 18px 36px rgba(255,50,50,.22); }
  100%{ box-shadow:0 0 0 0 rgba(255,90,90,0), 0 14px 32px rgba(255,50,50,.18); }
}

@media (max-width: 1500px){
  .ops-command-bar{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .ops-secondary-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width: 900px){
  .ops-command-bar,
  .ops-secondary-grid,
  .ops-maint-summary{
    grid-template-columns:1fr;
  }

  .ops-bell-wall{
    grid-template-columns:1fr;
  }

  .ops-bell-wall-room{
    font-size:1.6rem;
  }
}

/* --- Operations Command Status States --- */

.ops-state-normal{
  border:2px solid rgba(0,200,120,.55);
  box-shadow:0 0 18px rgba(0,200,120,.18);
}

.ops-state-warning{
  border:2px solid rgba(255,176,32,.65);
  box-shadow:0 0 20px rgba(255,176,32,.25);
}

.ops-state-critical{
  border:2px solid rgba(255,60,60,.85);
  box-shadow:
    0 0 0 1px rgba(255,60,60,.25),
    0 0 22px rgba(255,60,60,.35),
    0 0 38px rgba(255,60,60,.18);
  animation: opsCriticalPulse 1s ease-in-out infinite;
}

@keyframes opsCriticalPulse{
  0%{
    transform:scale(1);
    filter:brightness(1);
  }
  50%{
    transform:scale(1.01);
    filter:brightness(1.35);
  }
  100%{
    transform:scale(1);
    filter:brightness(1);
  }
}

.ops-bell-wall-device{
  margin-top:6px;
  font-size:.9rem;
  opacity:.55;
  font-family:monospace;
}
