/* VPS NOON Home layer — built to feel like the hotspot family, not a generic web app */
:root {
  --nh-gold: #d4af37;
  --nh-gold-soft: rgba(212, 175, 55, 0.16);
  --nh-dark-top: rgba(17, 24, 39, 0.985);
  --nh-dark-bottom: rgba(8, 14, 26, 0.99);
  --nh-tile-top: rgba(22, 33, 56, 0.96);
  --nh-tile-bottom: rgba(11, 19, 34, 0.985);
  --nh-line: rgba(212, 175, 55, 0.22);
  --nh-text-soft: rgba(255, 255, 255, 0.76);
  --nh-text-soft-light: rgba(23, 33, 48, 0.72);
}

body.noon-home-body {
  min-height: 100vh;
  padding-top: 8px;
}

.noon-shell {
  width: min(calc(100vw - 12px), 430px);
  margin: 58px auto 18px;
}

.noon-home-card {
  width: 100%;
  max-width: 430px;
  margin: 0 auto 14px;
  border-radius: 24px;
  padding: 16px 14px;
  position: relative;
  overflow: hidden;
}

.hero-card,
.section-card,
.status-card,
.form-card {
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, 0.18), transparent 34%),
    linear-gradient(180deg, var(--nh-dark-top) 0%, var(--nh-dark-bottom) 100%);
  border: 1px solid var(--nh-line);
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

body.light-theme .hero-card,
body.light-theme .section-card,
body.light-theme .status-card,
body.light-theme .form-card {
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, 0.11), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,0.996) 0%, rgba(241,245,250,0.992) 100%);
  border-color: rgba(114, 128, 150, 0.34);
  box-shadow:
    0 16px 34px rgba(13, 24, 39, 0.12),
    inset 0 1px 0 rgba(255,255,255,0.84);
}

.hero-glow {
  position: absolute;
  inset-inline-start: -16px;
  top: -20px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(212,175,55,0.22), transparent 66%);
  pointer-events: none;
}

.hero-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.noon-home-card .logo,
.noon-mark {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
}

.plain-logo {
  width: auto;
  min-width: 0;
  height: auto;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  font-size: 4.2rem;
  line-height: 1;
  letter-spacing: 0;
}

body.dark-theme .plain-logo {
  text-shadow:
    0 0 3px rgba(255,255,255,0.9),
    0 0 9px rgba(255,223,112,0.72),
    0 0 18px rgba(212,175,55,0.52);
}

.hero-copy {
  flex: 1;
  min-width: 0;
  text-align: start;
}

.hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 11px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  border: 1px solid rgba(212,175,55,0.25);
  background: rgba(212,175,55,0.07);
  color: var(--nh-gold);
}

.noon-page-title {
  margin: 11px 0 6px;
  font-size: 1.42rem;
  line-height: 1.24;
  font-weight: 900;
}

.noon-page-subtitle,
.hero-note,
.section-subtitle,
.tile-note,
.ticket-muted,
.status-meta,
.timeline-date,
.empty-note,
.helper-text {
  color: var(--nh-text-soft);
  line-height: 1.68;
}

body.light-theme .noon-page-subtitle,
body.light-theme .hero-note,
body.light-theme .section-subtitle,
body.light-theme .tile-note,
body.light-theme .ticket-muted,
body.light-theme .status-meta,
body.light-theme .timeline-date,
body.light-theme .empty-note,
body.light-theme .helper-text {
  color: var(--nh-text-soft-light);
}

.hero-mini-grid,
.ticket-mini-grid,
.service-grid,
.action-grid {
  display: grid;
  gap: 10px;
}

.hero-mini-grid,
.ticket-mini-grid,
.service-grid.two-col,
.action-grid.two-col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.summary-chip,
.service-tile,
.ticket-stat,
.timeline-item,
.action-panel,
.ticket-panel,
.form-block,
.ticket-line,
.mini-panel {
  border-radius: 18px;
  background: linear-gradient(180deg, var(--nh-tile-top) 0%, var(--nh-tile-bottom) 100%);
  border: 1px solid rgba(212,175,55,0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}

body.light-theme .summary-chip,
body.light-theme .service-tile,
body.light-theme .ticket-stat,
body.light-theme .timeline-item,
body.light-theme .action-panel,
body.light-theme .ticket-panel,
body.light-theme .form-block,
body.light-theme .ticket-line,
body.light-theme .mini-panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(241,245,249,0.96) 100%);
  border-color: rgba(113, 129, 150, 0.24);
}

.summary-chip,
.ticket-stat,
.mini-panel {
  padding: 12px 11px;
}

.service-tile,
.action-panel,
.ticket-line,
.ticket-panel,
.timeline-item {
  padding: 13px 12px;
  text-decoration: none;
  color: inherit;
}

.service-tile:hover,
.action-panel:hover,
.ticket-line:hover {
  transform: translateY(-1px);
  border-color: rgba(212,175,55,0.35);
}

.tile-top,
.ticket-line-top,
.section-head,
.panel-head,
.timeline-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.section-head {
  margin-bottom: 12px;
}

.section-title {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 900;
}

.section-subtitle {
  margin: 4px 0 0;
  font-size: .9rem;
}

.tile-icon,
.section-icon,
.panel-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(212,175,55,0.12);
  border: 1px solid rgba(212,175,55,0.18);
  font-size: 1.22rem;
}

.service-tile strong,
.ticket-line strong,
.summary-chip strong,
.ticket-stat strong,
.action-panel strong,
.ticket-panel strong,
.timeline-item strong,
.form-block strong {
  display: block;
  margin-bottom: 5px;
  font-size: .97rem;
}

.service-tile span,
.summary-chip span,
.ticket-stat span,
.action-panel span,
.ticket-line span,
.mini-panel span {
  display: block;
  font-size: .84rem;
  line-height: 1.58;
}

.tile-tag,
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .02em;
}

.tag-live,
.status-received,
.status-review,
.status-progress,
.status-resolved,
.status-needinfo,
.status-escalated {
  border: 1px solid rgba(212,175,55,0.22);
  background: rgba(212,175,55,0.09);
  color: var(--nh-gold);
}

.tag-muted {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.8);
}

body.light-theme .tag-muted {
  color: rgba(23,33,48,0.72);
  background: rgba(23,33,48,0.06);
}

.top-nav {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin: 0 auto 12px;
  width: min(calc(100vw - 12px), 430px);
}

.top-nav a {
  flex: 1;
  text-align: center;
  text-decoration: none;
  color: inherit;
  padding: 11px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(212,175,55,0.16);
}

body.light-theme .top-nav a {
  background: rgba(255,255,255,0.84);
  border-color: rgba(113,129,150,0.24);
}

.ticket-center-list {
  display: grid;
  gap: 10px;
}

.ticket-line {
  display: block;
}

.ticket-line small,
.ticket-line .ticket-muted,
.ticket-panel small,
.summary-chip small,
.ticket-stat small,
.mini-panel small {
  display: block;
  margin-top: 4px;
  font-size: .76rem;
  line-height: 1.55;
  color: var(--nh-text-soft);
}

body.light-theme .ticket-line small,
body.light-theme .ticket-panel small,
body.light-theme .summary-chip small,
body.light-theme .ticket-stat small,
body.light-theme .mini-panel small {
  color: var(--nh-text-soft-light);
}

.ticket-priority {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .74rem;
  font-weight: 700;
  color: var(--nh-gold);
}

.form-stack {
  display: grid;
  gap: 12px;
}

.form-block label {
  display: block;
  font-size: .84rem;
  font-weight: 700;
  margin-bottom: 7px;
}

.noon-field,
.noon-select,
.noon-textarea {
  width: 100%;
  border-radius: 15px;
  border: 1px solid rgba(212,175,55,0.18);
  background: rgba(255,255,255,0.04);
  color: inherit;
  padding: 13px 12px;
  font-size: .95rem;
  outline: none;
}

body.light-theme .noon-field,
body.light-theme .noon-select,
body.light-theme .noon-textarea {
  background: rgba(255,255,255,0.86);
  border-color: rgba(113,129,150,0.24);
}

.noon-textarea {
  min-height: 112px;
  resize: vertical;
}

.primary-action,
.secondary-action {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 46px;
  border-radius: 15px;
  text-decoration: none;
  font-weight: 800;
  cursor: pointer;
}

.primary-action {
  background: linear-gradient(180deg, #ffe58a 0%, #d4af37 100%);
  color: #111;
  border: none;
  box-shadow: 0 12px 28px rgba(212,175,55,0.24);
}

.secondary-action {
  background: transparent;
  color: inherit;
  border: 1px solid rgba(212,175,55,0.18);
}

.action-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.status-strip {
  margin-top: 12px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(212,175,55,0.08);
  border: 1px solid rgba(212,175,55,0.16);
}

.timeline {
  display: grid;
  gap: 10px;
}

.timeline-item {
  position: relative;
}

.timeline-item::before {
  content: '';
  position: absolute;
  inset-inline-start: 15px;
  top: 16px;
  bottom: -10px;
  width: 2px;
  background: rgba(212,175,55,0.18);
}

.timeline-item:last-child::before {
  display: none;
}

.timeline-head {
  align-items: flex-start;
}

.timeline-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--nh-gold);
  margin-top: 5px;
  flex: 0 0 auto;
}

.timeline-body {
  flex: 1;
  min-width: 0;
}

.page-footer {
  width: min(calc(100vw - 12px), 430px);
  margin: 0 auto 20px;
  text-align: center;
  font-size: .83rem;
  line-height: 1.65;
  color: var(--nh-text-soft);
}

body.light-theme .page-footer {
  color: var(--nh-text-soft-light);
}

.hidden {
  display: none !important;
}

@media (max-width: 430px) {
  .noon-shell {
    width: min(calc(100vw - 8px), 430px);
    margin-top: 54px;
  }

  .noon-home-card {
    border-radius: 21px;
    padding: 15px 11px;
  }

  .hero-head {
    align-items: flex-start;
  }

  .plain-logo {
    font-size: 3.6rem;
  }

  .hero-mini-grid,
  .ticket-mini-grid,
  .service-grid.two-col,
  .action-grid.two-col,
  .action-row {
    grid-template-columns: 1fr;
  }

  .top-nav {
    gap: 8px;
  }

  .top-nav a {
    padding: 10px 9px;
    border-radius: 14px;
    font-size: .9rem;
  }
}



.noon-logo-wrap {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: linear-gradient(145deg, #0c1220, #111827);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.05),
    0 8px 20px rgba(0,0,0,0.5);
}

.noon-logo {
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter:
    drop-shadow(0 0 2px rgba(255,255,255,0.6))
    drop-shadow(0 0 6px rgba(255,215,0,0.3));
}


.noon-page-card {
  text-align: center;
}

.noon-home-main-actions {
  margin-top: 18px;
}

.home-primary-btn,
.home-secondary-btn {
  min-height: 52px;
}

.home-primary-btn {
  background: linear-gradient(to right, #d4af37, #00c6ff);
}

.home-secondary-btn {
  background: linear-gradient(145deg, rgba(27,40,74,0.96), rgba(16,24,46,0.94));
  border: 1px solid rgba(212,175,55,0.35);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 0 10px rgba(0,0,0,0.2);
}

.home-secondary-btn:hover {
  background: gold;
  color: #111;
}

.noon-section-label {
  margin: 16px 0 10px;
  font-weight: 700;
  font-size: 1rem;
  color: #f0d87c;
}

.noon-service-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
  text-align: start;
}

.service-tile {
  display: block;
  text-decoration: none;
  height: 100%;
}

.service-tile h3 {
  margin: 0 0 8px;
  color: #f5d66c;
  font-size: 1.05rem;
}

.tile-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.service-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  background: rgba(212,175,55,0.12);
  border: 1px solid rgba(212,175,55,0.35);
  color: #f5d66c;
}

.service-icon {
  font-size: 1.4rem;
  line-height: 1;
}

.service-tile-live {
  border: 1px solid rgba(0,198,255,0.18);
}

.service-tile-track {
  border: 1px solid rgba(212,175,55,0.22);
}

.service-tile-soon {
  opacity: 0.92;
}

.ticket-form-card {
  background: rgba(18, 24, 44, 0.86);
  border: 1px solid rgba(212,175,55,0.16);
  border-radius: 22px;
  padding: 16px;
  margin-top: 14px;
  text-align: start;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.field-label {
  display: block;
  text-align: start;
  margin-top: 10px;
  margin-bottom: 6px;
  font-weight: 700;
  color: #f5d66c;
}

.status-shell {
  display: grid;
  gap: 12px;
  margin-top: 16px;
  text-align: start;
}

.status-card {
  background: rgba(18, 24, 44, 0.86);
  border: 1px solid rgba(212,175,55,0.16);
  border-radius: 20px;
  padding: 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.status-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
}

.status-id {
  font-size: 0.92rem;
  color: #cdd6e6;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}

.status-pill.review {
  background: rgba(250,204,21,0.18);
  border: 1px solid rgba(250,204,21,0.36);
  color: #ffe17a;
}

.status-list {
  display: grid;
  gap: 8px;
}

.status-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.status-row:last-child {
  border-bottom: 0;
}

.status-key {
  color: #9fb0ca;
}

.status-value {
  color: #fff;
  text-align: end;
}

.empty-ticket {
  background: rgba(18, 24, 44, 0.86);
  border: 1px dashed rgba(212,175,55,0.25);
  border-radius: 20px;
  padding: 18px;
  margin-top: 16px;
  text-align: center;
}

@media (max-width: 520px) {
  .noon-service-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   NOON Stage 2 visual alignment fix
   Purpose: restore compact app-style tiles for User Home and Staff Home
   while keeping the Stage 2 workflow/wiring unchanged.
   ========================================================= */

.noon-service-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
  margin-top: 10px;
}

.noon-service-grid .app-card,
.noon-service-grid .service-tile {
  min-height: 124px;
  padding: 12px 10px;
  border-radius: 18px;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: stretch;
  text-align: start;
  box-sizing: border-box;
  overflow: hidden;
}

.noon-service-grid .tile-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

.noon-service-grid .service-icon {
  width: 36px;
  height: 36px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-size: 1.12rem;
  background: rgba(212,175,55,0.12);
  border: 1px solid rgba(212,175,55,0.18);
}

.noon-service-grid .service-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  max-width: 76px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: .68rem;
  line-height: 1;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid rgba(212,175,55,0.22);
  background: rgba(212,175,55,0.09);
  color: var(--nh-gold);
}

.noon-service-grid .service-tile h3,
.noon-service-grid .app-card h3 {
  margin: 6px 0 4px;
  font-size: .96rem;
  line-height: 1.32;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.noon-service-grid .app-sub {
  font-size: .78rem;
  line-height: 1.52;
  opacity: .82;
  overflow-wrap: anywhere;
}

.noon-service-grid .app-sub span {
  font-size: inherit;
  line-height: inherit;
}

.noon-service-grid .service-tile:hover,
.noon-service-grid .app-card:hover {
  transform: translateY(-1px);
  border-color: rgba(212,175,55,0.35);
}

/* Keep the dashboard readable on very narrow phones without turning it into long wide list cards. */
@media (max-width: 360px) {
  .noon-service-grid {
    gap: 8px;
  }

  .noon-service-grid .app-card,
  .noon-service-grid .service-tile {
    min-height: 118px;
    padding: 10px 9px;
  }

  .noon-service-grid .service-icon {
    width: 32px;
    height: 32px;
    border-radius: 12px;
  }

  .noon-service-grid .service-badge {
    max-width: 64px;
    font-size: .64rem;
    padding: 0 7px;
  }

  .noon-service-grid .service-tile h3,
  .noon-service-grid .app-card h3 {
    font-size: .9rem;
  }

  .noon-service-grid .app-sub {
    font-size: .73rem;
  }
}


/* NOON full-system alignment helpers */
.noon-unified-nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:8px 0 12px}
.noon-unified-nav a,.std-nav a,.top-nav a{display:flex;align-items:center;justify-content:center;text-align:center;text-decoration:none;color:inherit;padding:10px 8px;border-radius:14px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.10);font-weight:800;font-size:.88rem;min-height:38px}
.noon-grid{display:grid;grid-template-columns:1fr;gap:12px}.noon-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.noon-field{margin:12px 0}.noon-field label,.field-label{display:block;margin:0 0 6px;font-weight:900}
.noon-field input,.noon-field select,.noon-field textarea,.ticket-form-card input,.ticket-form-card select,.ticket-form-card textarea{width:100%;box-sizing:border-box;border-radius:14px;border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.06);color:#fff;padding:13px;font-size:15px;outline:none}
body.light-theme .noon-field input,body.light-theme .noon-field select,body.light-theme .noon-field textarea,body.light-theme .ticket-form-card input,body.light-theme .ticket-form-card select,body.light-theme .ticket-form-card textarea{background:rgba(255,255,255,.92);color:#111827;border-color:rgba(17,24,39,.18)}
.noon-field textarea,.ticket-form-card textarea{min-height:105px;resize:vertical}.ticket-form-card{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:16px;margin-top:14px}
.noon-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.noon-btn,.noon-btn-primary,.noon-btn-secondary{border:0;border-radius:14px;padding:13px 12px;font-weight:900;text-align:center;text-decoration:none;cursor:pointer}.noon-btn-primary{background:#facc15;color:#111827}.noon-btn-secondary{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:inherit}.noon-btn-danger{background:#ef4444;color:#fff}.noon-small{font-size:.82rem;opacity:.78;line-height:1.6}.noon-pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;background:rgba(56,189,248,.15);border:1px solid rgba(56,189,248,.24);font-size:.78rem}.noon-card-line{display:block;text-decoration:none;color:inherit;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:14px;margin:10px 0;line-height:1.7}.noon-code{direction:ltr;color:#facc15;font-weight:900}.helper-box{margin-top:12px;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);line-height:1.8;color:#d9e4ff}.rtl-start{text-align:start}.ltr-value{direction:ltr;text-align:left}.noon-table{width:100%;border-collapse:separate;border-spacing:0 8px}.noon-table th,.noon-table td{padding:10px;border-bottom:1px solid rgba(255,255,255,.08);text-align:start;font-size:.86rem}.noon-actions-grid{display:grid;grid-template-columns:1fr;gap:10px}.noon-action-card{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:14px;margin:10px 0}
@media(max-width:420px){.noon-unified-nav{gap:6px}.noon-unified-nav a{font-size:.78rem;padding:9px 5px}.noon-grid.two,.noon-btn-row{grid-template-columns:1fr}}
