/* Modernized UI — visual polish, spacing, typography, shadows
   Preserves HTML structure and JS class/ID expectations. */
:root{
  /* Core palette */
  --bg-900: #071018; /* page background */
  --bg-800: #0f1720; /* elevated background */
  --panel:   #111827; /* cards/panels */
  --muted:   #9aa6b6; /* secondary text */
  --muted-2: #7b8897;
  --text:    #eef6f9; /* primary text */
  --accent:  #39d6a8; /* main accent */
  --accent-2:#1fbf9a; /* accent alt */
  --danger:  #ff6b6b;
  --glass:   rgba(255,255,255,0.03);
  --border:  rgba(255,255,255,0.045);

  --shadow-xs: 0 6px 18px rgba(2,6,23,0.55);
  --shadow-sm: 0 12px 32px rgba(2,6,23,0.6);
  --shadow-md: 0 20px 60px rgba(2,6,23,0.65);

  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 20px;
}

/* Reset + base */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;}
body{
  background: linear-gradient(180deg,var(--bg-900), #06121a 100%);
  color:var(--text);
  font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}

/* Layout container used in markup */
.container{max-width:1100px;margin:22px auto;padding:0 20px;}

/* Topbar (visual header) */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:8px 12px;position:sticky;top:8px;z-index:140;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));
  border-radius:16px;border:1px solid var(--glass);box-shadow:var(--shadow-xs);
}

/* Ensure editor panel stays below the topbar (override duplicates) */
.editor-panel{position:fixed;inset:64px 12px 12px 12px;z-index:220;pointer-events:none}
.brand{display:flex;gap:14px;align-items:center}
.logo-placeholder{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 8px 28px rgba(31,191,154,0.12)}
h1{font-size:18px;margin:0;font-weight:800;letter-spacing:-0.02em}
.sub{font-size:13px;color:var(--muted);margin-top:2px;font-weight:600}

/* Admin banner */
.admin-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;background:linear-gradient(180deg, rgba(57,214,168,0.05), rgba(57,214,168,0.02));border:1px solid rgba(57,214,168,0.06);box-shadow:0 6px 18px rgba(31,191,154,0.06);margin-bottom:18px}
.admin-banner strong{font-weight:800}
.admin-txt{color:var(--muted);font-size:13px}

/* Days grid */
.days{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:18px;margin-bottom:28px}

/* Card */
.card{background:var(--panel);border-radius:var(--radius-md);padding:18px;border:1px solid var(--glass);box-shadow:0 10px 30px rgba(2,6,23,0.55);transition:transform 220ms ease, box-shadow 220ms ease}
.card header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,0.03);padding-bottom:12px;margin-bottom:14px}
.card h3{margin:0;font-size:15px;font-weight:800;color:var(--text)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm)}

/* Segment (period row) */
.segment{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,0.02);background:linear-gradient(180deg, rgba(255,255,255,0.01), transparent);transition:transform 160ms ease}
.segment + .segment{margin-top:12px}
.segment.available{background:linear-gradient(90deg, rgba(57,214,168,0.06), rgba(31,191,154,0.02));border-color:rgba(31,191,154,0.08)}
.segment.waiting{opacity:0.95}
.segment.completed{opacity:0.35}
.segment.cancelled{opacity:0.85;color:#ffb3b0;background:linear-gradient(90deg, rgba(255,107,107,0.04), transparent);border-color:rgba(255,107,107,0.06)}

.meta{display:flex;align-items:center;gap:14px;flex:1}
.meta .time{font-weight:800;font-size:12px;color:var(--muted);text-transform:uppercase;background:rgba(255,255,255,0.02);padding:6px 10px;border-radius:8px}
.meta .route{font-size:15px;font-weight:700;color:var(--text)}

.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:flex-end}

/* Buttons */
.btn{background:transparent;border:1px solid rgba(255,255,255,0.03);color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer;font-weight:700;font-size:14px;transition:all 180ms ease}
.btn:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(2,6,23,0.55)}
.btn:active{transform:translateY(0)}
.btn.primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));border:none;color:#042126;padding:10px 16px;border-radius:12px}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.03);color:var(--muted)}
.btn:disabled{opacity:0.5;cursor:not-allowed}

.lock-logo{width:26px;height:26px;border-radius:6px;object-fit:contain}
/* Share button removed — UI simplified */
.lock-logo{width:26px;height:26px;border-radius:6px;object-fit:contain}
.logo-img{width:40px;height:40px;border-radius:10px;object-fit:cover;margin-right:12px}

/* Admin button in topbar */
.admin-btn{font-size:16px;padding:8px 10px;border-radius:10px;min-width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;position:relative;z-index:50;box-shadow:var(--shadow-sm);background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);backdrop-filter:blur(4px)}
.admin-btn:hover{transform:translateY(-2px)}

.status-btn{padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,0.03);background:transparent;color:var(--muted);font-weight:700}
.status-btn.active{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#042126;border-color:rgba(31,191,154,0.12)}

/* Inputs */
.input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,0.03);background:transparent;color:var(--text);font-size:14px}
.input:focus{outline:none;box-shadow:0 10px 28px rgba(2,6,23,0.55);border-color:var(--accent)}

/* Editor panel / modal */
.editor-panel{position:fixed;inset:64px 12px 12px 12px;z-index:220;pointer-events:auto}
.editor-inner{pointer-events:auto;background:var(--panel);border-radius:14px;border:1px solid rgba(255,255,255,0.03);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;max-width:1100px;margin:0 auto;height:calc(100% - 96px);padding:18px;overflow:auto}
.editor-header{display:flex;align-items:center;justify-content:space-between;padding:18px;border-bottom:1px solid rgba(255,255,255,0.03)}
.editor-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;padding:18px;flex:1;overflow:auto}
.editor-actions{display:flex;gap:12px;padding:14px;border-top:1px solid rgba(255,255,255,0.02);background:transparent}

.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(2,6,23,0.6), rgba(2,6,23,0.75));backdrop-filter:blur(6px);z-index:1200}
.modal-inner{width:720px;max-width:94%;background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));border-radius:14px;padding:22px;border:1px solid rgba(255,255,255,0.04);box-shadow:var(--shadow-md);backdrop-filter:blur(6px)}
.modal:not(.hidden){animation:modalIn 260ms cubic-bezier(.2,.9,.2,1)}
.modal.hidden{display:none !important}
.modal h2{margin:0 0 12px 0;font-size:20px}
.modal input{width:100%;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,0.03);background:transparent;color:var(--text)}

.toast{position:fixed;right:18px;top:18px;background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#042126;padding:12px 18px;border-radius:12px;border:1px solid rgba(255,255,255,0.04);box-shadow:0 10px 30px rgba(2,6,23,0.6);z-index:1200;opacity:0;transform:translateY(-8px) scale(0.98);transition:all 260ms cubic-bezier(.2,.9,.2,1);pointer-events:none;display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.toast::before{content:'✓';font-weight:800;margin-right:6px}

.logout-btn{position:fixed;bottom:26px;right:26px;background:linear-gradient(90deg,var(--danger),#d64545);border:none;color:white;padding:10px 14px;border-radius:12px;box-shadow:0 8px 28px rgba(214,69,69,0.18);z-index:140}

/* Waiting message */
.waiting-message{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:40px 16px;text-align:center;gap:18px;color:var(--muted)}
.waiting-icon{font-size:64px}

/* Misc */
.hidden{display:none !important}
.mono{font-family:'Fira Mono',monospace;color:var(--muted-2)}

/* Responsive */
@media (max-width:900px){
  .days{grid-template-columns:1fr}
  .topbar{padding:12px;margin:8px}
  .editor-panel{inset:64px 10px 10px 10px}
}

/* Mobile / small screens tweaks */
@media (max-width:780px){
  .topbar{padding:8px 10px;top:6px}
  .logo-img{width:36px;height:36px}
  .admin-btn{min-width:40px;height:40px;padding:6px;font-size:14px}

  /* Modal: full width, reduced padding */
  .modal-inner{width:94% !important;max-width:94% !important;padding:14px !important}
  .modal-inner h2{font-size:18px}
  .modal input{padding:12px}

  /* Editor: single column, smaller gaps */
  .editor-fields{grid-template-columns:1fr !important;gap:12px;padding:12px}
  .editor-card{padding:12px}
  .editor-title{font-size:16px}

  /* Editor actions stack vertically on mobile */
  .editor-actions{flex-direction:column;align-items:stretch;gap:12px;padding:12px}
  .editor-actions .left,.editor-actions .right{width:100%;display:flex;gap:12px}
  .editor-actions .left{justify-content:center}
  .editor-actions .right{justify-content:center}
  .editor-actions .btn{min-width:100%;padding:12px}

  /* Inputs and selects full width touch friendly */
  .editor-select,.editor-input{width:100%;padding:12px}

  /* Footer smaller */
  .footer .container{padding:8px 10px;font-size:12px}
}
.segment.waiting{
  opacity:0.85;
  background:linear-gradient(135deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02));
  border:1px solid var(--border-default);
}
.segment.completed{
  opacity:0.4;
  color:var(--text-tertiary);
  text-decoration:line-through;
  background:rgba(0,0,0,0.3);
}
.segment.cancelled{
  opacity:0.7;
  color:#ff8a80;
  background:linear-gradient(135deg,rgba(239,83,80,0.15),rgba(239,83,80,0.08));
  border:1px solid rgba(239,83,80,0.35);
}

/* Editor & modal polish */
.editor-header{padding:22px 18px}
.editor-header h3{font-size:20px;color:var(--text);margin:0}
.btn-close{width:44px;height:44px;border-radius:10px}
.editor-fields{gap:18px;padding:18px}
.editor-card{background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));border-radius:12px;padding:18px;border:1px solid rgba(255,255,255,0.02);box-shadow:0 8px 24px rgba(2,6,23,0.45);margin-bottom:14px}
.editor-title{font-weight:800;color:var(--text);margin-bottom:10px}
.editor-group{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
.editor-select{padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:var(--text);font-weight:700}
.editor-input{padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:var(--text)}
.editor-actions{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-top:1px solid rgba(255,255,255,0.02);background:transparent}
.editor-actions .left{display:flex;gap:12px}
.editor-actions .right{display:flex;gap:12px}
.editor-actions .btn{min-width:140px}

/* Modal animations */
@keyframes modalIn{from{opacity:0;transform:translateY(-8px) scale(0.995)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Strong override to keep editor panel below the topbar and centered */
.editor-panel{inset:64px 12px 12px 12px !important;position:fixed !important;z-index:220 !important}

/* Final safety overrides to ensure modal/editor visibility and interactivity */
.modal.hidden{display:none !important;visibility:hidden !important;opacity:0 !important;pointer-events:none !important}
.modal{z-index:1200}
.editor-panel{inset:64px 12px 12px 12px !important;position:fixed !important;z-index:900 !important;pointer-events:auto !important;display:block !important}
  .editor-inner{padding:12px}
  .editor-actions .btn{min-width:100%}
.meta .time{
  font-weight:700;
  font-size:11px;
.editor-panel.hidden{display:none !important;pointer-events:none !important;visibility:hidden !important}
  color:var(--text-tertiary);
  text-transform:uppercase;
  letter-spacing:0.06em;
  background:rgba(255,255,255,0.05);
  padding:4px 8px;
  border-radius:6px;
}
.meta .route{font-size:15px;font-weight:600;color:var(--text-primary)}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.btn{
  background:var(--surface);
  border:1px solid var(--border-default);
  color:var(--text-primary);
  padding:10px 16px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:600;
  font-size:14px;
  transition:all 0.2s ease;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.btn::before{
  content:'';
  position:absolute;
  top:50%;
  left:50%;
  width:0;
  height:0;
  border-radius:50%;
  background:rgba(255,255,255,0.1);
  transform:translate(-50%,-50%);
  transition:width 0.4s ease,height 0.4s ease;
}
.btn:hover:not(:disabled)::before{
  width:300px;
  height:300px;
}
.btn:hover:not(:disabled){
  background:var(--surface-hover);
  border-color:var(--border-default);
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}
.btn:active:not(:disabled){
  transform:translateY(0);
}
.btn:focus{outline:2px solid rgba(59,203,154,0.3);outline-offset:2px}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn.primary{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);
  border:none;
  color:white;
  font-weight:700;
  box-shadow:var(--shadow-accent);
}
.btn.primary:hover{
  background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent-light) 100%);
  box-shadow:0 6px 20px rgba(59,203,154,0.35);
  transform:translateY(-2px);
}
.btn.ghost{
  background:transparent;
  border:1px solid var(--border-subtle);
  color:var(--text-secondary);
}
.btn.ghost:hover{
  background:rgba(255,255,255,0.05);
  border-color:var(--border-default);
}
.admin-controls{display:flex;flex-direction:column;gap:10px;min-width:220px}
.status-group{display:flex;gap:8px}
.status-btn{
  flex:1;
  padding:8px;
  border:1px solid var(--border-default);
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:700;
  font-size:14px;
  transition:all 0.2s ease;
  background:var(--surface);
  color:var(--text-secondary);
  box-shadow:var(--shadow-sm);
}
.status-btn:active{transform:scale(0.95)}
.status-btn.active,.status-btn:hover{
  background:linear-gradient(135deg,var(--accent),var(--accent-hover));
  color:white;
  border-color:var(--accent);
  box-shadow:var(--shadow-accent);
  transform:translateY(-1px);
}
.status-btn.waiting.active,.status-btn.waiting:hover{
  background:linear-gradient(135deg,var(--warning),#fb8c00);
  border-color:var(--warning);
  box-shadow:0 4px 12px rgba(255,167,38,0.3);
}
.status-btn.cancelled.active,.status-btn.cancelled:hover{
  background:linear-gradient(135deg,var(--danger),#e53935);
  border-color:var(--danger);
  box-shadow:0 4px 12px rgba(239,83,80,0.3);
}
.input{
  width:100%;
  padding:10px 12px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border-default);
  background:var(--bg-secondary);
  color:var(--text-primary);
  font-size:14px;
  transition:all 0.2s ease;
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.2);
}
.input:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.2),0 0 0 3px rgba(59,203,154,0.15);
}
.input::placeholder{color:var(--text-tertiary)}
.footer{
  position:fixed;
  left:0;right:0;bottom:14px;
  display:flex;justify-content:center;pointer-events:none;z-index:1100;
}
.footer .container{
  pointer-events:auto;
  background:rgba(255,255,255,0.02);
  padding:8px 14px;border-radius:10px;font-size:13px;color:var(--text-tertiary);box-shadow:var(--shadow-xs);max-width:640px;margin:0 12px;
}
.footer .rights{font-size:12px;color:var(--text-tertiary);font-weight:500}
.modal{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,0.75);
  backdrop-filter:blur(10px) saturate(120%);
  -webkit-backdrop-filter:blur(10px) saturate(120%);
  z-index:200;
  animation:fadeIn 0.2s ease;
}
@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}
.modal.hidden{display:none}
.modal-inner{
  width:360px;
  max-width:90%;
  background:var(--surface);
  border-radius:var(--radius-lg);
  border:1px solid var(--border-default);
  padding:28px;
  box-shadow:var(--shadow-lg);
  animation:scaleIn 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes scaleIn{
  from{opacity:0;transform:scale(0.9)}
  to{opacity:1;transform:scale(1)}
}
.modal h2{
  margin:0 0 20px 0;
  font-size:20px;
  color:var(--text-primary);
  font-weight:700;
}
.modal input{
  width:100%;
  padding:12px 16px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border-default);
  background:var(--bg-secondary);
  color:var(--text-primary);
  margin-bottom:20px;
  font-size:15px;
  transition:all 0.2s ease;
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.2);
}

/* Admin button: fixed at top-right to avoid occupying topbar space */
.admin-btn{
  position:fixed !important;
  top:14px !important;
  right:14px !important;
  z-index:1500 !important;
  width:48px !important;
  height:48px !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:12px !important;
  background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.00));
  backdrop-filter:blur(6px) saturate(120%);
  -webkit-backdrop-filter:blur(6px) saturate(120%);
  box-shadow:0 10px 30px rgba(2,6,23,0.55);
  border:1px solid rgba(255,255,255,0.04) !important;
  color:var(--text) !important;
}
.admin-btn:hover{transform:translateY(-3px) scale(1.02)}
.admin-btn:active{transform:translateY(0) scale(0.99)}

/* Ensure button doesn't overlap the very top on small screens */
@media (max-width:780px){
  .admin-btn{top:10px;right:10px;width:44px;height:44px}
}

/* Editor panel visual unification: ensure same font, colors and glass effect */
#editorPanel, .editor-panel{
  inset:64px 12px 12px 12px !important;
  position:fixed !important;
  z-index:1200 !important;
  pointer-events:auto !important;
  display:block !important;
}
.editor-inner{
  font-family:inherit !important;
  color:var(--text) !important;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.00)) !important;
  border:1px solid rgba(255,255,255,0.04) !important;
  box-shadow:0 18px 50px rgba(2,6,23,0.7) !important;
  padding:20px !important;
  border-radius:16px !important;
}
.editor-header h3{font-family:inherit;color:var(--text);font-size:20px;font-weight:800}
.btn-close{width:44px;height:44px;border-radius:10px;background:transparent;border:1px solid rgba(255,255,255,0.03);color:var(--muted)}
.btn-close:hover{background:rgba(255,255,255,0.02);color:var(--text)}

/* Modal inner unify with editor visuals */
.modal-inner{
  background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));
  border:1px solid rgba(255,255,255,0.04);
  box-shadow:0 18px 50px rgba(2,6,23,0.7);
  border-radius:12px;
}

/* Reduce visual footprint on very small screens */
@media (max-width:480px){
  .admin-btn{top:8px;right:8px;width:40px;height:40px}
  .editor-inner{padding:12px}
  .editor-actions .btn{min-width:100%}
}
.modal input:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.2),0 0 0 3px rgba(59,203,154,0.15);
}
.modal .row{display:flex;gap:12px}
.modal .btn{flex:1}
.editor-panel{
  position:fixed;
  inset:60px 0 0 0;
  z-index:150;
  pointer-events:none;
  background:var(--bg-primary);
}
.editor-inner{
  background:var(--surface);
  border-radius:0;
  border:none;
  padding:0;
  pointer-events:auto;
  max-height:100%;
  overflow-y:auto;
  box-shadow:none;
  display:flex;
  flex-direction:column;
  height:100%;
  animation:none;
}
.editor-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px;
  border-bottom:1px solid var(--border-subtle);
  flex-shrink:0;
  gap:16px;
}
.editor-inner h3{
  margin:0;
  font-size:18px;
  color:var(--text-primary);
  font-weight:700;
  flex:1;
}
.btn-close{
  background:transparent;
  border:1px solid var(--border-default);
  color:var(--text-secondary);
  width:40px;
  height:40px;
  padding:0;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-size:20px;
  transition:all 0.2s ease;
  display:flex;
  align-items:center;
  justify-content:center;
}
.btn-close:hover{
  background:var(--surface-hover);
  border-color:var(--danger);
  color:var(--danger);
}
.editor-fields{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:20px;
  padding:24px;
  flex:1;
  overflow-y:auto;
}
.editor-fields label{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:14px;
  color:var(--text-primary);
  font-weight:500;
}
.editor-fields select{
  background:var(--bg-secondary);
  border:1px solid var(--border-default);
  color:var(--text-primary);
  padding:10px 12px;
  border-radius:var(--radius-sm);
  font-size:14px;
  cursor:pointer;
  transition:all 0.2s ease;
}
.editor-fields select:hover{
  border-color:var(--accent);
}
.editor-fields select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(59,203,154,0.1);
}
@media(max-width:900px){.editor-fields{grid-template-columns:1fr}}
.editor-actions{
  display:flex;
  gap:12px;
  padding:20px 24px;
  border-top:1px solid var(--border-subtle);
  flex-shrink:0;
  background:var(--bg-secondary);
}
.editor-actions .btn{
  flex:1;
  min-width:0;
}
.editor-inner::-webkit-scrollbar{width:10px}
.editor-inner::-webkit-scrollbar-track{background:transparent}
.editor-inner::-webkit-scrollbar-thumb{
  background:rgba(59,203,154,0.3);
  border-radius:5px;
  border:2px solid var(--surface);
}
.editor-inner::-webkit-scrollbar-thumb:hover{background:rgba(59,203,154,0.4)}
.editor-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:16px;margin-bottom:20px}
@media(max-width:800px){.editor-fields{grid-template-columns:1fr}}
.editor-card{
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-md);
  padding:16px;
  transition:all 0.2s ease;
}
.editor-card:hover{
  background:rgba(255,255,255,0.04);
  border-color:var(--border-default);
}
.editor-title{
  font-weight:700;
  font-size:14px;
  margin-bottom:12px;
  color:var(--accent-light);
  text-transform:uppercase;
  letter-spacing:0.06em;
}
.editor-group{margin-bottom:10px;display:flex;flex-direction:column;gap:6px}
.editor-label{
  font-size:11px;
  color:var(--text-tertiary);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.05em;
}
.editor-select,.editor-input{
  width:100%;
  padding:8px 12px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border-default);
  background:var(--bg-secondary);
  color:var(--text-primary);
  font-size:13px;
  transition:all 0.2s ease;
}
.editor-select:focus,.editor-input:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(59,203,154,0.15);
}
.editor-actions{display:flex;gap:12px;align-items:center;margin-bottom:20px;flex-wrap:wrap}
.editor-actions .btn{flex:1;min-width:120px;padding:10px 16px;font-size:14px}
textarea{
  width:100%;
  background:var(--bg-secondary);
  border-radius:var(--radius-sm);
  border:1px solid var(--border-default);
  color:var(--text-primary);
  padding:12px;
  font-family:'SF Mono',Monaco,Consolas,'Courier New',monospace;
  font-size:12px;
  line-height:1.6;
  max-height:220px;
  resize:vertical;
  margin:12px 0;
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.2);
  transition:all 0.2s ease;
}
textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.2),0 0 0 3px rgba(59,203,154,0.15);
}
textarea::-webkit-scrollbar{width:8px}
textarea::-webkit-scrollbar-thumb{
  background:rgba(59,203,154,0.3);
  border-radius:4px;
}
.toast{
  position:fixed;
  right:24px;
  top:24px;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);
  color:white;
  padding:14px 20px;
  border-radius:var(--radius-md);
  border:1px solid rgba(59,203,154,0.4);
  z-index:1000;
  box-shadow:var(--shadow-accent);
  opacity:0;
  transform:translateY(-16px) scale(0.95);
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  pointer-events:none;
  font-weight:600;
  font-size:14px;
  display:flex;
  align-items:center;
  gap:8px;
}
.toast::before{
  content:'✓';
  font-size:16px;
  font-weight:700;
}
.toast.show{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.hidden{display:none !important}

/* Floating logout button */
.logout-btn{
  position:fixed;
  bottom:32px;
  right:32px;
  background:linear-gradient(135deg,var(--danger) 0%,#e53935 100%);
  border:none;
  color:white;
  padding:12px 20px;
  border-radius:var(--radius-md);
  cursor:pointer;
  font-weight:700;
  font-size:14px;
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 4px 16px rgba(239,83,80,0.3);
  z-index:140;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.logout-btn::before{
  content:'🚪';
  font-size:16px;
}
.logout-btn:hover{
  background:linear-gradient(135deg,#e53935 0%,#d32f2f 100%);
  box-shadow:0 6px 24px rgba(239,83,80,0.4);
  transform:translateY(-2px);
}
.logout-btn:active{
  transform:translateY(0);
}

/* Editor panel should not block background scrolling */
.editor-panel{pointer-events:none}
.editor-panel .editor-inner{pointer-events:auto;max-height:75vh;overflow:auto}

.waiting-message{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-height:100%;
  padding:60px 24px;
  text-align:center;
  gap:24px;
}
.waiting-icon{
  font-size:80px;
  animation:bounce 2s ease-in-out infinite;
}
@keyframes bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-20px)}
}
.waiting-message h2{
  font-size:32px;
  color:var(--text-primary);
  margin:0;
  font-weight:700;
}
.waiting-message p{
  font-size:16px;
  color:var(--text-secondary);
  max-width:500px;
  margin:0;
  line-height:1.6;
}
.topbar .admin-btn{
  /* Place admin button inside the topbar (right-aligned by flex) */
  position:relative !important;
  top:auto !important;
  right:auto !important;
  z-index:60 !important;
  width:44px !important;
  height:44px !important;
  padding:8px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:10px !important;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.00));
  border:1px solid rgba(255,255,255,0.03) !important;
  box-shadow:var(--shadow-sm) !important;
  color:var(--text) !important;
}
.topbar .admin-btn:hover{transform:translateY(-2px)}

/* Minimal admin button overrides (strong, applied last) */
.admin-btn{background:transparent !important;border:none !important;box-shadow:none !important}
.admin-btn svg{width:18px;height:18px;display:block;color:var(--accent) !important}
.admin-btn.fixed-bottom{position:fixed !important;right:18px !important;bottom:18px !important;width:44px !important;height:44px !important;border-radius:999px !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;background:var(--panel) !important;border:1px solid rgba(255,255,255,0.03) !important;box-shadow:0 8px 20px rgba(2,6,23,0.45) !important}
@media(max-width:480px){.admin-btn.fixed-bottom{right:12px;bottom:12px;width:40px;height:40px}}


.whats-btn{
  background:linear-gradient(135deg,#25d366 0%,#20ba5a 100%);
  color:white;
  border:none;
  padding:16px 32px;
  font-size:16px;
  font-weight:600;
  border-radius:var(--radius-lg);
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:all 0.3s ease;
  margin-top:12px;
}
.whats-btn:hover{
  transform:scale(1.05);
  box-shadow:0 8px 24px rgba(37,211,102,0.35);
}
.whats-btn:active{
  transform:scale(0.98);
}

/* Responsive adjustments */
@media(max-width:600px){
  .topbar{padding:12px 16px}
  .container{padding:0 16px}
  .card{padding:16px}
  .segment{flex-direction:column;align-items:flex-start;gap:12px}
  .meta{width:100%}
  .row{width:100%;justify-content:stretch}
  .btn{flex:1}
  .editor-panel{inset:auto 16px 16px 16px;width:calc(100% - 32px)}
  .toast{right:16px;top:16px;left:16px}
  .logout-btn{bottom:24px;right:24px;padding:10px 16px;font-size:13px}
}

/* Strong default: keep editor panel hidden unless admin mode enabled */
#editorPanel, .editor-panel{display:none !important;visibility:hidden !important;pointer-events:none !important;opacity:0 !important}
.admin-active #editorPanel, .admin-active .editor-panel{display:block !important;visibility:visible !important;pointer-events:auto !important;opacity:1 !important}

/* Extra strong rule: when body does NOT have admin-active, ensure panel never shows (protect mobile) */
body:not(.admin-active) #editorPanel, body:not(.admin-active) .editor-panel{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
  opacity:0 !important;
}

