/* ═══ RESET & VARIABLES ═══════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  /* ── Brand Colors ── */
  --primary:#4CAF50; --primary-dark:#388E3C; --primary-light:#81C784;
  --primary-gradient:linear-gradient(135deg,#43A047,#66BB6A);
  --accent:#8BC34A;
  /* ── Compat aliases ── */
  --green:#4CAF50; --green-dark:#388E3C; --green-light:#E8F5E9; --green-mid:#C8E6C9;
  /* ── Surfaces ── */
  --text:#212121; --text-light:#757575; --text-secondary:#757575;
  --bg:#f1f5f9; --card:#FFFFFF; --card-elevated:#FAFAFA;
  --border:#E0E0E0; --border-light:#EEEEEE;
  /* ── Radius & Spacing ── */
  --radius:8px; --radius-sm:6px; --radius-md:8px; --radius-lg:12px; --radius-pill:9999px;
  --space-xs:4px; --space-sm:8px; --space-md:16px; --space-lg:24px; --space-xl:32px;
  /* ── Shadows ── */
  --shadow:0 1px 3px rgba(0,0,0,.08);
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow-md:0 4px 12px rgba(0,0,0,.1);
  --shadow-lg:0 8px 24px rgba(0,0,0,.12);
  --shadow-card:0 2px 8px rgba(0,0,0,.06);
  /* ── Semantic ── */
  --red:#EF4444; --amber:#FF9800; --blue:#2196F3; --purple:#8b5cf6;
  --success:#4CAF50; --warning:#FF9800; --danger:#EF4444; --info:#2196F3;
  /* ── Typography ── */
  --font-heading:'Baloo 2',sans-serif;
  --font-body:'Open Sans',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
}
/* ═══ TMAVÝ REŽIM — neutrální paleta (Notion/Linear/Apple style) ══ */
html[data-theme="dark"]{
  --bg:#111111; --card:#1c1c1c; --card-elevated:#242424; --border:#2c2c2c; --border-light:#333;
  --text:#efefef; --text-light:#888888; --text-secondary:#888;
  --bg2:#1f1f1f;
  --green-light:#0a2e1a; --green-mid:#14532d;
  --primary-gradient:linear-gradient(135deg,#2E7D32,#43A047);
  --shadow:0 1px 4px rgba(0,0,0,.5); --shadow-sm:0 1px 4px rgba(0,0,0,.5);
  --shadow-md:0 4px 16px rgba(0,0,0,.65); --shadow-lg:0 8px 32px rgba(0,0,0,.7);
  --shadow-card:0 2px 8px rgba(0,0,0,.4);
}
html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select{background:#1f1f1f!important;color:var(--text)!important;border-color:var(--border)!important}
html[data-theme="dark"] .section-card,
html[data-theme="dark"] .dash-card{background:var(--card)!important;border-color:var(--border)!important}
html[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.75)!important}
html[data-theme="dark"] .admin-modal-sheet,
html[data-theme="dark"] .modal-sheet{background:var(--card)!important;border-color:var(--border)!important}
html[data-theme="dark"] .fin-stat,
html[data-theme="dark"] .runner-stat{background:#1f1f1f!important}
html[data-theme="dark"] .task-status.in_progress{background:#1a2e1a!important;border-color:var(--green)!important}
html[data-theme="dark"] .task-tag{background:#2a2a18!important;color:#d4a20a!important}
html[data-theme="dark"] .fab-panel{background:var(--card)!important}
html[data-theme="dark"] .proj-card{background:var(--card)!important;border-color:var(--border)!important}
html[data-theme="dark"] .theme-name{color:var(--text)!important}
html[data-theme="dark"] .theme-count{color:var(--text-light)!important}
html[data-theme="dark"] .theme-card{border-color:var(--border)!important;background:var(--card)!important;border-left:3px solid var(--tc,var(--border))}
html[data-theme="dark"] .theme-name{color:var(--text)!important}
html[data-theme="dark"] .theme-count{color:var(--text-light)!important}
html[data-theme="dark"] .theme-panel{background:var(--card)!important}
html[data-theme="dark"] .theme-panel-header{background:var(--card)!important;border-color:var(--border)!important}
html[data-theme="dark"] .theme-panel-close{background:#1f1f1f!important;color:var(--text)!important}
html[data-theme="dark"] .td-project{background:#1f1f1f!important;border-left-color:var(--green)!important}
html[data-theme="dark"] .theme-detail-actions button{background:#1f1f1f!important;color:var(--text)!important}
html[data-theme="dark"] .tp-view-btn.active{background:#1a2e1a!important;color:#4ade80!important}
html[data-theme="dark"] .contact-picker{border-color:var(--border)!important;background:#1f1f1f!important}
html[data-theme="dark"] .contact-picker-search{background:#141414!important;color:var(--text)!important;border-color:var(--border)!important}
html[data-theme="dark"] .color-preset.active{border-color:var(--text)!important;box-shadow:0 0 0 2px #141414,0 0 0 4px var(--text)!important}
html[data-theme="dark"] .rq-panel{background:var(--card)!important}
html[data-theme="dark"] .rq-header{background:var(--card)!important}
html[data-theme="dark"] .rq-input,html[data-theme="dark"] .rq-textarea,html[data-theme="dark"] .rq-select{background:#1f1f1f!important;color:var(--text)!important;border-color:var(--border)!important}
html[data-theme="dark"] .rq-checkbox-item.checked{background:#1a2e1a!important;color:#4ade80!important;border-color:#166534!important}
html[data-theme="dark"] .qr-mini{background:var(--card)!important}
html[data-theme="dark"] .qr-runner-add{border-color:#4ade80;color:#4ade80}
html[data-theme="dark"] .qr-runner-add:hover{background:#4ade80;color:#111}
html[data-theme="dark"] .qr-mini-btn.secondary{background:#1f1f1f!important;color:var(--text)!important}
html[data-theme="dark"] .co-panel{background:var(--card)!important}
html[data-theme="dark"] .co-header{border-color:var(--border)!important}
html[data-theme="dark"] .co-header-close{background:#1f1f1f!important;color:var(--text)!important}
html[data-theme="dark"] .co-stat{background:#1f1f1f!important}
html[data-theme="dark"] .co-table th{background:#1f1f1f!important}
html[data-theme="dark"] .co-table tr:hover td{background:#1f1f1f!important}
html[data-theme="dark"] .co-filter-btn{background:#1f1f1f!important;border-color:var(--border)!important;color:var(--text)!important}
html[data-theme="dark"] .co-filter-btn.active{background:var(--green)!important;color:white!important;border-color:var(--green)!important}
html[data-theme="dark"] .co-badge.nova{background:#1e3a5f!important;color:#93c5fd!important}
html[data-theme="dark"] .co-badge.vyroba{background:#422006!important;color:#fcd34d!important}
html[data-theme="dark"] .co-badge.faktura{background:#2e1065!important;color:#d8b4fe!important}
html[data-theme="dark"] .co-badge.hotovo{background:#052e16!important;color:#86efac!important}
html[data-theme="dark"] .co-badge.placeno{background:#022c22!important;color:#6ee7b7!important}
html[data-theme="dark"] .co-badge.pay-ne{background:#450a0a!important;color:#fca5a5!important}
html[data-theme="dark"] .co-badge.pay-ano{background:#052e16!important;color:#86efac!important}
html[data-theme="dark"] .co-badge.pay-fakt{background:#422006!important;color:#fcd34d!important}
html[data-theme="dark"] .rte-wrap{border-color:var(--border)!important;background:#1f1f1f!important}
html[data-theme="dark"] .rte-toolbar{background:var(--card)!important;border-color:var(--border)!important}
html[data-theme="dark"] .rte-btn{color:var(--text)!important}
html[data-theme="dark"] .rte-btn.active{background:#1a2e1a!important;color:#4ade80!important}
html[data-theme="dark"] .rte-body{color:var(--text)!important}
html[data-theme="dark"] .rte-color-dropdown{background:var(--card)!important;border-color:var(--border)!important}
/* ═══════════════════════════════════════════════════════════════════ */

body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:800}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}

/* ═══ LOADING & AUTH SCREENS ══════════════════════════════════════ */
#loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;flex-direction:column;gap:12px}
#loading-screen .spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
#auth-error{display:none;text-align:center;padding:60px 24px}
#dashboard{display:none}

/* ═══ HEADER ══════════════════════════════════════════════════════ */
.header{
  background:var(--card);border-bottom:1px solid var(--border);
  padding:12px 20px;padding-top:calc(12px + env(safe-area-inset-top, 0px));
  display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100;
}
.header-logo{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--text);white-space:nowrap}
.header-logo span{color:var(--text-light);font-weight:700;font-size:14px;margin-left:6px}
.app-switcher{cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s}
.app-switcher:hover{background:var(--bg)}
.app-switch-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:1100;min-width:220px;overflow:hidden}
.app-switch-menu.open{display:block}
.app-switch-item{display:flex;align-items:center;gap:6px;padding:12px 16px;font-size:14px;font-weight:600;color:var(--text);text-decoration:none;transition:background .12s;font-family:var(--font-heading);border-bottom:1px solid var(--border)}
.app-switch-item:last-child{border-bottom:none}
.app-switch-item:hover{background:var(--bg)}
.app-switch-item.active{background:var(--green-light);color:var(--green-dark)}
.app-switch-item span{font-size:11px;font-weight:400;color:var(--text-light);margin-left:auto}
.header-spacer{flex:1}
.header-btn{
  background:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:7px 14px;font-size:13px;font-weight:600;color:var(--text-light);
  display:flex;align-items:center;gap:5px;transition:all .15s;white-space:nowrap;
}
.header-btn:hover{border-color:var(--green);color:var(--green)}
.header-btn-icon{
  background:none;border:none;padding:6px 8px;font-size:18px;cursor:pointer;
  color:var(--text-light);border-radius:8px;transition:background .15s;
}
.header-btn-icon:hover{background:var(--border)}
.google-connected #google-status-btn{background:var(--green-light);color:var(--green)}
/* Tlačítka co potřebují gcal connect — viditelná jen když je gcal zelený */
.tcal-gcal-sync-btn{display:none !important}
.google-connected .tcal-gcal-sync-btn{display:inline-flex !important}

/* ═══ QUICK ACTIONS ═══════════════════════════════════════════════ */
.quick-actions{
  display:flex;gap:8px;padding:16px 20px 8px;overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.quick-actions::-webkit-scrollbar{display:none}
.qa-btn{
  flex-shrink:0;display:flex;align-items:center;gap:6px;
  padding:9px 16px;border-radius:24px;border:1.5px solid var(--border);
  background:var(--card);font-size:13px;font-weight:600;color:var(--text);
  transition:all .15s;white-space:nowrap;
}
.qa-btn:active{transform:scale(.96);border-color:var(--green);background:var(--green-light)}
.qa-btn .qa-icon{font-size:16px}

/* ═══ UNIFIED NAV ══════════════════════════════════════════════ */
.admin-nav{display:flex;gap:6px;padding:8px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:calc(46px + env(safe-area-inset-top,0px));z-index:101}
.admin-nav::-webkit-scrollbar{display:none}
.nav-pill{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:var(--text-light);background:var(--card);border:1px solid var(--border);text-decoration:none;white-space:nowrap;transition:all .15s;font-family:var(--font-body)}
.nav-pill:hover{border-color:var(--primary);color:var(--primary)}
.nav-pill.active{color:white;background:var(--primary);border-color:var(--primary)}

/* ═══ KPI BAR ════════════════════════════════════════════════════ */
.kpi-bar{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.kpi-group{display:flex;flex-direction:column;gap:8px}
.kpi-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);padding-left:2px}
.kpi-group-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-card);transition:box-shadow .2s,transform .2s}
.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.kpi-icon{font-size:24px;line-height:1;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--card-elevated);flex-shrink:0}
.kpi-val{font-size:24px;font-weight:800;color:var(--text);font-family:var(--font-heading);letter-spacing:-0.03em}
.kpi-lbl{font-size:11px;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
@media(max-width:767px){.kpi-bar{grid-template-columns:1fr}.kpi-group-cards{grid-template-columns:1fr 1fr}.kpi-val{font-size:20px}.kpi-icon{width:36px;height:36px;font-size:20px}}

/* ═══ DASHBOARD GRID ══════════════════════════════════════════════ */
.dash-container{max-width:1280px;margin:0 auto;padding:16px 20px 80px}
.dash-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:1000px){.dash-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}}

/* Dashboard card ordering — logické seskupení */
#card-finance    { order: 1; }
#card-invoices   { order: 2; }
#card-runners    { order: 3; }
#card-camp       { order: 4; }
#card-orders     { order: 5; }
/* Order tabs */
.ord-tab{padding:8px 12px;border:none;background:transparent;font-size:12px;font-weight:700;color:var(--text-light);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:color .15s;white-space:nowrap}
.ord-tab.active{color:var(--green);border-bottom-color:var(--green)}
.ord-tab:hover:not(.active){color:var(--text)}
/* Order card items */
.ord-card{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.ord-card:hover{background:var(--bg)}
.ord-card-actions{display:flex;gap:4px;flex-shrink:0}
.ord-card-actions button{font-size:11px;padding:3px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-weight:600;transition:all .12s}
.ord-card-actions button:hover{border-color:var(--green);color:var(--green)}
.ord-stat{background:var(--bg);border-radius:10px;padding:8px 14px;text-align:center;min-width:80px}
.ord-stat-val{font-size:18px;font-weight:800}
.ord-stat-lbl{font-size:10px;font-weight:600;color:var(--text-light);text-transform:uppercase;margin-top:2px}
#card-pages      { order: 6; }
#card-webpages   { order: 7; }
#card-resources  { order: 8; }
#card-time       { order: 9; }
#card-calc       { order: 10; }
#card-reviews    { order: 11; }
#card-questionnaires { order: 12; }
#card-library    { order: 13; }

/* ═══ DESKTOP SIDEBAR ═════════════════════════════════════════════ */
.desktop-sidebar{display:none}
@media(min-width:1000px){
  .dash-container{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start;max-width:1200px}
  .desktop-sidebar{display:flex;flex-direction:column;gap:4px;position:sticky;top:72px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 8px;box-shadow:var(--shadow-card)}
  .fab-btn,.fab-overlay{display:none!important}
  .co-table{min-width:auto}
}
@media(min-width:1400px){
  .dash-container{grid-template-columns:240px 1fr;gap:28px}
}
.ds-title{font-size:10px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:1px;padding:4px 8px 6px;font-family:var(--font-heading)}
.ds-btn{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:8px 12px;background:transparent;border:none;
  border-radius:var(--radius-sm);font-size:13px;font-weight:500;
  color:var(--text);text-align:left;cursor:pointer;transition:all .15s;
  border-left:3px solid transparent;
}
.ds-btn:hover{background:rgba(76,175,80,.06);color:var(--primary-dark)}
.ds-btn.active{border-left-color:var(--primary);background:rgba(76,175,80,.08);color:var(--primary-dark);font-weight:600}
.ds-sep{height:1px;background:var(--border);margin:4px 0}
.ds-btn.ds-danger{color:#ef4444}
.qa-item{display:flex!important;align-items:center;gap:6px;position:relative}
.qa-handle{cursor:grab;color:var(--text-light);font-size:13px;flex-shrink:0;opacity:.5;transition:opacity .15s}
.qa-handle:active{cursor:grabbing}
.qa-item:hover .qa-handle{opacity:1;color:var(--green)}
.qa-item.qa-dragging{opacity:.35}
.qa-item.qa-over{border-top:2px solid var(--green)}
.qa-group{margin-bottom:4px}
.qa-group-title{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.7px;padding:10px 4px 4px;cursor:pointer;user-select:none;transition:color .15s}
.qa-group-title:hover{color:var(--green)}
.qa-group:first-child .qa-group-title{padding-top:2px}
.qa-toggle{font-size:8px;transition:transform .25s ease;display:inline-block}
.qa-group.collapsed .qa-toggle{transform:rotate(-90deg)}
.qa-group-items{display:flex;flex-direction:column;gap:3px;overflow:hidden;transition:max-height .3s ease,opacity .25s ease;max-height:600px;opacity:1;padding-left:2px}
.qa-group.collapsed .qa-group-items{max-height:0;opacity:0;pointer-events:none}
.qa-fav-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:11px;cursor:pointer;opacity:0;transition:opacity .15s;padding:2px 4px;line-height:1}
.qa-item:hover .qa-fav-btn{opacity:.5}
.qa-fav-btn:hover{opacity:1!important}
.qa-fav-btn.active{opacity:1!important}

/* ── Trash / Koš modal ── */
.trash-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.trash-item:last-child{border-bottom:none}
.trash-icon{font-size:20px;flex-shrink:0}
.trash-info{flex:1;min-width:0}
.trash-label{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trash-meta{font-size:12px;color:var(--text-light);margin-top:2px;text-transform:capitalize}
.trash-restore{flex-shrink:0;background:none;border:1px solid var(--border);border-radius:8px;padding:4px 10px;cursor:pointer;color:var(--text-light);font-size:16px;transition:color .15s,border-color .15s}
.trash-restore:hover{color:var(--green);border-color:var(--green)}
.ds-btn.ds-danger:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626}
.ds-btn.ds-timer{color:var(--green)}
.ds-btn.ds-timer:hover{background:var(--green-light);border-color:var(--green-mid)}

/* ═══ CARDS ═══════════════════════════════════════════════════════ */
.dash-card{
  background:var(--card);border-radius:var(--radius-md);border:1px solid var(--border);
  overflow:hidden;box-shadow:var(--shadow-card);transition:box-shadow .2s;
}
.dash-card:hover{box-shadow:var(--shadow-md)}
.card-link{cursor:pointer}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px 12px;border-bottom:1px solid var(--border-light);
}
.card-title{font-family:var(--font-heading);font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;letter-spacing:-0.01em}
.card-badge{font-size:11px;font-weight:600;background:var(--green-light);color:var(--primary-dark);padding:3px 10px;border-radius:var(--radius-pill);font-family:var(--font-mono)}
.card-action{
  font-size:12px;font-weight:600;color:var(--primary);cursor:pointer;
  border:none;background:none;padding:4px 10px;border-radius:var(--radius-sm);transition:background .15s;
}
.card-action:hover{background:var(--green-light)}
.card-body{padding:14px 20px 18px;min-height:60px}
.card-empty{text-align:center;padding:32px 24px;color:var(--text-light);font-size:14px}
.card-full{grid-column:1/-1}

/* ═══ LIBRARY ═════════════════════════════════════════════════════ */
.lib-categories{display:flex;gap:6px;overflow-x:auto;padding-bottom:12px;-webkit-overflow-scrolling:touch}
.lib-categories::-webkit-scrollbar{display:none}
.lib-cat-btn{
  flex-shrink:0;padding:6px 14px;border-radius:20px;
  border:1.5px solid var(--border);background:var(--bg);
  font-size:12px;font-weight:600;cursor:pointer;
  white-space:nowrap;transition:all .15s;
  display:flex;align-items:center;gap:4px;color:var(--text);
}
.lib-cat-btn:hover{border-color:var(--green)}
.lib-cat-btn.active{background:var(--green);color:white;border-color:var(--green)}
.lib-cat-count{font-size:11px;opacity:.7}
.lib-item{
  display:flex;align-items:center;gap:12px;padding:10px 0;
  border-bottom:1px solid var(--border);
}
.lib-item:last-child{border-bottom:none}
.lib-item-icon{font-size:22px;flex-shrink:0}
.lib-item-info{flex:1;min-width:0}
.lib-item-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lib-item-meta{font-size:12px;color:var(--text-light);margin-top:2px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.lib-meta-badge{display:inline-block;padding:1px 7px;border-radius:12px;font-size:11px;font-weight:600;border:1px solid var(--border);background:var(--bg)}
.lib-item-actions{display:flex;gap:2px;flex-shrink:0}
.lib-item-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:6px;color:var(--text-light);border-radius:8px;transition:background .15s}
.lib-item-btn:hover{background:var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}

/* ═══ INBOX ITEMS ═════════════════════════════════════════════════ */
.inbox-item{
  display:flex;align-items:center;gap:10px;padding:9px 0;
  border-bottom:1px solid #f1f5f9;transition:opacity .2s;
}
.inbox-item:last-child{border-bottom:none}
.inbox-check{
  width:20px;height:20px;border:2px solid var(--border);border-radius:50%;
  cursor:pointer;flex-shrink:0;transition:all .15s;display:flex;align-items:center;justify-content:center;
  background:none;font-size:11px;color:transparent;
}
.inbox-check:hover{border-color:var(--green)}
.inbox-check.done{border-color:var(--green);background:var(--green);color:white}
.inbox-text{flex:1;font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;transition:color .15s}
.inbox-text:hover{color:var(--green)}
.inbox-text.done{text-decoration:line-through;color:var(--text-light)}
.inbox-del{background:none;border:none;font-size:14px;color:var(--text-light);padding:4px;opacity:0;transition:opacity .15s}
.inbox-item:hover .inbox-del{opacity:1}
.inbox-add{
  display:flex;gap:8px;padding:10px 0 0;border-top:1px solid var(--border);margin-top:4px;
}
.inbox-add input{
  flex:1;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-size:14px;outline:none;background:var(--bg);
}
.inbox-add input:focus{border-color:var(--green)}
.inbox-add button{
  padding:8px 14px;background:var(--green);color:white;border:none;border-radius:var(--radius-sm);
  font-weight:600;font-size:13px;white-space:nowrap;
}

/* ═══ TASK ITEMS ══════════════════════════════════════════════════ */
.task-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-light);padding:8px 0 4px;cursor:pointer;display:flex;align-items:center;gap:6px;user-select:none}
.task-group-label:hover{color:var(--green)}
.task-group-label .tg-arrow{transition:transform .2s;font-size:9px;display:inline-block}
.task-group-label.collapsed .tg-arrow{transform:rotate(-90deg)}
.task-group-items{overflow:hidden;transition:max-height .3s ease}
.task-group-items.collapsed{max-height:0!important;overflow:hidden}
.task-item{
  display:flex;align-items:center;gap:10px;padding:8px 0;
  border-bottom:1px solid #f1f5f9;
}
.task-item:last-child{border-bottom:none}
.task-status{
  width:22px;height:22px;border-radius:6px;border:2px solid var(--border);
  cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:none;font-size:12px;color:transparent;transition:all .15s;
}
.task-status.in_progress{border-color:var(--blue);background:#eff6ff;color:var(--blue)}
.task-status.done{border-color:var(--green);background:var(--green);color:white}
.task-info{flex:1;min-width:0}
.task-name{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.task-name.done{text-decoration:line-through;color:var(--text-light)}
.task-meta{font-size:11px;color:var(--text-light);margin-top:1px;display:flex;gap:8px;align-items:center}
.task-tag{
  font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;
  background:#fef3c7;color:#92400e;white-space:nowrap;
}
.task-due{font-size:11px;color:var(--text-light)}
.task-due.overdue{color:var(--red);font-weight:600}
.task-del{background:none;border:none;font-size:14px;color:var(--text-light);padding:4px;opacity:0;transition:opacity .15s}
.task-item:hover .task-del{opacity:1}

/* ═══ FINANCE ═════════════════════════════════════════════════════ */
.fin-row{display:flex;gap:12px;margin-bottom:16px}
.fin-stat{flex:1;text-align:center;padding:14px;border-radius:var(--radius-md);background:var(--card-elevated);border:1px solid var(--border-light)}
.fin-stat-val{font-family:var(--font-heading);font-size:22px;font-weight:800}
.fin-stat-val.income{color:var(--green)}
.fin-stat-val.expense{color:var(--red)}
.fin-stat-val.balance{color:var(--blue)}
.fin-stat-lbl{font-size:11px;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.fin-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--border);margin-bottom:14px}
.fin-bar-fill{height:100%;border-radius:4px;transition:width .5s}
.fin-entry{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid #f1f5f9;font-size:13px}
.fin-entry:last-child{border-bottom:none}
.fin-entry-date{color:var(--text-light);font-size:12px;flex-shrink:0;width:50px}
.fin-entry-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fin-entry-amt{font-weight:700;flex-shrink:0}
.fin-entry-amt.income{color:var(--green)}
.fin-entry-amt.expense{color:var(--red)}
.fin-entry-del{background:none;border:none;font-size:14px;color:var(--text-light);padding:2px 4px;opacity:0;transition:opacity .15s;flex-shrink:0;cursor:pointer;line-height:1}
.fin-entry:hover .fin-entry-del{opacity:1}
@media(max-width:600px){.fin-entry-del{opacity:.5;font-size:12px}}

/* ═══ RUNNERS ═════════════════════════════════════════════════════ */
.runner-stats{display:flex;gap:12px;margin-bottom:12px}
.runner-stat{flex:1;text-align:center;padding:10px;border-radius:var(--radius-sm);background:var(--bg)}
.runner-stat-val{font-family:var(--font-heading);font-size:24px;font-weight:800;color:var(--green-dark)}
.runner-stat-lbl{font-size:11px;color:var(--text-light);font-weight:600}
.runner-mini{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px}
.runner-mini-name{font-weight:600}
.runner-mini-info{color:var(--text-light);font-size:12px}

/* ═══ CAMP ════════════════════════════════════════════════════════ */
.camp-stats{display:flex;gap:12px;margin-bottom:12px}
.camp-stat{flex:1;text-align:center;padding:10px;border-radius:var(--radius-sm);background:var(--bg)}
.camp-stat-val{font-family:var(--font-heading);font-size:24px;font-weight:800;color:var(--green-dark)}
.camp-stat-lbl{font-size:11px;color:var(--text-light);font-weight:600}
.camp-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}
.camp-row:last-child{border-bottom:none}
.camp-name{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.camp-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap}
.camp-badge.paid{background:#dcfce7;color:#166534}
.camp-badge.unpaid{background:#fef3c7;color:#92400e}
.camp-badge.storno{background:#fee2e2;color:#991b1b}
.camp-badge.level-lip{background:#dbeafe;color:#1e40af}
.camp-badge.level-rak{background:#ffedd5;color:#9a3412}
.camp-badge.level-jel{background:#ede9fe;color:#5b21b6}
html[data-theme="dark"] .camp-stat{background:#1f1f1f!important}
html[data-theme="dark"] .camp-badge.paid{background:#052e16!important;color:#86efac!important}
html[data-theme="dark"] .camp-badge.unpaid{background:#422006!important;color:#fcd34d!important}
html[data-theme="dark"] .camp-badge.storno{background:#450a0a!important;color:#fca5a5!important}
html[data-theme="dark"] .camp-badge.level-lip{background:#1e3a5f!important;color:#93c5fd!important}
html[data-theme="dark"] .camp-badge.level-rak{background:#431407!important;color:#fdba74!important}
html[data-theme="dark"] .camp-badge.level-jel{background:#2e1065!important;color:#d8b4fe!important}

/* ═══ PROJECTS ════════════════════════════════════════════════════ */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.proj-card{
  padding:14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);
  background:var(--bg);cursor:pointer;transition:all .15s;
}
.proj-card:active{border-color:var(--green);background:var(--green-light)}
.proj-name{font-weight:700;font-size:14px;margin-bottom:4px}
.proj-owner{font-size:12px;color:var(--text-light);margin-bottom:8px}
.proj-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.proj-bar-fill{height:100%;background:var(--green);border-radius:3px;transition:width .4s}
.proj-pct{font-size:11px;color:var(--text-light);margin-top:4px;text-align:right}

/* ═══ THEMES ══════════════════════════════════════════════════════ */
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.theme-card{
  padding:14px 12px;border-radius:var(--radius);text-align:center;
  cursor:pointer;transition:all .15s;border:1.5px solid transparent;
}
.theme-card:active{transform:scale(.96)}
.theme-icon{font-size:28px;margin-bottom:4px}
.theme-name{font-size:13px;font-weight:700;color:rgba(0,0,0,.8)}
.theme-count{font-size:11px;color:rgba(0,0,0,.55);margin-top:2px}

/* Theme detail overlay panel — 3 view modes */
.theme-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s}
.theme-overlay.open{opacity:1;pointer-events:all}
.theme-panel{position:fixed;top:0;right:0;bottom:0;width:min(520px,100vw);background:var(--card);overflow-y:auto;transform:translateX(100%);transition:transform .3s ease,width .3s ease,left .3s ease,right .3s ease,top .3s ease,border-radius .3s ease;box-shadow:-4px 0 24px rgba(0,0,0,.12);display:flex;flex-direction:column;border-radius:0}
.theme-overlay.open .theme-panel{transform:translateX(0)}
.theme-overlay.mode-center{display:flex;align-items:center;justify-content:center}
.theme-overlay.mode-center .theme-panel{position:relative;top:auto;right:auto;bottom:auto;width:min(750px,95vw);max-height:90vh;border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.25);transform:translateY(30px) scale(.97)}
.theme-overlay.mode-center.open .theme-panel{transform:translateY(0) scale(1)}
.theme-overlay.mode-full{background:transparent}
.theme-overlay.mode-full .theme-panel{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;max-height:none;border-radius:0;box-shadow:none;transform:translateY(100%)}
.theme-overlay.mode-full.open .theme-panel{transform:translateY(0)}
.theme-panel-header{display:flex;align-items:center;gap:10px;padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top,0px));border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:1}
.theme-panel-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--hover);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.theme-panel-close:hover{background:var(--border)}
.tp-view-switcher{display:flex;gap:2px;margin-left:8px;flex-shrink:0}
.tp-view-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-light);transition:all .15s;font-size:12px}
.tp-view-btn:hover{border-color:var(--green);color:var(--green)}
.tp-view-btn.active{border-color:var(--green);background:#dcfce7;color:#166534}
.theme-panel-body{padding:20px;flex:1}

/* Theme detail view (inside panel) */
.theme-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.theme-detail-icon{font-size:28px}
.theme-detail-title{font-size:20px;font-weight:800;flex:1}
.theme-detail-actions{display:flex;gap:6px}
.theme-detail-actions button{background:var(--hover);border:none;padding:6px 10px;border-radius:8px;cursor:pointer;font-size:14px;transition:background .15s}
.theme-detail-actions button:hover{background:var(--border)}
.theme-detail-section{margin-bottom:24px}
.theme-detail-section-title{font-size:14px;font-weight:700;margin-bottom:10px;color:var(--text)}
.td-project{border-left:3px solid var(--green);padding:12px 16px;margin-bottom:10px;background:var(--hover);border-radius:0 var(--radius) var(--radius) 0}
.td-project-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:4px}
.td-project-name{font-weight:700;font-size:14px}
.td-project-meta{font-size:12px;color:var(--text-light);display:flex;gap:8px;align-items:center}
.td-project-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden;width:80px}
.td-project-bar-fill{height:100%;background:var(--green);border-radius:3px}
.td-task{display:flex;align-items:center;gap:8px;padding:6px 4px 6px 4px;font-size:13px;position:relative;border-radius:6px;transition:background .1s,box-shadow .15s}
.td-task:hover{background:var(--bg)}
.td-task.dragging{opacity:.4;background:var(--green-light)}
.td-task.drag-over{box-shadow:0 -2px 0 0 var(--green)}
.td-task-grip{cursor:grab;color:var(--text-light);font-size:12px;padding:2px 4px;flex-shrink:0;touch-action:none;user-select:none}
.td-task-grip:active{cursor:grabbing}
.td-task-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;cursor:pointer;flex-shrink:0;transition:all .15s;background:transparent}
.td-task-check.done{background:var(--green);border-color:var(--green);color:white}
.td-task-check.in_progress{border-color:var(--blue);color:var(--blue)}
.td-task-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.td-task-name.done{text-decoration:line-through;opacity:.5}
.td-task-meta{font-size:11px;color:var(--text-light);white-space:nowrap}
.td-task-overdue{color:#ef4444;font-weight:600}
.td-task-del{width:22px;height:22px;border:none;border-radius:4px;background:transparent;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;color:var(--text-light);transition:all .1s;padding:0;flex-shrink:0;opacity:0}
.td-task:hover .td-task-del{opacity:1}
.td-task-del:hover{background:var(--bg);color:var(--red)}
@media(max-width:768px){.td-task-del{opacity:1}}
.td-add-link{display:inline-block;margin-top:8px;font-size:13px;color:var(--green);font-weight:600;cursor:pointer;padding:4px 0}
.td-add-link:hover{text-decoration:underline}
.td-contact{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--hover);font-size:13px}
.td-contact:last-child{border-bottom:none}
.td-contact-name{font-weight:600;min-width:140px}
.td-contact-email{color:var(--text-light);flex:1}
.td-contact-phone{color:var(--text-light)}
.td-empty{font-size:13px;color:var(--text-light);padding:8px 0;font-style:italic}
.contact-picker{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);padding:8px;margin-top:4px}
.contact-picker-search{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;font-size:13px;box-sizing:border-box}
.contact-picker-item{display:flex;align-items:center;gap:8px;padding:5px 4px;font-size:13px;cursor:pointer;border-radius:6px}
.contact-picker-item:hover{background:var(--hover)}
.contact-picker-item input[type=checkbox]{margin:0}
/* Quick-add runner mini modal */
.qr-runner-row{display:flex;gap:8px;align-items:end}
.qr-runner-row .form-group{flex:1}
.qr-runner-add{width:42px;height:42px;border-radius:var(--radius-sm);border:1.5px dashed var(--green);background:none;color:var(--green);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.qr-runner-add:hover{background:var(--green);color:#fff;border-style:solid}
.qr-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:310;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.qr-overlay.open{opacity:1;pointer-events:all}
.qr-mini{width:min(420px,92vw);background:var(--card);border-radius:var(--radius);box-shadow:0 16px 48px rgba(0,0,0,.3);padding:24px;transform:translateY(20px) scale(.96);transition:transform .25s ease}
.qr-overlay.open .qr-mini{transform:translateY(0) scale(1)}
.qr-mini-title{font-size:16px;font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.qr-mini .form-group{margin-bottom:12px}
.qr-mini-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}
.qr-mini-btn{padding:8px 20px;border-radius:var(--radius-sm);border:none;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s}
.qr-mini-btn.primary{background:var(--green);color:#fff}
.qr-mini-btn.primary:hover{opacity:.85}
.qr-mini-btn.secondary{background:var(--hover);color:var(--text)}
.qr-mini-btn.secondary:hover{background:var(--border)}
/* Runner questionnaire overlay */
.rq-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s;display:flex;align-items:center;justify-content:center}
.rq-overlay.open{opacity:1;pointer-events:all}
.rq-panel{position:relative;width:min(680px,95vw);max-height:90vh;background:var(--card);border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.25);overflow-y:auto;transform:translateY(30px) scale(.97);transition:transform .3s ease}
.rq-overlay.open .rq-panel{transform:translateY(0) scale(1)}
.rq-header{display:flex;align-items:center;gap:12px;padding:20px 24px 0;padding-top:calc(20px + env(safe-area-inset-top,0px));position:sticky;top:0;background:var(--card);z-index:1;border-radius:var(--radius) var(--radius) 0 0}
.rq-header-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--hover);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}
.rq-header-close:hover{background:var(--border)}
.rq-title{font-size:18px;font-weight:800;flex:1}
.rq-body{padding:20px 24px 24px}
.rq-desc{font-size:13px;color:var(--text-light);margin-bottom:20px;line-height:1.5;font-style:italic}
.rq-section{font-size:14px;font-weight:700;margin:24px 0 10px;padding-top:16px;border-top:1px solid var(--border)}
.rq-section:first-of-type{border-top:none;margin-top:0;padding-top:0}
.rq-field{margin-bottom:14px}
.rq-label{font-size:13px;font-weight:600;margin-bottom:4px;display:block}
.rq-label .rq-req{color:#ef4444}
.rq-hint{font-size:11px;color:var(--text-light);margin-bottom:4px;display:block}
.rq-input,.rq-textarea,.rq-select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;box-sizing:border-box;background:white;color:var(--text)}
.rq-textarea{resize:vertical;min-height:60px}
.rq-select{appearance:auto}
.rq-checkbox-group{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.rq-checkbox-item{display:flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px;cursor:pointer;transition:all .15s}
.rq-checkbox-item:hover{border-color:var(--green)}
.rq-checkbox-item.checked{background:#dcfce7;border-color:var(--green);color:#166534}
.rq-checkbox-item input{display:none}
.rq-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:500px){.rq-row{grid-template-columns:1fr}}
.rq-submit{background:var(--green);color:white;border:none;padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;margin-top:20px;width:100%;transition:opacity .15s}
.rq-submit:hover{opacity:.9}
.rq-submit:disabled{opacity:.5;cursor:not-allowed}

/* ═══ CLOTHING ORDERS ═════════════════════════════════════════════ */
.co-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s;display:flex;align-items:center;justify-content:center}
.co-overlay.open{opacity:1;pointer-events:all}
.co-panel{position:relative;width:min(1100px,98vw);max-height:95vh;background:var(--card);border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.25);overflow:hidden;transform:translateY(30px) scale(.97);transition:transform .3s ease;display:flex;flex-direction:column}
.co-overlay.open .co-panel{transform:translateY(0) scale(1)}
.co-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.co-header-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--bg);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.co-header-close:hover{background:var(--border)}
.co-header-title{font-size:18px;font-weight:800;flex:1}
.co-header-actions{display:flex;gap:8px;align-items:center}
.co-header-btn{background:var(--green);color:white;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.co-header-btn:hover{opacity:.9}
.co-stats{display:flex;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}
.co-stat{text-align:center;padding:8px 16px;background:var(--bg);border-radius:var(--radius-sm);flex:1;min-width:80px}
.co-stat-val{font-family:var(--font-heading);font-size:18px;font-weight:800}
.co-stat-lbl{font-size:10px;color:var(--text-light);font-weight:600;text-transform:uppercase}
.co-filters{display:flex;gap:6px;padding:10px 20px;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}
.co-filter-btn{flex-shrink:0;padding:5px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;color:var(--text)}
.co-filter-btn:hover{border-color:var(--green)}
.co-filter-btn.active{background:var(--green);color:white;border-color:var(--green)}
.co-table-wrap{overflow:auto;flex:1;padding:0}
.co-table{width:100%;border-collapse:collapse;font-size:13px;min-width:900px}
.co-table th{position:sticky;top:0;background:var(--bg);padding:8px 12px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--text-light);border-bottom:1px solid var(--border);white-space:nowrap;z-index:1}
.co-table td{padding:8px 12px;border-bottom:1px solid var(--border);white-space:nowrap;vertical-align:middle}
.co-table tr:hover td{background:var(--bg)}
.co-table tr{cursor:pointer;transition:background .1s}
.co-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;white-space:nowrap}
.co-badge.nova{background:#dbeafe;color:#1d4ed8}
.co-badge.vyroba{background:#fef3c7;color:#92400e}
.co-badge.faktura{background:#fae8ff;color:#7c3aed}
.co-badge.hotovo{background:#dcfce7;color:#166534}
.co-badge.placeno{background:#d1fae5;color:#065f46}
.co-badge.pay-ne{background:#fee2e2;color:#991b1b}
.co-badge.pay-ano{background:#dcfce7;color:#166534}
.co-badge.pay-fakt{background:#fef3c7;color:#92400e}
.co-empty{text-align:center;padding:40px;color:var(--text-light);font-size:14px}
@media(max-width:767px){.co-panel{width:100vw;max-height:100vh;border-radius:0}.co-stats{flex-wrap:wrap}.co-stat{min-width:70px}}

.color-presets{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.color-preset{width:28px;height:28px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .15s}
.color-preset:hover{transform:scale(1.15)}
.color-preset.active{border-color:var(--text);box-shadow:0 0 0 2px white,0 0 0 4px var(--text)}

/* ═══ RICH TEXT EDITOR ════════════════════════════════════════════ */
.rte-wrap{border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg);transition:border-color .15s}
.rte-wrap:focus-within{border-color:var(--green)}
.rte-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px 8px;border-bottom:1px solid var(--border);background:var(--card)}
.rte-btn{width:30px;height:28px;border:none;background:none;border-radius:4px;cursor:pointer;font-size:13px;color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .12s;flex-shrink:0}
.rte-btn:hover{background:var(--border)}
.rte-btn.active{background:var(--green-light);color:var(--green-dark)}
.rte-sep{width:1px;height:20px;background:var(--border);margin:4px 4px;flex-shrink:0}
.rte-color-picker{position:relative;display:inline-flex}
.rte-color-btn{width:30px;height:28px;border:none;background:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;position:relative;transition:background .12s}
.rte-color-btn:hover{background:var(--border)}
.rte-color-btn .rte-color-bar{position:absolute;bottom:3px;left:6px;right:6px;height:3px;border-radius:2px}
.rte-color-dropdown{display:none;position:absolute;top:100%;left:0;z-index:10;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:6px;box-shadow:var(--shadow-md);flex-wrap:wrap;gap:3px;width:160px}
.rte-color-dropdown.show{display:flex}
.rte-color-swatch{width:22px;height:22px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform .12s}
.rte-color-swatch:hover{transform:scale(1.2)}
.rte-color-swatch.active{border-color:var(--text)}
.rte-body{min-height:200px;max-height:500px;overflow-y:auto;padding:12px 14px;font-size:14px;line-height:1.6;outline:none;color:var(--text)}
.rte-body:empty::before{content:attr(data-placeholder);color:var(--text-light);pointer-events:none}
.rte-body ul,.rte-body ol{padding-left:24px;margin:4px 0}
.rte-body li{margin:2px 0}
.rte-body h3{font-family:var(--font-heading);font-size:16px;margin:8px 0 4px}
.rte-body blockquote{border-left:3px solid var(--green);padding-left:12px;margin:6px 0;color:var(--text-light);font-style:italic}

/* ═══ MODALS ══════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:flex-end;justify-content:center;z-index:200;
  opacity:0;pointer-events:none;transition:opacity .2s ease;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-sheet{
  background:var(--card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:0;width:100%;max-width:520px;
  transform:translateY(100%) scale(.98);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:85vh;overflow-y:auto;
}
.modal-overlay.open .modal-sheet{transform:translateY(0) scale(1)}
@media(min-width:768px){
  .modal-overlay{align-items:center}
  .modal-sheet{border-radius:var(--radius-lg);max-height:80vh;box-shadow:var(--shadow-lg)}
  .modal-overlay.open .modal-sheet{transform:translateY(0) scale(1)}
  .modal-sheet{transform:translateY(20px) scale(.95)}
  .modal-handle{display:none}
}
.modal-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:12px auto 16px}
.modal-inner{padding:0 24px 32px}
.modal-title{font-family:var(--font-heading);font-size:18px;font-weight:700;margin-bottom:16px;letter-spacing:-0.02em}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-light);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.form-input{
  width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-size:14px;outline:none;background:var(--bg);transition:border-color .15s,box-shadow .15s;height:40px;
}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(76,175,80,.15)}
textarea.form-input{resize:vertical;min-height:70px;height:auto}
select.form-input{appearance:auto}
.form-row{display:flex;gap:12px}
.form-row .form-group{flex:1;min-width:0}
@media(max-width:400px){.form-row{flex-direction:column;gap:0}}
.btn-submit{
  width:100%;padding:12px;background:var(--primary);color:white;border:none;
  border-radius:var(--radius-sm);font-size:15px;font-weight:600;margin-top:8px;height:44px;
  font-family:var(--font-body);transition:background .15s,transform .1s;
  transition:opacity .15s;
}
.btn-submit:active{opacity:.85}

/* ═══ COACHING ═══════════════════════════════════════════════════ */
.cm-day-btn{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;border:1.5px solid var(--border);background:var(--bg);color:var(--text-light);cursor:pointer;transition:all .15s}
.cm-day-btn.active{border-color:var(--green);background:var(--green-light);color:var(--green-dark);font-weight:700}
html[data-theme="dark"] .cm-day-btn.active{background:rgba(22,163,74,.15);color:#4ade80;border-color:#4ade80}
.co-sort-btn.active{border-color:var(--green)!important;background:var(--green-light)!important;color:var(--green-dark)!important}
html[data-theme="dark"] .co-sort-btn.active{background:rgba(22,163,74,.15)!important;color:#4ade80!important;border-color:#4ade80!important}
.co-client-row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.co-client-row:hover{background:var(--bg)}
.co-client-row:last-child{border-bottom:none}
.co-avatar{width:36px;height:36px;border-radius:50%;background:var(--green-light);color:var(--green);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
html[data-theme="dark"] .co-avatar{background:#052e16;color:#4ade80}

/* ═══ TOAST ═══════════════════════════════════════════════════════ */
.toast{
  position:fixed;top:20px;right:20px;transform:translateX(120%);
  background:var(--card);color:var(--text);padding:12px 20px;border-radius:var(--radius-md);
  font-size:14px;font-weight:500;z-index:999;transition:transform .3s cubic-bezier(.32,.72,0,1);
  white-space:nowrap;box-shadow:var(--shadow-lg);border:1px solid var(--border);
  display:flex;align-items:center;gap:8px;max-width:380px;
}
.toast.show{transform:translateX(0)}
.toast.toast-success{border-left:3px solid var(--success)}
.toast.toast-error{border-left:3px solid var(--danger)}
.toast.toast-warning{border-left:3px solid var(--warning)}
.toast.toast-info{border-left:3px solid var(--info)}
@media(max-width:767px){.toast{top:auto;bottom:24px;right:auto;left:50%;transform:translateX(-50%) translateY(80px)}.toast.show{transform:translateX(-50%) translateY(0)}}

/* ═══ UTILITIES ═══════════════════════════════════════════════════ */
.hidden{display:none!important}
@media(max-width:767px){.hide-mobile{display:none!important}}
.desktop-only{display:none}
@media(min-width:1000px){.desktop-only{display:revert}}

/* ═══ FAB ═════════════════════════════════════════════════════════ */
.fab-btn{
  position:fixed;bottom:24px;right:20px;z-index:200;
  width:56px;height:56px;border-radius:50%;
  background:var(--green);color:white;border:none;
  font-size:26px;font-weight:300;
  box-shadow:0 4px 16px rgba(22,163,74,.45);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s,background .2s;
}
.fab-btn.open{transform:rotate(45deg);background:#ef4444;box-shadow:0 4px 16px rgba(239,68,68,.4)}
.fab-btn:active{transform:scale(.9)}
.fab-overlay{
  position:fixed;inset:0;z-index:190;
  background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .25s;
}
.fab-overlay.open{opacity:1;pointer-events:all}
.fab-panel{
  position:fixed;bottom:0;left:0;right:0;z-index:195;
  background:var(--card);border-radius:20px 20px 0 0;
  padding-bottom:env(safe-area-inset-bottom,16px);
  transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  max-height:90vh;overflow-y:auto;
}
.fab-panel.open{transform:translateY(0)}
.fab-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:12px auto 4px}
.fab-panel-title{font-family:var(--font-heading);font-size:12px;font-weight:800;padding:6px 20px 2px;color:var(--text-light);text-transform:uppercase;letter-spacing:.6px}
.fab-action{
  display:flex;align-items:center;gap:14px;
  width:100%;padding:14px 20px;background:none;border:none;border-top:1px solid var(--border);
  font-size:15px;font-weight:600;color:var(--text);text-align:left;transition:background .12s;
}
.fab-action:hover,.fab-action:active{background:var(--bg)}
html[data-theme="dark"] .fab-action:hover,html[data-theme="dark"] .fab-action:active{background:#1e293b}
.fab-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0}
.fab-action.fab-danger{color:#ef4444}
.fab-action.fab-running{color:var(--green)}
.fab-qa-handle{cursor:grab;font-size:14px;opacity:.35;flex-shrink:0;transition:opacity .15s;padding:2px 6px 2px 0;touch-action:none}
.fab-qa-handle:active{cursor:grabbing}
.fab-qa-item:hover .fab-qa-handle,.fab-qa-item:active .fab-qa-handle{opacity:.8}
.fab-qa-item.qa-dragging{opacity:.3}
.fab-qa-item.qa-over{border-top:2px solid var(--green)!important}
.dash-card.card-link{cursor:pointer;transition:box-shadow .15s}
.dash-card.card-link:hover{box-shadow:0 4px 24px rgba(0,0,0,.12)}

/* ═══ RESOURCES ═══════════════════════════════════════════════════ */
.resource-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.resource-item:last-child{border-bottom:none}
.resource-link{font-size:14px;color:var(--green);text-decoration:none;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.resource-link:hover{text-decoration:underline}
.resource-note{font-size:12px;color:var(--text-light);flex-shrink:0;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.resource-del{background:none;border:none;font-size:14px;color:var(--text-light);padding:4px;opacity:0;transition:opacity .15s;flex-shrink:0}
.resource-item:hover .resource-del{opacity:1}

/* ═══ PAGES (rich-text stránky) ═══════════════════════════════════ */
.page-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.page-item:last-child{border-bottom:none}
.page-item:hover{background:var(--bg);border-radius:6px;margin:0 -6px;padding:10px 6px}
.page-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0}
.page-info{flex:1;min-width:0}
.page-title{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.page-meta{font-size:11px;color:var(--text-light);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}
.page-del{background:none;border:none;font-size:14px;color:var(--text-light);padding:4px;opacity:0;transition:opacity .15s;flex-shrink:0;cursor:pointer}
.page-item:hover .page-del{opacity:1}

/* Page editor overlay — kopie theme-panel patterns */
.page-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s}
.page-overlay.open{opacity:1;pointer-events:all}
.page-panel{position:fixed;top:0;right:0;bottom:0;width:min(620px,100vw);background:var(--card);overflow-y:auto;transform:translateX(100%);transition:transform .3s ease,width .3s ease,left .3s ease,right .3s ease,top .3s ease,border-radius .3s ease;box-shadow:-4px 0 24px rgba(0,0,0,.12);display:flex;flex-direction:column;border-radius:0}
.page-overlay.open .page-panel{transform:translateX(0)}
.page-overlay.mode-center{display:flex;align-items:center;justify-content:center}
.page-overlay.mode-center .page-panel{position:relative;top:auto;right:auto;bottom:auto;width:min(800px,95vw);max-height:90vh;border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.25);transform:translateY(30px) scale(.97)}
.page-overlay.mode-center.open .page-panel{transform:translateY(0) scale(1)}
.page-overlay.mode-full{background:transparent}
.page-overlay.mode-full .page-panel{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;max-height:none;border-radius:0;box-shadow:none;transform:translateY(100%)}
.page-overlay.mode-full.open .page-panel{transform:translateY(0)}
.page-panel-header{display:flex;align-items:center;gap:10px;padding:12px 20px;padding-top:calc(12px + env(safe-area-inset-top,0px));border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:1;flex-shrink:0}
.page-panel-body{padding:0;flex:1;display:flex;flex-direction:column}
.page-title-input{border:none;outline:none;font-size:22px;font-weight:800;font-family:var(--font-heading);padding:20px 20px 8px;background:transparent;width:100%;color:var(--text)}
.page-title-input::placeholder{color:var(--text-light);opacity:.5}
.page-meta-bar{display:flex;gap:8px;padding:4px 20px 12px;flex-wrap:wrap}
.page-meta-bar select{padding:4px 8px;font-size:12px;font-weight:600;border:1px solid var(--border);border-radius:6px;background:var(--card);color:var(--text);cursor:pointer}

/* Page RTE */
.page-rte-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px 16px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:52px;z-index:1}
.page-rte-btn{width:30px;height:28px;border:none;background:none;border-radius:4px;cursor:pointer;font-size:13px;color:var(--text);display:flex;align-items:center;justify-content:center}
.page-rte-btn:hover{background:var(--border)}
.page-rte-sep{width:1px;height:20px;background:var(--border);margin:4px 4px}
.page-editor{min-height:300px;padding:16px 20px 40vh 40px;font-size:14px;line-height:1.7;outline:none;flex:1}
.page-editor:empty::before{content:attr(data-placeholder);color:var(--text-light);opacity:.5}
.page-editor h1{font-size:24px;font-weight:800;font-family:var(--font-heading);margin:16px 0 8px}
.page-editor h2{font-size:19px;font-weight:700;font-family:var(--font-heading);margin:14px 0 6px}
.page-editor h3{font-size:15px;font-weight:700;margin:12px 0 4px}
.page-editor ul,.page-editor ol{padding-left:24px;margin:6px 0}
.page-editor blockquote{border-left:3px solid var(--green);padding:4px 12px;margin:8px 0;color:var(--text-light)}
.page-editor hr{border:none;border-top:2px solid var(--border);margin:16px 0}
.page-editor .toggle-block{border:1px solid var(--border);border-radius:8px;margin:8px 0;overflow:hidden}
.page-editor .toggle-head{font-weight:700;cursor:pointer;user-select:none;padding:8px 12px;background:var(--bg)}
.page-editor .toggle-body{display:none;padding:8px 12px;border-top:1px solid var(--border)}
.page-editor .toggle-block.open .toggle-head::first-letter{content:''}
.page-editor .toggle-block.open .toggle-body{display:block}
.page-editor input[type="checkbox"]{width:16px;height:16px;accent-color:var(--green);cursor:pointer;margin-right:6px;vertical-align:middle}
.page-editor .cb-line{display:flex;align-items:center;padding:2px 0;min-height:24px}
/* Inline code */
.page-editor code{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-family:'SF Mono',Monaco,Consolas,monospace;font-size:12px;color:#e11d48}
html[data-theme="dark"] .page-editor code{background:#1e293b;border-color:#334155;color:#f472b6}
/* Callout block */
.page-editor .callout-block{display:flex;gap:10px;padding:12px 14px;border-radius:8px;background:#f0fdf4;border:1px solid #bbf7d0;margin:8px 0}
.page-editor .callout-icon{font-size:20px;flex-shrink:0;cursor:pointer;line-height:1.4}
.page-editor .callout-body{flex:1;min-width:0;outline:none}
html[data-theme="dark"] .page-editor .callout-block{background:#052e16;border-color:#166534}
/* Simple table */
.page-editor table{width:100%;border-collapse:collapse;margin:8px 0;font-size:13px}
.page-editor th,.page-editor td{border:1px solid var(--border);padding:6px 10px;text-align:left;min-width:60px}
.page-editor th{background:var(--bg);font-weight:700;font-size:12px}
.page-editor td{outline:none}
/* Code block */
.page-editor pre{background:#1e293b;color:#e2e8f0;border-radius:8px;padding:14px 16px;font-family:'SF Mono',Monaco,Consolas,monospace;font-size:13px;line-height:1.5;overflow-x:auto;margin:8px 0;white-space:pre-wrap;word-break:break-word}
html[data-theme="dark"] .page-editor pre{background:#0f172a;border:1px solid #334155}
/* Link dialog */
.pg-link-dialog{position:fixed;z-index:320;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:8px;box-shadow:0 8px 32px rgba(0,0,0,.18);display:none;gap:4px;align-items:center;width:320px}
.pg-link-dialog.show{display:flex}
.pg-link-dialog input{flex:1;border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;outline:none;background:var(--bg);color:var(--text)}
.pg-link-dialog input:focus{border-color:var(--green)}
.pg-link-dialog button{padding:6px 12px;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer}
.pg-link-dialog .pg-link-ok{background:var(--green);color:white}
.pg-link-dialog .pg-link-rm{background:var(--bg);color:var(--text-light);border:1px solid var(--border)}
html[data-theme="dark"] .pg-link-dialog{background:var(--card);border-color:var(--border)}
/* Block context menu */
.pg-ctx-menu{position:fixed;z-index:320;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:4px 0;box-shadow:0 8px 32px rgba(0,0,0,.18);display:none;min-width:180px}
.pg-ctx-menu.show{display:block}
.pg-ctx-item{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;font-size:13px;color:var(--text);transition:background .1s}
.pg-ctx-item:hover{background:var(--green-light);color:var(--green-dark)}
.pg-ctx-sep{height:1px;background:var(--border);margin:4px 0}
html[data-theme="dark"] .pg-ctx-menu{background:var(--card);border-color:var(--border)}
/* Help overlay */
.pg-help-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;display:none;align-items:center;justify-content:center}
.pg-help-overlay.show{display:flex}
.pg-help-card{background:var(--card);border-radius:12px;padding:20px 24px;max-width:640px;width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.pg-help-cols{display:flex;gap:24px}
@media(max-width:600px){.pg-help-cols{flex-direction:column;gap:12px}}
.pg-help-cols h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--green);margin:12px 0 6px}
.pg-help-cols h4:first-child{margin-top:0}
.pg-help-row{font-size:13px;padding:3px 0;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.pg-help-row kbd{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:11px;font-family:'SF Mono',Monaco,Consolas,monospace;white-space:nowrap}
/* Share panel */
.pg-share-panel{position:absolute;top:52px;right:20px;z-index:310;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;box-shadow:0 8px 32px rgba(0,0,0,.18);width:340px;display:none}
.pg-share-panel.show{display:block}
html[data-theme="dark"] .pg-help-card{background:var(--card)}
html[data-theme="dark"] .pg-share-panel{background:var(--card);border-color:var(--border)}
/* Page color picker */
.pg-color-picker{position:relative;display:inline-flex}
.pg-color-btn{width:30px;height:28px;border:none;background:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;position:relative;transition:background .12s;color:var(--text)}
.pg-color-btn:hover{background:var(--border)}
.pg-color-btn .pg-color-bar{position:absolute;bottom:3px;left:6px;right:6px;height:3px;border-radius:2px}
.pg-color-dropdown{display:none;position:absolute;top:100%;left:0;z-index:310;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px;box-shadow:0 8px 32px rgba(0,0,0,.18);width:200px}
.pg-color-dropdown.show{display:block}
.pg-color-section{margin-bottom:8px}
.pg-color-section:last-child{margin-bottom:0}
.pg-color-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:4px}
.pg-color-swatches{display:flex;flex-wrap:wrap;gap:3px}
.pg-color-swatch{width:22px;height:22px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform .12s}
.pg-color-swatch:hover{transform:scale(1.2)}
.pg-color-swatch.active{border-color:var(--text)}
.pg-color-reset{width:100%;padding:4px;border:1px solid var(--border);border-radius:4px;background:none;color:var(--text-light);font-size:11px;cursor:pointer;margin-top:6px}
.pg-color-reset:hover{background:var(--bg);color:var(--text)}
html[data-theme="dark"] .pg-color-dropdown{background:var(--card);border-color:var(--border);box-shadow:0 8px 32px rgba(0,0,0,.5)}

/* Block handle (Notion-style drag grip) */
.pg-block-handle{position:absolute;left:6px;width:18px;height:24px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s;z-index:5;pointer-events:none;cursor:grab;font-size:16px;color:var(--text-light);border-radius:4px;user-select:none}
.pg-block-handle.visible{opacity:.4;pointer-events:all}
.pg-block-handle:hover{opacity:1;background:var(--border);color:var(--text)}
.pg-block-handle:active{cursor:grabbing}
/* Drop indicator line */
.pg-drop-indicator{position:absolute;left:40px;right:8px;height:3px;background:var(--green);border-radius:2px;z-index:6;pointer-events:none;display:none}
.pg-drop-indicator.visible{display:block}
/* Highlight hovered block */
.page-editor [data-block-hover]{outline:2px solid color-mix(in srgb, var(--green) 25%, transparent);outline-offset:2px;border-radius:4px}

html[data-theme="dark"] .page-panel{background:var(--card)!important}
html[data-theme="dark"] .page-panel-header{background:var(--card)!important;border-color:var(--border)!important}

/* Slash command menu */
.slash-menu{position:absolute;z-index:300;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.15);padding:6px 0;width:220px;max-height:320px;overflow-y:auto;display:none}
.slash-menu.open{display:block}
.slash-menu-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-light);padding:6px 14px 4px}
.slash-item{display:flex;align-items:center;gap:10px;padding:7px 14px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text);transition:background .1s}
.slash-item:hover,.slash-item.active{background:var(--green-light);color:var(--green-dark)}
.slash-item-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.slash-item-label{flex:1}
.slash-item-hint{font-size:11px;color:var(--text-light)}
html[data-theme="dark"] .slash-menu{background:var(--card);border-color:var(--border);box-shadow:0 8px 32px rgba(0,0,0,.5)}
/* @mention chip in editor */
.mention-chip{display:inline;background:#dcfce7;color:#15803d;font-weight:700;padding:1px 6px;border-radius:6px;font-size:13px;white-space:nowrap;cursor:default}
html[data-theme="dark"] .mention-chip{background:#052e16;color:#4ade80}

/* ═══ TIME TRACKING ═══════════════════════════════════════════════ */
.timer-active{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:var(--green-light);border-radius:var(--radius-sm);margin-bottom:12px;
  border:1.5px solid var(--green-mid);
}
.timer-display{font-family:var(--font-heading);font-size:28px;font-weight:800;color:var(--green);line-height:1}
.timer-desc{font-size:12px;color:var(--green-dark);margin-top:2px;font-weight:600}
.timer-stop-btn{margin-left:auto;background:#ef4444;color:white;border:none;border-radius:8px;padding:8px 14px;font-weight:700;font-size:13px;white-space:nowrap;flex-shrink:0}
.time-entry{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px}
.time-entry:last-child{border-bottom:none}
.time-duration{font-weight:700;color:var(--green);font-size:13px;flex-shrink:0;width:55px}
.time-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.time-date{color:var(--text-light);font-size:12px;flex-shrink:0}
.time-del{background:none;border:none;font-size:12px;color:var(--text-light);padding:4px;opacity:0;transition:opacity .15s;flex-shrink:0}
.time-entry:hover .time-del{opacity:1}
.time-total{font-size:13px;padding:0 0 8px;color:var(--text-light)}
/* ═══ OFFLINE BANNER ═══ */
.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:#f59e0b;color:#78350f;text-align:center;font-size:13px;font-weight:600;padding:calc(6px + env(safe-area-inset-top,0px)) 12px 6px;transform:translateY(-100%);transition:transform .3s ease}
.offline-banner.show{transform:translateY(0)}
html[data-theme="dark"] .offline-banner{background:#92400e;color:#fef3c7}
/* ═══ GLOBAL SEARCH ══════════════════════════════════════════════ */
.search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:340px;overflow-y:auto;z-index:200;display:none}
.search-results.open{display:block}
.search-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-light);padding:8px 12px 4px}
.search-result-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .1s;font-size:13px}
.search-result-item:hover{background:var(--green-light)}
.sr-icon{font-size:15px;flex-shrink:0}
.sr-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.search-empty{text-align:center;padding:16px;color:var(--text-light);font-size:13px}
/* ═══ SKELETON LOADING ═══════════════════════════════════════════ */
.skeleton{background:linear-gradient(90deg,var(--border) 25%,var(--bg) 50%,var(--border) 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:6px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-line{height:14px;margin-bottom:10px;border-radius:6px}
.skeleton-line.w60{width:60%}
.skeleton-line.w80{width:80%}
.skeleton-line.w40{width:40%}
.skeleton-block{height:60px;margin-bottom:12px;border-radius:var(--radius-sm)}

/* ── Notification bell ─────────────────────────────────────────── */
.admin-notif-dot{position:absolute;top:4px;right:4px;width:9px;height:9px;background:#ef4444;border-radius:50%;display:none;border:2px solid var(--bg)}
.admin-notif-dot.show{display:block}
.admin-notif-badge{position:absolute;top:0;right:-2px;background:#ef4444;color:#fff;border-radius:10px;font-size:9px;font-weight:800;padding:1px 5px;min-width:16px;text-align:center;display:none;border:2px solid var(--card);line-height:1.3}
.admin-notif-badge.show{display:block}
.admin-notif-panel{display:none;position:absolute;top:calc(100% + 8px);right:0;width:420px;max-height:520px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 40px rgba(0,0,0,.15);z-index:1100;overflow:hidden}
.admin-notif-panel.open{display:flex;flex-direction:column}
@media (max-width:520px){
  .admin-notif-panel{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;max-height:85vh;border-radius:16px 16px 0 0;border:none;box-shadow:0 -8px 32px rgba(0,0,0,.18)}
  .admin-search-wrap{display:none !important}
}
.admin-notif-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-weight:700;font-size:15px;font-family:var(--font-heading);gap:8px}
.admin-notif-clear{background:none;border:1px solid var(--border);color:var(--text-light);font-size:11px;cursor:pointer;font-family:inherit;padding:4px 10px;border-radius:8px}
.admin-notif-clear:hover{background:var(--border);color:var(--red)}
/* Bell tabs */
.crm-bell-tabs{display:flex;gap:0;flex-shrink:0;border-bottom:2px solid var(--border)}
.crm-bell-tab{flex:1;padding:9px 8px;border:none;background:transparent;font-size:13px;font-weight:700;color:var(--text-light);cursor:pointer;text-align:center;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:color .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}
.crm-bell-tab.active{color:var(--green);border-bottom-color:var(--green)}
.crm-bell-tab-badge{background:#ef4444;color:white;border-radius:10px;font-size:9px;font-weight:800;padding:1px 6px;min-width:14px;text-align:center;display:none;line-height:1.3;flex-shrink:0}
.admin-notif-body{overflow-y:auto;flex:1;max-height:400px;padding:8px 12px}
/* Notif items — card style */
.admin-notif-item{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;margin-bottom:6px;border-radius:10px;transition:background .15s;position:relative;background:var(--bg);border:1px solid var(--border)}
.admin-notif-item:last-child{margin-bottom:0}
.admin-notif-item.unread{background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.2)}
.admin-notif-item:hover{background:var(--bg)}.admin-notif-item[onclick]:hover{background:rgba(22,163,74,.06);border-color:rgba(22,163,74,.2)}
.admin-notif-icon{font-size:18px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--card);border:1px solid var(--border)}
.admin-notif-item.unread .admin-notif-icon{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.2)}
.admin-notif-content{flex:1;min-width:0}
.admin-notif-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px;line-height:1.3}
.admin-notif-text{font-size:12px;color:var(--text-light);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}
.admin-notif-time{font-size:11px;color:var(--text-light);margin-top:3px}
.admin-notif-del{position:absolute;top:6px;right:6px;width:22px;height:22px;border:none;background:transparent;color:#9ca3af;font-size:13px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
@media (hover:hover){.admin-notif-del{opacity:0;transition:opacity .15s}.admin-notif-item:hover .admin-notif-del{opacity:1}}
.admin-notif-del:hover{background:var(--bg);color:var(--red)}
.admin-notif-del:active{background:#fee2e2;color:#dc2626}
.admin-notif-empty{text-align:center;padding:40px 16px;color:var(--text-light);font-size:14px}
.admin-notif-group-label{font-size:10px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin:10px 0 4px;padding:0 4px}
.admin-notif-overlay{display:none;position:fixed;inset:0;z-index:1050}
.admin-notif-overlay.open{display:block}
/* Chip buttons for broadcast modal */
.chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:16px;border:1.5px solid var(--border);background:var(--bg);color:var(--text-light);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.chip:hover{border-color:var(--green);color:var(--green)}
.chip.active{border-color:var(--green);background:rgba(34,197,94,.1);color:var(--green)}
/* News items in CRM bell */
.crm-news-item{border-radius:10px;border:1px solid var(--border);padding:12px;margin-bottom:8px;background:var(--bg)}
.crm-news-item.unread{border-color:rgba(34,197,94,.2);background:rgba(34,197,94,.04)}
.crm-news-title{font-weight:700;font-size:14px;margin-bottom:3px}
.crm-news-meta{font-size:11px;color:var(--text-light);margin-bottom:6px}
.crm-news-body{font-size:13px;color:var(--text);line-height:1.5}
.admin-refresh-btn.spinning{animation:spin-once .65s linear}
@keyframes spin-once{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}

/* ═══ SNIPPETS / ŠABLONY ZPRÁV ════════════════════════════════════ */
.snip-search-bar{display:flex;gap:6px;padding:0 18px 8px;align-items:center;flex-wrap:wrap}
.snip-search{flex:1;min-width:140px;padding:7px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;outline:none;background:var(--bg);color:var(--text);font-family:inherit}
.snip-search:focus{border-color:var(--primary)}
.snip-cat-pills{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;padding:0 18px 10px}
.snip-cat-pills::-webkit-scrollbar{display:none}
.snip-cat-pill{padding:4px 12px;border-radius:16px;font-size:11px;font-weight:700;border:1.5px solid var(--border);background:var(--bg);color:var(--text-light);cursor:pointer;white-space:nowrap;transition:all .12s}
.snip-cat-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.snip-cat-pill:hover:not(.active){border-color:var(--primary);color:var(--primary)}
.snip-item{padding:12px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;position:relative}
.snip-item:last-child{border-bottom:none}
.snip-item:hover{background:var(--hover)}
.snip-item-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.snip-item-title{font-weight:700;font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.snip-item-cat{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;background:var(--green-light);color:var(--primary-dark);white-space:nowrap}
.snip-item-preview{font-size:12px;color:var(--text-light);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.snip-item-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.snip-item-tag{font-size:10px;padding:1px 7px;border-radius:8px;background:var(--bg);color:var(--text-light);border:1px solid var(--border)}
.snip-item-actions{position:absolute;top:10px;right:14px;display:flex;gap:4px;opacity:0;transition:opacity .12s}
.snip-item:hover .snip-item-actions{opacity:1}
.snip-item-btn{width:28px;height:28px;border-radius:6px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;transition:all .12s}
.snip-item-btn:hover{background:var(--green-light);border-color:var(--primary)}
.snip-item-btn.danger:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626}
.snip-empty{text-align:center;color:var(--text-light);padding:24px 16px;font-size:13px}
.snip-copied{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:#16a34a;color:#fff;padding:10px 20px;border-radius:12px;font-weight:700;font-size:14px;z-index:9999;animation:snipFade .3s ease}
@keyframes snipFade{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Snippet detail/edit modal */
.snip-detail-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.45);display:none;align-items:flex-end;justify-content:center}
.snip-detail-overlay.open{display:flex}
@media(min-width:768px){.snip-detail-overlay.open{align-items:center}}
.snip-detail-sheet{background:var(--card);width:100%;max-width:560px;max-height:85vh;border-radius:20px 20px 0 0;overflow-y:auto;box-shadow:0 -8px 40px rgba(0,0,0,.2);padding:0}
@media(min-width:768px){.snip-detail-sheet{border-radius:20px;max-height:80vh}}
.snip-detail-header{display:flex;align-items:center;padding:16px 20px;gap:10px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:1}
.snip-detail-title{flex:1;font-family:var(--font-heading);font-size:17px;font-weight:700}
.snip-detail-body{padding:16px 20px 24px}
.snip-form-group{margin-bottom:14px}
.snip-form-group label{display:block;font-size:12px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px}
.snip-form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;font-family:inherit;outline:none;background:var(--bg);color:var(--text);transition:border-color .15s}
.snip-form-input:focus{border-color:var(--primary)}
.snip-form-textarea{width:100%;min-height:150px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:13px;font-family:inherit;outline:none;background:var(--bg);color:var(--text);line-height:1.6;resize:vertical;transition:border-color .15s}
.snip-form-textarea:focus{border-color:var(--primary)}
.snip-form-row{display:flex;gap:10px}
.snip-form-row .snip-form-group{flex:1}
.snip-btn-primary{width:100%;padding:12px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;transition:opacity .12s}
.snip-btn-primary:hover{opacity:.9}
.snip-toolbar{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.snip-toolbar-btn{padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg);font-size:13px;cursor:pointer;transition:all .12s}
.snip-toolbar-btn:hover{background:var(--green-light);border-color:var(--primary)}

/* ═══ RITUAL WIDGET ═══════════════════════════════════════════════ */
.ritual-dash-widget{border-left:3px solid var(--primary)}
.ritual-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:10px 0}
.ritual-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#4ade80);border-radius:3px;transition:width .5s ease}
.ritual-badge{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px}
.ritual-quick-item{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px;cursor:pointer}
.ritual-quick-item input[type="checkbox"]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}
.ritual-quick-item.done span{opacity:.5;text-decoration:line-through}
.ritual-quick-item .rqi-time{font-size:11px;color:var(--text-light);margin-left:auto}
.btn-close-day{width:100%;padding:10px;border:none;border-radius:8px;background:linear-gradient(135deg,#dc2626,#ea580c);color:#fff;font-weight:700;font-size:13px;cursor:pointer;margin-top:10px;transition:transform .15s}
.btn-close-day:hover{transform:translateY(-1px)}
.btn-close-day:disabled{opacity:.5;cursor:not-allowed}
.btn-close-day.pulse{animation:ritualPulse 2s infinite}
@keyframes ritualPulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}}
html[data-theme="dark"] .ritual-progress-bar{background:var(--dm-border)}
.ar-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-bottom:1px solid var(--border);transition:background .1s;border-radius:0}
.ar-item:last-child{border-bottom:none}
.ar-item:hover{background:rgba(0,0,0,.02)}
.ar-item.done .ar-label{opacity:.45;text-decoration:line-through}
.ar-drag-handle{cursor:grab;color:var(--text-light);font-size:13px;padding:2px;user-select:none;flex-shrink:0}
.ar-label{font-size:14px;flex:1;min-width:0;cursor:text;padding:4px 8px;border-radius:6px;border:1px solid transparent;line-height:1.3}
.ar-label:focus{outline:none;background:var(--bg);border-color:var(--primary);box-shadow:0 0 0 2px rgba(76,175,80,.15)}
.ar-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}
.ar-time-input{width:80px;padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);background:var(--bg);text-align:center;cursor:pointer}
.ar-time-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(76,175,80,.15)}
.ar-dur-input{width:50px;padding:4px 6px;border:1px solid var(--border);border-radius:6px;font-size:12px;text-align:center;background:var(--green-light);color:var(--primary);font-weight:600}
.ar-dur-input:focus{border-color:var(--primary);background:var(--bg);box-shadow:0 0 0 2px rgba(76,175,80,.15)}
.ar-dur-suffix{font-size:11px;color:var(--text-light);margin-left:-2px}
.ar-cat-select{padding:4px 6px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:var(--bg);color:var(--text);cursor:pointer}
.ar-cat-select:focus{border-color:var(--primary)}
.ar-del-btn{border:none;background:none;color:var(--text-light);font-size:16px;cursor:pointer;padding:4px 6px;border-radius:4px;opacity:0;transition:opacity .15s,background .1s}
.ar-item:hover .ar-del-btn{opacity:1}
.ar-del-btn:hover{color:#ef4444;background:rgba(239,68,68,.08)}
.ar-item.dragging{opacity:.3}
html[data-theme="dark"] .ar-label:focus{background:var(--dm-input)}
html[data-theme="dark"] .ar-time-input{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
html[data-theme="dark"] .ar-dur-input{background:rgba(76,175,80,.12)}
html[data-theme="dark"] .ar-cat-select{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
/* ═══ RITUAL FULL PANEL — shared styles with index.html ══════════ */
.ritual-section{display:flex;flex-direction:column;gap:16px;padding:12px;max-width:800px;margin:0 auto}
.ritual-panel{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;min-width:0}
.ritual-panel-title{font-weight:700;font-size:15px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.ritual-tabs{display:flex;gap:4px;margin-bottom:14px;background:var(--border);border-radius:8px;padding:3px}
.ritual-tab{flex:1;text-align:center;padding:6px 10px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s;color:var(--text-light)}
.ritual-tab.active{background:var(--card);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.ritual-checklist-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;transition:background .15s;cursor:pointer}
.ritual-checklist-item:hover{background:rgba(76,175,80,.06)}
.ritual-checklist-item.completed{opacity:.55}
.ritual-checklist-item.completed .rcl-label{text-decoration:line-through}
.ritual-checklist-item input[type="checkbox"]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.rcl-label{font-size:14px;flex:1;min-width:0}
.rcl-time{font-size:11px;color:var(--text-light);white-space:nowrap}
.rcl-duration{font-size:10px;background:rgba(76,175,80,.12);color:var(--primary);padding:1px 6px;border-radius:10px;white-space:nowrap}
.ritual-textarea{width:100%;min-height:56px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;background:var(--bg);color:var(--text)}
.ritual-gratitude-input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;margin-bottom:6px;background:var(--bg);color:var(--text)}
.ritual-circle-progress{display:flex;flex-direction:column;align-items:center;margin-bottom:14px}
.ritual-circle-progress svg{width:110px;height:110px;transform:rotate(-90deg)}
.ritual-circle-progress .rcp-bg{fill:none;stroke:var(--border);stroke-width:8}
.ritual-circle-progress .rcp-fill{fill:none;stroke:var(--primary);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .6s ease}
.ritual-circle-progress .rcp-text{font-size:28px;font-weight:700;fill:var(--text);text-anchor:middle;dominant-baseline:central;transform:rotate(90deg);transform-origin:center}
.ritual-sync-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--primary);border-radius:8px;background:rgba(76,175,80,.08);color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;width:100%;justify-content:center;margin-top:6px}
.ritual-sync-btn:hover{background:rgba(76,175,80,.15)}
/* Focus blocks */
.ritual-focus-block{border-radius:10px;border:1px solid var(--border);margin-bottom:8px;overflow:hidden;transition:all .2s;background:var(--card)}
.ritual-focus-block.completed{opacity:.65}
.ritual-focus-block.fixed-block{background:#f8f9fa;cursor:default}
.ritual-focus-block.hard-boundary{border:2px solid #27AE60;background:#EAFAF6}
.rfb-header{padding:10px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.rfb-time{font-size:11px;color:var(--text-light);white-space:nowrap;font-weight:600}
.rfb-label{font-weight:600;font-size:13px;flex:1;min-width:0}
.rfb-body{padding:8px 14px 10px;display:flex;flex-direction:column;gap:6px}
.ritual-category-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}
.ritual-category-select{border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:12px;padding:3px 6px;border-radius:6px;cursor:pointer}
.rfb-note-input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--bg);color:var(--text);box-sizing:border-box}
.ritual-hard-label{font-size:10px;font-weight:700;color:#27AE60;letter-spacing:.5px;text-transform:uppercase}
/* Energy */
.ritual-energy-rating{display:flex;align-items:center;gap:4px;margin-top:2px;flex-wrap:wrap}
.energy-label{font-size:11px;color:var(--text-light);white-space:nowrap}
.energy-dot{width:18px;height:18px;border-radius:50%;border:none;cursor:pointer;font-size:15px;color:#ddd;background:none;padding:0;line-height:1;transition:transform .1s,color .1s}
.energy-dot:hover{transform:scale(1.2)}
.energy-dot.active{transform:scale(1.25)}
.energy-dot[data-value="1"].active{color:#E74C3C}
.energy-dot[data-value="2"].active{color:#E67E22}
.energy-dot[data-value="3"].active{color:#F1C40F}
.energy-dot[data-value="4"].active{color:#2ECC71}
.energy-dot[data-value="5"].active{color:#27AE60}
.energy-avg-label{font-size:12px;font-weight:600;color:var(--text-light);margin-left:4px}
/* History */
.ritual-history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:7px;margin-top:6px}
.ritual-day-card{border-radius:10px;border:1px solid var(--border);padding:9px;cursor:pointer;transition:all .2s;background:var(--card)}
.ritual-day-card:hover{box-shadow:0 3px 12px rgba(0,0,0,.1);transform:translateY(-1px)}
.ritual-day-card.today{border:2px solid var(--primary)}
.day-card-header{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-bottom:4px}
.day-name{font-size:11px;font-weight:700;color:var(--text)}
.day-cat-badge{font-size:9px;font-weight:700;padding:1px 5px;border-radius:10px}
.day-card-stats{font-size:10px;color:var(--text-light);margin-bottom:4px;line-height:1.5}
.day-card-blocks{display:flex;gap:2px;flex-wrap:wrap}
.day-block-dot{width:12px;height:12px;border-radius:3px;background:#eee}
/* Weekly chart */
.ritual-week-tab{display:grid;grid-template-columns:1fr 180px;gap:16px;align-items:start}
.ritual-chart-wrap{overflow:hidden}
.ritual-stacked-chart{width:100%;height:160px;display:block}
.ritual-pie-chart-wrap{display:flex;flex-direction:column;gap:8px;align-items:center}
.ritual-pie-legend{font-size:11px;display:flex;flex-direction:column;gap:3px;width:100%}
.ritual-pie-legend-item{display:flex;align-items:center;gap:5px}
.ritual-pie-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.ritual-target-alerts{margin-top:10px;display:flex;flex-direction:column;gap:5px}
.ritual-alert{padding:6px 10px;border-radius:8px;font-size:12px;display:flex;align-items:center;gap:7px;font-weight:500}
.ritual-alert.warn{background:#FFF3CD;color:#856404}
.ritual-alert.danger{background:#FDECEA;color:#842029}
.ritual-alert.info{background:#E8F4FD;color:#0C5460}
.ritual-alert.success{background:#D4EDDA;color:#155724}
/* Buffer */
.ritual-buffer-suggestion{background:#EEF5FF;border:1px solid #4A90D9;border-radius:10px;padding:10px 14px;margin-bottom:10px;display:flex;align-items:center;gap:10px;font-size:13px;flex-wrap:wrap}
.ritual-buffer-suggestion button{padding:4px 10px;border-radius:6px;border:none;cursor:pointer;font-size:12px;font-weight:600}
.ritual-buffer-suggestion .buf-add{background:#4A90D9;color:#fff}
.ritual-buffer-suggestion .buf-dismiss{background:none;color:#4A90D9}
/* Weekly review modal */
#arWeeklyReviewModal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;display:none;align-items:center;justify-content:center;padding:16px}
#arWeeklyReviewModal.open{display:flex}
.weekly-review-content{background:var(--card);border-radius:16px;width:min(600px,100%);max-height:88vh;overflow-y:auto;padding:24px}
.wrc-section{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.wrc-section:last-child{border-bottom:none}
.wrc-title{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text)}
.wrc-stat{display:flex;justify-content:space-between;font-size:13px;padding:3px 0}
.wrc-textarea{width:100%;min-height:50px;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;background:var(--bg);color:var(--text);margin-top:4px}
.wrc-plan-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:13px}
.wrc-plan-row select{flex:1;padding:4px 6px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--bg);color:var(--text)}
/* Template editor */
.ritual-tpl-item{display:flex;align-items:center;gap:8px;padding:8px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;background:var(--card);cursor:grab}
.ritual-tpl-item.dragging{opacity:.4}
.ritual-tpl-item input{flex:1;padding:4px 8px;border:1px solid var(--border);border-radius:4px;font-size:13px;background:var(--bg);color:var(--text)}
.ritual-tpl-item select{padding:4px;border:1px solid var(--border);border-radius:4px;font-size:12px;background:var(--bg);color:var(--text)}
.ritual-tpl-item .tpl-delete{background:none;border:none;color:#ef4444;cursor:pointer;font-size:16px;padding:4px}
.ritual-tpl-item .tpl-drag{color:var(--text-light);cursor:grab;font-size:14px}
.ritual-settings-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.ritual-settings-toggle label{font-size:14px;font-weight:500}
.ritual-toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}
.ritual-toggle-switch input{opacity:0;width:0;height:0}
.ritual-toggle-switch .slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:24px;transition:background .2s}
.ritual-toggle-switch .slider:before{content:'';position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}
.ritual-toggle-switch input:checked+.slider{background:var(--primary)}
.ritual-toggle-switch input:checked+.slider:before{transform:translateX(20px)}
.ritual-add-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed var(--border);border-radius:8px;background:none;color:var(--text-light);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s}
.ritual-add-btn:hover{border-color:var(--primary);color:var(--primary)}
html[data-theme="dark"] .ritual-panel{background:var(--dm-card);box-shadow:none;border:1px solid var(--dm-border)}
html[data-theme="dark"] .ritual-tabs{background:var(--dm-border)}
html[data-theme="dark"] .ritual-tab.active{background:var(--dm-card)}
html[data-theme="dark"] .ritual-focus-block{background:var(--dm-card);border-color:var(--dm-border)}
html[data-theme="dark"] .ritual-focus-block.fixed-block{background:rgba(255,255,255,.04)}
html[data-theme="dark"] .rfb-note-input,.rfb-note-input{box-sizing:border-box}
html[data-theme="dark"] .rfb-note-input{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
html[data-theme="dark"] .ritual-category-select{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
html[data-theme="dark"] .ritual-day-card{background:var(--dm-card);border-color:var(--dm-border)}
html[data-theme="dark"] .ritual-textarea,.ritual-gratitude-input{box-sizing:border-box}
html[data-theme="dark"] .ritual-textarea{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
html[data-theme="dark"] .ritual-gratitude-input{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
html[data-theme="dark"] .weekly-review-content{background:var(--dm-card)}
html[data-theme="dark"] .wrc-textarea{background:var(--dm-input);border-color:var(--dm-border);color:var(--dm-text)}
@media(max-width:900px){.ritual-section{gap:10px}.ritual-week-tab{grid-template-columns:1fr}.ritual-history-grid{grid-template-columns:repeat(2,1fr)}}

/* ═══ DASHBOARD TABS ═══════════════════════════════════════════════ */
.dashboard-alerts{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;margin-bottom:8px}
.dashboard-alerts:empty{display:none}
.dash-alert{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--card);transition:background .15s,border-color .15s;white-space:nowrap}
.dash-alert:hover{background:var(--bg);border-color:var(--text-light)}
.dash-alert.alert-red{color:#dc2626;border-color:#fecaca;background:#fef2f2}
.dash-alert.alert-red:hover{background:#fee2e2}
.dash-alert.alert-orange{color:#d97706;border-color:#fed7aa;background:#fffbeb}
.dash-alert.alert-orange:hover{background:#fef3c7}
.dash-alert.alert-blue{color:#2563eb;border-color:#bfdbfe;background:#eff6ff}
.dash-alert.alert-blue:hover{background:#dbeafe}
html[data-theme="dark"] .dash-alert{background:var(--card);border-color:var(--border)}
html[data-theme="dark"] .dash-alert.alert-red{background:#1c1111;border-color:#7f1d1d;color:#fca5a5}
html[data-theme="dark"] .dash-alert.alert-orange{background:#1c1a11;border-color:#78350f;color:#fcd34d}
html[data-theme="dark"] .dash-alert.alert-blue{background:#111827;border-color:#1e3a5f;color:#93c5fd}

.dashboard-tabs{display:flex;gap:4px;padding:4px 0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.dashboard-tabs::-webkit-scrollbar{display:none}
.dash-tab{flex:1;min-width:0;padding:10px 6px;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--card);color:var(--text);font-size:13px;font-weight:700;font-family:var(--font-heading);cursor:pointer;transition:all .15s;text-align:center;white-space:nowrap;letter-spacing:-.01em}
.dash-tab:hover{border-color:var(--green);background:var(--green-light)}
.dash-tab.active{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 2px 8px rgba(76,175,80,.25)}
.dash-tab .dash-tab-icon{display:block;font-size:18px;line-height:1;margin-bottom:2px}
@media(min-width:768px){.dash-tab{padding:10px 16px;font-size:14px}}
html[data-theme="dark"] .dash-tab{background:var(--card);border-color:var(--border)}
html[data-theme="dark"] .dash-tab:hover{background:#1a2e1a;border-color:var(--green)}
html[data-theme="dark"] .dash-tab.active{background:var(--green);border-color:var(--green);color:#fff}

.dash-tab-content{display:none}
.dash-tab-content.active{display:block}

/* ── Inbox panel ──────────────────────────────────────────────── */
.inbox-row{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .15s}
.inbox-row:hover{background:var(--bg)}
.inbox-row.is-done .inbox-title{text-decoration:line-through;color:var(--text-light)}
.inbox-row.is-archived{opacity:.55}
.inbox-row.is-leaving{opacity:0;transform:translateX(8px);transition:opacity .25s,transform .25s}
.inbox-row.is-pending-archive{opacity:.6}
.inbox-row.is-pending-archive .inbox-title{text-decoration:line-through;color:var(--text-light)}
.inbox-undo{margin-top:4px;font-size:12px;color:var(--text-light);display:flex;align-items:center;gap:8px}
.inbox-undo-btn{background:none;border:1px solid var(--border);color:var(--green);padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit}
.inbox-undo-btn:hover{background:var(--bg)}
.inbox-check{width:18px;height:18px;border:1.5px solid var(--border);border-radius:4px;cursor:pointer;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;background:var(--card);font-size:12px;line-height:1;color:#fff}
.inbox-check.checked{background:var(--green);border-color:var(--green)}
.inbox-body{flex:1;min-width:0}
.inbox-title{font-size:14px;color:var(--text);font-weight:500;word-wrap:break-word;white-space:pre-wrap}
.inbox-meta{font-size:11px;color:var(--text-light);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap}
.inbox-meta-pill{background:#fef3c7;color:#92400e;padding:1px 6px;border-radius:4px;font-weight:600}
.inbox-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;position:relative}
.inbox-actions-btn{background:none;border:none;font-size:16px;cursor:pointer;color:var(--text-light);padding:4px 6px;border-radius:4px}
.inbox-actions-btn:hover{background:var(--bg);color:var(--text)}
.inbox-actions-menu{position:absolute;top:28px;right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:50;min-width:170px;padding:4px;display:none}
.inbox-actions-menu.open{display:block}
.inbox-actions-menu button{display:block;width:100%;text-align:left;padding:7px 10px;font-size:13px;border:none;background:none;color:var(--text);cursor:pointer;border-radius:4px;font-family:inherit}
.inbox-actions-menu button:hover{background:var(--bg)}
.inbox-empty{padding:32px 16px;text-align:center;color:var(--text-light);font-size:13px}
.ibx-c{background:rgba(0,0,0,.08);padding:1px 6px;border-radius:8px;font-size:11px;font-weight:700;margin-left:4px}
.chip.active .ibx-c{background:rgba(255,255,255,.25)}

/* Inbox 1-line header */
.inbox-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.inbox-header-filters{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);font-weight:600}
.inbox-filter-active{display:inline-flex;align-items:center;gap:4px}
.inbox-filter-toggle{background:none;border:1px solid var(--border);color:var(--text-light);padding:4px 10px;border-radius:14px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}
.inbox-filter-toggle:hover{background:var(--bg);color:var(--text)}
.inbox-filter-toggle.active{background:var(--green);color:#fff;border-color:var(--green)}
.inbox-filter-toggle.active .ibx-c{background:rgba(255,255,255,.25);color:#fff}
.inbox-tag-chip{padding:4px 10px;border-radius:14px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid transparent;font-family:inherit}
.inbox-tag-chip.active{outline:2px solid var(--green);outline-offset:1px}

/* F2.7: Dnes panel */
.dnes-filter-btn{background:var(--card);border:1px solid var(--border);color:var(--text-light);padding:5px 12px;border-radius:14px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}
.dnes-filter-btn:hover{border-color:var(--green);color:var(--green)}
.dnes-filter-btn.active{background:linear-gradient(135deg,var(--green),#16a34a);color:#fff;border-color:var(--green);box-shadow:0 2px 8px rgba(29,158,117,.25)}
.dnes-row{display:flex;align-items:flex-start;gap:10px;padding:11px 16px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer;text-decoration:none;color:inherit}
.dnes-row:hover{background:var(--bg)}
.dnes-row.is-overdue .dnes-due{color:#dc2626;font-weight:700}
.dnes-source-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:var(--bg)}
.dnes-source-icon.src-admin{background:#e0e7ff;color:#4338ca}
.dnes-source-icon.src-project{background:#dcfce7;color:#16a34a}
.dnes-source-icon.src-inbox{background:#fef3c7;color:#92400e}
.dnes-body{flex:1;min-width:0}
.dnes-title{font-size:14px;color:var(--text);font-weight:500;word-wrap:break-word}
.dnes-meta{font-size:11px;color:var(--text-light);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap}
.dnes-meta-pill{padding:1px 7px;border-radius:8px;font-weight:600;font-size:11px}
.dnes-due{font-weight:600}
.dnes-empty{padding:36px 16px;text-align:center;color:var(--text-light);font-size:13px}

/* F2.8.J Týden widget */
.week-stat{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;text-align:center;cursor:pointer;transition:all .15s}
.week-stat:hover{border-color:var(--green);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.05)}
.week-stat-num{font-size:24px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.week-stat-lbl{font-size:11px;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-top:4px}
.inbox-add-btn{background:#1D9E75;color:#fff;border:none;padding:6px 14px;border-radius:18px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;flex-shrink:0}
.inbox-add-btn:hover{filter:brightness(1.05)}
.inbox-rem-chip{background:var(--card);border:1px solid var(--border);color:var(--text);padding:4px 10px;border-radius:14px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}
.inbox-rem-chip:hover{border-color:var(--green);color:var(--green)}
.inbox-rem-chip.active{background:var(--green);color:#fff;border-color:var(--green)}


/* ═══ COLLAPSIBLE CARDS (Admin tab) ════════════════════════════════ */
.dash-card.collapsible .card-header{cursor:pointer;user-select:none}
.dash-card.collapsible .card-header::after{content:'▾';font-size:14px;color:var(--text-light);transition:transform .2s;margin-left:auto;flex-shrink:0}
.dash-card.collapsible.collapsed .card-header::after{transform:rotate(-90deg)}
.dash-card.collapsible.collapsed .card-body,
.dash-card.collapsible.collapsed .snip-search-bar,
.dash-card.collapsible.collapsed .snip-cat-pills,
.dash-card.collapsible.collapsed .lib-categories{display:none!important}


/* ─── F5.1.3 — Tab Kurz: sub-navigace + KPI dashboard ─── */
.kurz-subnav-btn {
  padding: 6px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--card);
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.kurz-subnav-btn:hover:not(:disabled) {
  border-color: var(--green);
  background: var(--green-light);
}
.kurz-subnav-btn.active {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
  box-shadow: 0 2px 6px rgba(76, 175, 80, 0.2);
}
.kurz-subnav-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.kurz-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.kurz-kpi-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 16px;
}
.kurz-kpi-card--success { border-color: var(--green); background: var(--green-light); }
.kurz-kpi-card--warning { border-color: #f59e0b; background: #fef3c7; }
.kurz-kpi-card--accent  { border-color: #8b5cf6; background: #f3e8ff; }
.kurz-kpi-card--info    { border-color: #3b82f6; background: #dbeafe; }
.kurz-kpi-label {
  font-size: 12px;
  color: var(--text-light);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
  margin-bottom: 4px;
}
.kurz-kpi-value {
  font-size: 28px;
  font-weight: 800;
  line-height: 1;
  color: var(--text);
  margin-bottom: 4px;
}
.kurz-kpi-sub {
  font-size: 12px;
  color: var(--text-light);
  margin-top: 4px;
}
html[data-theme="dark"] .kurz-kpi-card--success { background: rgba(76,175,80,0.1); }
html[data-theme="dark"] .kurz-kpi-card--warning { background: rgba(245,158,11,0.12); color: var(--text); }
html[data-theme="dark"] .kurz-kpi-card--accent  { background: rgba(139,92,246,0.12); }
html[data-theme="dark"] .kurz-kpi-card--info    { background: rgba(59,130,246,0.12); }

.kurz-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.kurz-actions .btn-kurz-action {
  padding: 8px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--card);
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
}
.kurz-actions .btn-kurz-action:hover {
  border-color: var(--green);
  background: var(--green-light);
}
.kurz-actions .btn-kurz-action--primary {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
}
.kurz-actions .btn-kurz-action--primary:hover {
  background: var(--green-dark, #2e7d32);
}

.kurz-section-title {
  font-size: 16px;
  font-weight: 700;
  margin: 20px 0 12px;
  color: var(--text);
}

.kurz-reg-list {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.kurz-reg-row {
  display: grid;
  grid-template-columns: 80px 110px 1fr 100px 90px 84px;
  gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  align-items: center;
}
.kurz-reg-actions {
  display: flex;
  gap: 4px;
  justify-content: flex-end;
}
.btn-kurz-row {
  padding: 4px 8px;
  font-size: 13px;
  line-height: 1;
  min-width: 34px;
}
.btn-kurz-row--danger { color: #dc2626; }
.btn-kurz-row--danger:hover { border-color: #dc2626; background: #fef2f2; }
.kurz-reg-row:last-child { border-bottom: none; }
.kurz-reg-row:hover { background: var(--bg); }
.kurz-reg-row code {
  font-family: 'SF Mono', Menlo, Monaco, monospace;
  background: var(--bg);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 12px;
}
.kurz-reg-status {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  text-align: center;
  font-weight: 600;
}
.kurz-reg-status--paid { background: #dcfce7; color: #166534; }
.kurz-reg-status--awaiting { background: #fef3c7; color: #92400e; }
.kurz-reg-status--partial { background: #fee2e2; color: #991b1b; }
.kurz-reg-status--cancelled { background: var(--bg); color: var(--text-light); }
html[data-theme="dark"] .kurz-reg-status--paid { background: rgba(22,101,52,0.3); color: #86efac; }
html[data-theme="dark"] .kurz-reg-status--awaiting { background: rgba(146,64,14,0.3); color: #fcd34d; }
html[data-theme="dark"] .kurz-reg-status--partial { background: rgba(153,27,27,0.3); color: #fca5a5; }

@media (max-width: 600px) {
  .kurz-reg-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 14px;
  }
}

.kurz-discounts-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  font-size: 13px;
}
.kurz-discounts-table thead th {
  background: var(--bg);
  padding: 10px 12px;
  text-align: left;
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-light);
}
.kurz-discounts-table td {
  padding: 10px 12px;
  border-top: 1px solid var(--border);
}
.kurz-discount-code {
  font-family: 'SF Mono', monospace;
  background: var(--green-light);
  color: var(--green-dark, #166534);
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 700;
  display: inline-block;
}

/* ═══ F6.1 — Course CMS (Týdny / Cviky / Tipy) ══════════════════════════ */
.btn-kurz-action {
  background: var(--card, #fff);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: border-color .15s, background .15s;
}
.btn-kurz-action:hover { border-color: var(--green); }
.btn-kurz-action:disabled { cursor: not-allowed; }
.btn-kurz-primary {
  background: var(--green);
  color: #fff;
  border: 1px solid var(--green);
  border-radius: 6px;
  padding: 8px 18px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
}
.btn-kurz-primary:hover { background: #15803d; }
.kurz-cms-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--card, #fff);
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--border);
  font-size: 13px;
  margin-bottom: 10px;
}
.kurz-cms-table thead th {
  background: var(--bg-soft, #f8fafc);
  text-align: left;
  padding: 10px 12px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-light);
  border-bottom: 1px solid var(--border);
}
.kurz-cms-table td {
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  vertical-align: middle;
}
.kurz-empty-card {
  background: var(--card, #fff);
  border: 1px dashed var(--border);
  border-radius: 8px;
  padding: 24px;
  text-align: center;
  color: var(--text-light);
  font-size: 13px;
}
.kurz-cms-editor {
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
}
.kurz-cms-field {
  display: block;
  margin-bottom: 12px;
}
.kurz-cms-field > span {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-light);
  margin-bottom: 4px;
}
.kurz-cms-field input[type="text"],
.kurz-cms-field textarea,
.kurz-cms-field select {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  font-family: inherit;
  background: #fff;
}
.kurz-cms-field textarea { min-height: 60px; resize: vertical; }

/* ═══ F6.2 — Course CMS extensions ══════════════════════════════════════ */
.kurz-cms-tablewrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 8px;
}
.kurz-cms-modeselect {
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
}
.kurz-cms-modeselect:hover { border-color: var(--green); }

.kurz-status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.kurz-status-pill--ok    { background: var(--green-light, #dcfce7); color: #166534; }
.kurz-status-pill--muted { background: rgba(100,116,139,0.12); color: #475569; }

.kurz-audit-log-toggle {
  background: rgba(0,0,0,0.025);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
}
.kurz-audit-log-toggle > summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--text-light);
  font-size: 13px;
  user-select: none;
}
.kurz-audit-log-toggle[open] > summary { margin-bottom: 12px; }

.kurz-mode-badge {
  display: inline-block;
  padding: 2px 8px;
  background: rgba(16, 185, 129, 0.1);
  color: #047857;
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.btn-kurz-action--primary {
  background: var(--green, #10b981);
  color: #fff;
  border-color: var(--green, #10b981);
}
.btn-kurz-action--primary:hover {
  background: #0d9668;
  border-color: #0d9668;
}

/* ═══ F6.3.2 — Účastníci sub-tab (search + filtry + table) ═══════════════ */
.kurz-uc-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
  align-items: center;
}
.kurz-uc-toolbar select,
.kurz-uc-search {
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 13px;
  font-family: inherit;
}
.kurz-uc-toolbar select { cursor: pointer; }
.kurz-uc-search {
  flex: 1;
  min-width: 200px;
  max-width: 320px;
}
.kurz-uc-toolbar select:hover,
.kurz-uc-search:focus { border-color: var(--green); outline: none; }

.kurz-uc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
  align-items: center;
}

.kurz-uc-table {
  font-size: 12.5px;
}
.kurz-uc-table th, .kurz-uc-table td {
  padding: 8px 10px;
}

.kurz-quest-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}
.kurz-quest-none   { background: rgba(100,116,139,0.10); color: #475569; }
.kurz-quest-sent   { background: rgba(245,158,11,0.12); color: #b45309; }
.kurz-quest-filled { background: rgba(16,185,129,0.15); color: #047857; }
