:root{
  --bg:#f5f3ec; --panel:#ffffff; --ink:#1f2a37; --muted:#6b7280;
  --accent:#2563eb; --accent-soft:#dbeafe; --line:#e5e7eb; --line2:#cbd5e1;
  --danger:#dc2626; --ok:#16a34a; --warn:#d97706;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font:13px/1.4 -apple-system,"Segoe UI",Helvetica,Arial,sans-serif;color:var(--ink);background:#eceae1}
button{font:inherit;color:inherit}
input,select,textarea{font:inherit;color:inherit}
.app{display:grid;grid-template-rows:44px 1fr 24px;grid-template-columns:240px 1fr 300px;
  grid-template-areas:"top top top" "left center right" "status status status";height:100vh;width:100vw}
/* Top bar */
.top{grid-area:top;background:var(--panel);border-bottom:1px solid var(--line);
  display:flex;align-items:stretch;padding:0;gap:0;height:52px;overflow:visible}
.top-section{display:flex;align-items:center;gap:6px;padding:0 12px;height:100%}
.top-left{flex:0 0 auto;border-right:1px solid var(--line)}
.top-tabs{flex:1 1 auto;justify-content:center;gap:4px;min-width:0;overflow-x:auto}
.top-right{flex:0 0 auto;border-left:1px solid var(--line)}
.top h1{font-size:14px;font-weight:600;margin:0 14px 0 4px;display:flex;align-items:baseline}
.top h1 .title-input{font:inherit;color:inherit;border:1px solid transparent;background:transparent;padding:2px 6px;width:140px;border-radius:4px}
.top h1 .title-input:hover{border-color:var(--line)}
.top h1 .title-input:focus{outline:none;border-color:var(--accent);background:white}
.btn{border:1px solid var(--line);background:white;padding:5px 10px;border-radius:5px;cursor:pointer;white-space:nowrap;font-size:12.5px}
.btn:hover{background:var(--accent-soft);border-color:var(--accent)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:white}
.btn.primary:hover{background:#1d4fd6}
.btn.ghost{border-color:transparent;background:transparent}
.btn.ghost:hover{background:var(--line)}
.btn-compact{padding:4px 8px;font-size:12px}
.btn.icon-btn{padding:5px 8px;font-size:13px;min-width:30px;text-align:center;background:transparent;border-color:transparent}
.btn.icon-btn:hover{background:var(--accent-soft);border-color:var(--line)}
.sep{width:1px;height:22px;background:var(--line);margin:0 4px}
/* Main tabs (Míľnik 1) */
.top-tab{display:inline-flex;align-items:center;gap:6px;padding:14px 14px 14px;
  background:transparent;border:none;border-bottom:3px solid transparent;
  cursor:pointer;font-size:13px;color:#475569;font-weight:500;
  transition:all 0.15s;position:relative;height:100%;white-space:nowrap}
.top-tab:hover{color:#0f172a;background:rgba(0,0,0,0.03)}
.top-tab.active{color:#16a34a;border-bottom-color:#16a34a;font-weight:600;
  background:linear-gradient(to bottom, transparent 0%, rgba(22,163,74,0.04) 100%)}
.top-tab .tab-ico{font-size:15px;line-height:1}
.top-tab .tab-label{font-size:13px}
.top-tab .hc-badge{margin-left:2px}
@media (max-width: 1280px){
  .top-tab .tab-label{display:none}
  .top-tab{padding:14px 10px}
}
/* Left sidebar */
.left{grid-area:left;background:var(--panel);border-right:1px solid var(--line);overflow-y:auto;padding:10px}
.left h2{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:0.5px;margin:10px 4px 4px}
.left h2.collapsible-h2{cursor:pointer;user-select:none;padding:6px 4px 6px 4px;margin:6px 0 0 0;border-radius:4px;display:flex;align-items:center;gap:6px;transition:background 0.12s}
.left h2.collapsible-h2:hover{background:#f1f5f9;color:#475569}
.left h2.collapsible-h2.collapsed{margin-bottom:0}
.left h2.collapsible-h2 .collapse-chev{font-size:10px;transition:transform 0.15s;color:#94a3b8;display:inline-block;width:10px}
.left h2.collapsible-h2.collapsed .collapse-chev{transform:rotate(-90deg)}
.left h2.collapsible-h2.collapsed{color:#475569}
.left h2:first-child{margin-top:0}
.tool-btn{display:flex;width:100%;align-items:center;gap:6px;padding:6px 8px;margin:1px 0;border:1px solid transparent;
  background:transparent;border-radius:4px;cursor:pointer;text-align:left;font-size:12.5px;position:relative}
.tool-btn:hover{background:var(--accent-soft)}
.tool-btn.active{background:var(--accent);color:white}
/* Skladacie sekcie + obľúbené (kompaktnejšie pravidlá — duplicitné ::before odstránené,
   chevron je <span class="collapse-chev"> vložený JS-om — pravidlá pre neho hore v CSS) */
.tool-btn.has-pin-star::after{content:'★';position:absolute;top:1px;right:4px;
  font-size:9px;color:#f59e0b;text-shadow:0 0 2px white;opacity:0.85;pointer-events:none}
.tool-btn.is-pinned-copy{background:#fffbeb;border:1px solid #f6d782}
.tool-btn.is-pinned-copy:hover{background:#fef3c7}
.tool-btn.is-pinned-copy::after{content:none}
#pinnedSection{margin:0 0 6px 0;padding:0 0 6px 0;border-bottom:1px solid #e5e7eb}
#pinnedSection h2{margin-top:0;margin-bottom:4px;color:#92400e}
.hc-badge{display:inline-block;min-width:18px;padding:1px 5px;margin-left:4px;border-radius:9px;
  background:#dc2626;color:white;font-size:10px;font-weight:700;text-align:center;line-height:14px;vertical-align:middle}
.hc-badge.warn{background:#f59e0b}
.hc-badge.ok{background:#16a34a}
.hc-issue{display:flex;gap:8px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:6px;margin:4px 0;
  background:#fafafa;cursor:pointer;transition:background 0.15s,border-color 0.15s}
.hc-issue:hover{background:#fff;border-color:#3b82f6}
.hc-issue.sev-error{border-left:4px solid #dc2626}
.hc-issue.sev-warn{border-left:4px solid #f59e0b}
.hc-issue.sev-info{border-left:4px solid #3b82f6}
.hc-issue .ico{font-size:18px;flex-shrink:0;line-height:1.2}
.hc-issue .body{flex:1;line-height:1.4;font-size:13px;color:#0f172a}
.hc-issue .cat-pill{display:inline-block;font-size:10px;padding:1px 6px;border-radius:8px;
  background:#e5e7eb;color:#475569;margin-right:6px;text-transform:uppercase;letter-spacing:0.4px;vertical-align:middle}
.hc-empty{padding:20px;text-align:center;color:#16a34a;font-size:14px;background:#f0fdf4;border-radius:8px;border:1px dashed #86efac}
.hc-summary{display:flex;gap:12px;margin-bottom:10px;padding:8px 12px;background:#f8fafc;border-radius:6px;font-size:13px}
.hc-summary .item{display:flex;align-items:center;gap:4px}
.hc-summary .dot{width:10px;height:10px;border-radius:50%}
.hc-summary .dot.error{background:#dc2626}
.hc-summary .dot.warn{background:#f59e0b}
.hc-summary .dot.info{background:#3b82f6}
#canvasHcBadge{position:absolute;bottom:12px;left:12px;z-index:5;background:rgba(255,255,255,0.96);
  padding:6px 12px;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,0.15);font-size:12px;
  display:none;cursor:pointer;border:1px solid #e5e7eb;font-weight:600}
#canvasHcBadge.has-errors{border-color:#dc2626;color:#991b1b}
#canvasHcBadge.has-warns{border-color:#f59e0b;color:#92400e}
#canvasHcBadge:hover{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,0.18)}
/* Kontrola návrhu — premium iterácia */
.hc-empty-ico{font-size:42px;color:#16a34a;margin-bottom:6px}
.hc-empty-text{font-weight:600;font-size:15px;margin-bottom:4px}
.hc-empty-small{font-size:11px;color:#64748b;line-height:1.5}
.hc-sum-item{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:14px;font-size:12px}
.hc-sum-item.crit{background:#fee2e2;color:#991b1b}
.hc-sum-item.warn{background:#fef3c7;color:#92400e}
.hc-sum-item.info{background:#dbeafe;color:#1e40af}
.hc-sum-item.ign{background:#e2e8f0;color:#475569}
.hc-sum-item.hand{background:#fce7f3;color:#9d174d}
.hc-section{margin:6px 0;border:1px solid #e5e7eb;border-radius:6px;background:#fafbfc}
.hc-section[open]{background:#fff}
.hc-section-head{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;list-style:none;font-weight:600}
.hc-section-head::-webkit-details-marker{display:none}
.hc-section-ico{font-size:14px}
.hc-section-title{flex:1;font-size:13px;color:#0f172a}
.hc-section-badge{color:#fff;padding:1px 8px;border-radius:9px;font-size:11px;font-weight:600;min-width:18px;text-align:center}
.hc-section-reset{margin-left:8px;font-size:10.5px;padding:2px 8px;border:1px solid #cbd5e1;background:#fff;border-radius:4px;cursor:pointer;color:#475569}
.hc-section-reset:hover{background:#fef2f2;border-color:#dc2626;color:#991b1b}
.hc-section-body{padding:4px 8px 8px}
.hc-card{padding:8px 10px;background:#fff;border:1px solid #e5e7eb;border-radius:5px;margin:4px 0;
  border-left-width:3px}
.hc-card.sev-error{border-left-color:#dc2626;background:linear-gradient(to right, #fef2f2 0%, #fff 30px)}
.hc-card.sev-warn{border-left-color:#f59e0b;background:linear-gradient(to right, #fffbeb 0%, #fff 30px)}
.hc-card.sev-info{border-left-color:#0891b2;background:linear-gradient(to right, #ecfeff 0%, #fff 30px)}
.hc-card.ignored{opacity:0.7;background:#f8fafc}
.hc-card.handled{opacity:0.85;background:linear-gradient(to right, #fdf2f8 0%, #fff 60px);border-left:3px solid #db2777}
.hc-card-head{display:flex;align-items:flex-start;gap:6px;line-height:1.4;font-size:12.5px}
.hc-sev-ico{font-size:14px;flex-shrink:0}
.hc-cat-pill{display:inline-block;font-size:9.5px;padding:1px 6px;border-radius:8px;
  background:#e2e8f0;color:#475569;text-transform:uppercase;letter-spacing:0.4px;flex-shrink:0;margin-top:1px}
.hc-msg{color:#0f172a;flex:1}
.hc-actions{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}
.hc-act{font-size:10.5px;padding:3px 8px;border:1px solid #cbd5e1;background:#fff;border-radius:4px;cursor:pointer;color:#334155;transition:all 0.12s}
.hc-act:hover{background:#f1f5f9;border-color:#64748b}
.hc-act.hc-fix:hover{background:#fef3c7;border-color:#d97706;color:#92400e}
.hc-act.hc-explain:hover{background:#dbeafe;border-color:#3b82f6;color:#1e40af}
.hc-act.hc-show:hover{background:#dcfce7;border-color:#16a34a;color:#166534}
.hc-act.hc-neighbor:hover{background:#fce7f3;border-color:#db2777;color:#9d174d}
.hc-act.hc-ignore:hover{background:#fee2e2;border-color:#dc2626;color:#991b1b}
.hc-explain-card{margin:6px 0 4px 0;padding:8px 10px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:5px}
.hc-explain-title{font-weight:700;font-size:12px;color:#075985;margin-bottom:4px}
.hc-explain-text{font-size:11.5px;line-height:1.5;color:#1e293b}
.hc-explain-source{font-size:10px;color:#64748b;margin-top:4px}
/* Kalendár starostlivosti */
.cal-cat-head{font-size:11px;font-weight:700;text-transform:uppercase;color:#64748b;
  margin:8px 0 4px;letter-spacing:0.5px;border-bottom:1px solid #e5e7eb;padding-bottom:2px}
.cal-task{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:5px;
  margin:2px 0;cursor:pointer;transition:background 0.12s}
.cal-task:hover{background:#f3f4f6}
.cal-task input[type="checkbox"]{margin-top:3px;flex-shrink:0}
.cal-task .task-txt{font-size:13px;color:#0f172a}
.cal-task .task-src{font-size:11px;color:#64748b}
.cal-task.pri-high{border-left:3px solid #dc2626;padding-left:8px}
.cal-task.pri-med{border-left:3px solid #f59e0b;padding-left:8px}
.cal-task.pri-low{border-left:3px solid #94a3b8;padding-left:8px}
/* Lifecycle status toggle — kompaktná karta s heading + 3-stĺpcový grid tlačidiel */
.lc-card{margin-top:10px;padding:8px 10px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px}
.lc-card-title{font-size:11px;font-weight:600;color:#475569;letter-spacing:0.5px;margin-bottom:6px;text-transform:uppercase}
.lc-card-hint{font-size:10px;color:#94a3b8;margin-top:6px;line-height:1.4}
.lc-toggle{display:grid;grid-template-columns:repeat(3, 1fr);gap:3px;width:100%}
.lc-btn{padding:5px 4px;font-size:10.5px;border:1px solid #cbd5e1;background:white;
  border-radius:4px;cursor:pointer;font-weight:500;white-space:nowrap;transition:all 0.12s;min-width:0;overflow:hidden;text-overflow:ellipsis}
.lc-btn:hover{background:#f3f4f6}
.lc-btn.active{color:white;font-weight:600;box-shadow:inset 0 1px 3px rgba(0,0,0,0.2)}
.lc-btn.lc-new.active{background:#2563eb;border-color:#2563eb}
.lc-btn.lc-existing.active{background:#475569;border-color:#475569}
.lc-btn.lc-move.active{background:#0284c7;border-color:#0284c7}
.lc-btn.lc-replace.active{background:#d97706;border-color:#d97706}
.lc-btn.lc-remove.active{background:#dc2626;border-color:#dc2626}
/* Vizuálne rozlíšenie objektov v 2D kreslení sa robí v drawing fn (cez obj.lifecycle) */
/* BOM nákupný zoznam */
.bom-section{margin:14px 0;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}
.bom-section summary{padding:10px 14px;cursor:pointer;font-weight:600;
  background:#f8fafc;border-bottom:1px solid #e5e7eb}
.bom-section[open] summary{border-bottom:1px solid #cbd5e1}
.bom-section.section-buy summary{background:#dbeafe;color:#1e3a8a}
.bom-section.section-remove summary{background:#fee2e2;color:#7f1d1d}
.bom-section.section-move summary{background:#e0f2fe;color:#075985}
.bom-section.section-replace summary{background:#ffedd5;color:#9a3412}
.bom-section.section-existing summary{background:#f1f5f9;color:#475569}
.bom-table{width:100%;border-collapse:collapse;font-size:12px}
.bom-table th{text-align:left;padding:8px 12px;background:#fafbfc;font-weight:600;color:#475569;border-bottom:1px solid #e5e7eb;font-size:11px;text-transform:uppercase;letter-spacing:0.4px}
.bom-table td{padding:6px 12px;border-bottom:1px solid #f3f4f6}
.bom-table .num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.bom-table .total{font-weight:700;background:#fef9c3;color:#713f12}
.bom-cat-row td{background:#f9fafb;font-weight:600;color:#475569;text-transform:uppercase;font-size:10px;letter-spacing:0.5px}
.bom-summary{display:grid;grid-template-columns:1fr auto;gap:6px 16px;padding:14px 18px;background:linear-gradient(135deg,#fef3c7,#fef9c3);border-radius:8px;font-size:14px;margin-bottom:10px}
.bom-summary .label{color:#451a03}
.bom-summary .amt{font-weight:700;color:#0f172a;font-variant-numeric:tabular-nums;text-align:right}
.bom-summary .total-row{padding-top:8px;margin-top:4px;border-top:2px solid rgba(120,53,15,0.3);font-size:16px}
.bom-summary .total-row .label{font-weight:700}
/* Asistent panel (pravý panel keď nič nie je vybrané) */
.ap-block{margin-bottom:14px}
.ap-section-head{font-size:11px;font-weight:700;text-transform:uppercase;color:#475569;letter-spacing:0.5px;margin:0 0 6px;padding-bottom:4px;border-bottom:1px solid #e5e7eb}
/* Wizard panel — checklist a krokovník */
.ap-progress{margin:0 0 8px}
.ap-progress-row{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#475569;margin-bottom:3px}
.ap-progress-label{font-weight:500}
.ap-progress-pct{font-weight:700;font-size:13px}
.ap-progress-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}
.ap-progress-fill{height:100%;background:#2563eb;border-radius:3px;transition:width 0.35s ease}
.ap-wizard-teaser{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd}
.ap-wizard{background:#f8fafc;border:1px solid #cbd5e1}
.ap-wiz-head{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.ap-wiz-scenario{font-size:10.5px;background:#dbeafe;color:#1e40af;padding:1px 8px;border-radius:9px;flex:1}
.ap-wiz-close{background:none;border:none;cursor:pointer;font-size:16px;color:#94a3b8;padding:0 4px}
.ap-wiz-close:hover{color:#475569}
.ap-wiz-list{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}
.ap-wiz-step{display:flex;align-items:center;gap:6px;padding:5px 7px;background:white;border:1px solid #e5e7eb;border-radius:5px;cursor:pointer;transition:background 0.12s,border 0.12s}
.ap-wiz-step:hover{background:#f1f5f9;border-color:#94a3b8}
.ap-wiz-step.active{border-color:#2563eb;background:#eff6ff;box-shadow:inset 2px 0 0 #2563eb}
.ap-wiz-step.ws-done{background:#f0fdf4;border-color:#86efac}
.ap-wiz-step.ws-done .ap-wiz-num,.ap-wiz-step.ws-done .ap-wiz-title{color:#15803d}
.ap-wiz-step.ws-skipped{opacity:0.55}
.ap-wiz-num{font-size:11px;font-weight:700;color:#94a3b8;width:14px;text-align:center;flex-shrink:0}
.ap-wiz-ico{font-size:14px;flex-shrink:0}
.ap-wiz-body{flex:1;min-width:0}
.ap-wiz-title{font-size:11.5px;font-weight:600;color:#1e293b;line-height:1.2}
.ap-wiz-sub{font-size:10px;color:#94a3b8;line-height:1.3}
.ap-wiz-status{font-size:13px;flex-shrink:0;width:14px;text-align:center}
.ap-wiz-step.ws-done .ap-wiz-status{color:#15803d}
.ap-wiz-step.ws-in_progress .ap-wiz-status{color:#2563eb}
.ap-wiz-foot{display:flex;gap:4px}
.ap-wiz-foot .btn{flex:1;font-size:11px;padding:5px 6px}
/* Scenárový modal — hero karty */
.wiz-scenarios{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.wiz-sc-card{background:white;border:2px solid #e5e7eb;border-radius:8px;padding:14px;cursor:pointer;text-align:left;transition:all 0.15s}
.wiz-sc-card:hover{border-color:#2563eb;box-shadow:0 2px 8px rgba(37,99,235,0.12)}
.wiz-sc-card .ico{font-size:32px;line-height:1;margin-bottom:6px}
.wiz-sc-card .title{font-size:14px;font-weight:700;color:#0f172a;margin-bottom:4px}
.wiz-sc-card .desc{font-size:11.5px;color:#64748b;line-height:1.4}
.wiz-import-list{display:flex;flex-direction:column;gap:6px}
.wiz-import-item{display:flex;align-items:flex-start;gap:10px;background:white;border:1px solid #e5e7eb;border-radius:6px;padding:10px;cursor:pointer;text-align:left;transition:border 0.12s}
.wiz-import-item:hover{border-color:#2563eb;background:#eff6ff}
.wiz-import-item .ico{font-size:22px;flex-shrink:0}
/* Wizard step modal — obsah */
.wiz-explain{background:#eff6ff;border-left:3px solid #2563eb;padding:8px 10px;font-size:12px;color:#1e3a8a;border-radius:0 5px 5px 0;line-height:1.45}
.wiz-checkboxes{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:6px}
.wiz-checkboxes label{display:flex;align-items:center;gap:6px;font-size:12px;color:#0f172a;cursor:pointer;padding:3px}
.wiz-step-foot{display:flex;gap:6px;flex-wrap:wrap}
.wiz-step-foot .btn{flex:1;min-width:auto}
/* Wizard panel — track labels */
.ap-wiz-track-label{font-size:10px;font-weight:700;color:#94a3b8;letter-spacing:0.5px;margin:6px 0 3px;text-transform:uppercase}
/* Lesson modal — vrstvený obsah */
.wiz-modal .modal-body{max-height:65vh;overflow-y:auto}
.wiz-step-sub{font-size:12px;color:#64748b;margin-bottom:10px;font-style:italic}
.wiz-warn{background:#fef3c7;border-left:3px solid #d97706;padding:8px 10px;font-size:11.5px;color:#7c2d12;border-radius:0 5px 5px 0;margin-bottom:10px;line-height:1.45}
.wiz-summary{background:#f0fdf4;border-left:3px solid #16a34a;padding:8px 10px;border-radius:0 5px 5px 0;margin-bottom:8px}
.wiz-summary-label{font-size:10.5px;font-weight:700;color:#15803d;text-transform:uppercase;letter-spacing:0.4px;margin-bottom:3px}
.wiz-summary-text{font-size:12.5px;color:#0f172a;line-height:1.5}
.wiz-section{margin:6px 0;border:1px solid #e5e7eb;border-radius:5px;background:#fafbfc}
.wiz-section[open]{background:#fff}
.wiz-section summary{padding:7px 10px;cursor:pointer;font-weight:600;font-size:12px;color:#475569;list-style:none}
.wiz-section summary::-webkit-details-marker{display:none}
.wiz-list{margin:6px 12px 8px;padding:0 0 0 14px;font-size:11.5px;color:#334155;line-height:1.55}
.wiz-list li{margin:3px 0}
.wiz-mistakes li::marker{color:#dc2626}
.wiz-section-deep summary{color:#1e3a8a}
.wiz-section-deep[open] summary{border-bottom:1px solid #dbeafe}
.wiz-section-hint{font-weight:normal;color:#94a3b8;font-size:10.5px;margin-left:4px}
.wiz-deepdive{padding:10px 14px;font-size:12.5px;color:#1e293b;line-height:1.65;background:#f8fafc}
.wiz-deepdive p{margin:0 0 9px 0}
.wiz-deepdive p:last-child{margin-bottom:0}
.wiz-deepdive b{color:#0f172a}
.wiz-deepdive i{color:#475569}
.wiz-interactive{margin-top:14px;padding-top:10px;border-top:2px solid #2563eb}
.wiz-int-head{font-size:13px;font-weight:700;color:#1e3a8a;margin-bottom:8px}
.wiz-subhead{font-size:11px;font-weight:700;color:#475569;letter-spacing:0.4px;text-transform:uppercase;margin:10px 0 5px}
/* Lesson 1 — checklist */
.wiz-checklist{display:flex;flex-direction:column;gap:3px}
.wiz-checklist-item{display:flex;align-items:flex-start;gap:6px;padding:5px 7px;border:1px solid #e5e7eb;border-radius:4px;background:white;cursor:pointer;transition:background 0.1s,border 0.1s}
.wiz-checklist-item:hover{background:#f8fafc;border-color:#94a3b8}
.wiz-checklist-item input{margin-top:2px}
.wiz-cli-icon{font-size:14px;flex-shrink:0;width:18px;text-align:center}
.wiz-cli-body{flex:1;min-width:0}
.wiz-cli-label{font-size:12px;font-weight:500;color:#0f172a;line-height:1.3}
.wiz-cli-tool{font-size:10px;color:#94a3b8;margin-top:1px}
.wiz-auto-badge{font-size:9.5px;background:#dcfce7;color:#15803d;padding:1px 6px;border-radius:8px;margin-left:6px;font-weight:600}
/* Lekcia 2 — DNA kresliace nástroje */
.wiz-dna-tools{display:flex;flex-direction:column;gap:5px}
.wiz-dna-btn{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:5px;cursor:pointer;text-align:left;transition:all 0.12s}
.wiz-dna-btn:hover{background:#e0f2fe;border-color:#0891b2}
.wiz-dna-btn .ico{font-size:18px;flex-shrink:0}
.wiz-dna-btn div{flex:1;font-size:12px;color:#0c4a6e;line-height:1.4}
.wiz-dna-btn b{color:#075985}
/* Lekcie 4, 5 — wishlist chips */
.wiz-chips{display:flex;flex-wrap:wrap;gap:5px;margin:6px 0}
.wiz-chip{display:flex;align-items:center;gap:4px;padding:5px 10px;background:white;border:1px solid #cbd5e1;border-radius:14px;cursor:pointer;font-size:12px;color:#475569;transition:all 0.12s}
.wiz-chip:hover{border-color:#94a3b8;background:#f8fafc}
.wiz-chip.active{background:#dbeafe;border-color:#2563eb;color:#1e40af;font-weight:600}
.wiz-chip .ico{font-size:14px}
/* Lekcia 10 — phases */
.wiz-phases{display:flex;flex-direction:column;gap:6px;margin:8px 0}
.wiz-phase-row{display:flex;align-items:center;gap:8px;font-size:12px}
.wiz-phase-label{flex:0 0 180px;color:#475569;font-weight:500}
.wiz-phase-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}
.wiz-phase-fill{height:100%;background:linear-gradient(90deg,#2563eb,#3b82f6);transition:width 0.35s ease}
.wiz-phase-count{flex:0 0 80px;text-align:right;color:#0f172a;font-size:11px}
.wiz-out-buttons{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
.ap-status{display:flex;flex-direction:column;gap:1px}
.ap-status-row{display:flex;justify-content:space-between;align-items:center;padding:5px 8px;border-radius:5px;font-size:12.5px;transition:background 0.12s}
.ap-status-row:hover{background:#f8fafc}
.ap-status-row .lbl{color:#475569;font-weight:500}
.ap-status-row .val{font-weight:600;font-variant-numeric:tabular-nums}
.ap-status-row.st-ok .val{color:#16a34a}
.ap-status-row.st-empty .val{color:#94a3b8;font-style:italic;font-weight:400}
.ap-status-row.st-err .val{color:#dc2626;font-weight:700}
.ap-recs{display:flex;flex-direction:column;gap:6px}
.ap-rec{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;transition:all 0.15s;font-size:13px}
.ap-rec[data-assist]:hover{background:#dbeafe;border-color:#93c5fd;transform:translateX(2px)}
.ap-rec .ico{font-size:18px;flex-shrink:0;width:24px;text-align:center}
.ap-rec .txt{color:#0f172a;font-weight:500;line-height:1.3}
.ap-rec .hint{color:#64748b;font-size:11px;margin-top:2px}
.ap-rec .arr{color:#94a3b8;font-size:18px;margin-left:auto;flex-shrink:0}
.ap-rec[data-assist]:hover .arr{color:#2563eb}
.ap-tip{margin-top:14px;padding:10px;background:#fef3c7;border-left:3px solid #f59e0b;border-radius:4px;font-size:11px;line-height:1.5;color:#713f12}
.ap-tip b{color:#451a03}
/* Ukážkové projekty galéria */
.sample-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.sample-card{padding:16px;border:2px solid #e2e8f0;border-radius:10px;background:white;cursor:pointer;transition:all 0.18s;display:flex;flex-direction:column;gap:6px}
.sample-card:hover{border-color:#16a34a;background:#f0fdf4;transform:translateY(-2px);box-shadow:0 4px 12px rgba(22,163,74,0.15)}
.sample-card .sample-thumb{font-size:42px;line-height:1;text-align:center;margin-bottom:4px;background:linear-gradient(135deg,#dcfce7,#dbeafe);border-radius:8px;padding:0;overflow:hidden;min-height:140px;display:flex;align-items:center;justify-content:center}
.sample-card .sample-thumb-img{display:block;width:100%;height:auto;max-height:180px;object-fit:cover;border-radius:8px}
.sample-card .sample-thumb-loading{padding:18px 0;animation:pulse 1.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
/* Top-right "Viac" overflow menu */
.more-menu-wrap{position:relative;display:inline-block}
.more-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #cbd5e1;
  border-radius:6px;box-shadow:0 8px 24px rgba(0,0,0,0.12);min-width:260px;z-index:50;padding:4px 0}
.more-menu-section{font-size:10px;font-weight:700;color:#94a3b8;padding:6px 12px 2px;
  text-transform:uppercase;letter-spacing:0.6px}
.more-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 12px;background:none;
  border:none;cursor:pointer;font-size:13px;color:#0f172a;text-align:left;transition:background 0.1s}
.more-item:hover{background:#f1f5f9}
.more-item .ico{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.more-item span:last-child{flex:1}
.sample-card h4{margin:0;font-size:14px;color:#0f172a;font-weight:600}
.sample-card p{margin:0;font-size:12px;color:#475569;line-height:1.45}
.sample-card .sample-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto;padding-top:6px}
.sample-card .sample-tags span{font-size:10px;padding:2px 8px;background:#f1f5f9;color:#475569;border-radius:10px;text-transform:lowercase}
.sample-card:hover .sample-tags span{background:#bbf7d0;color:#15803d}
.hc-fix-btn{display:inline-block;margin-top:6px;padding:4px 10px;font-size:11px;background:#dbeafe;
  border:1px solid #93c5fd;color:#1d4ed8;border-radius:5px;cursor:pointer;font-weight:600}
.hc-fix-btn:hover{background:#bfdbfe;border-color:#3b82f6}
.hc-fix-btn:disabled{opacity:0.5;cursor:not-allowed}
.hc-fix-btn.applied{background:#dcfce7;border-color:#86efac;color:#15803d}
/* === ONBOARDING / TOUR === */
.welcome-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:14px 0}
.welcome-card{padding:12px;border:1px solid #e2e8f0;border-radius:10px;background:#fafafa}
.welcome-card .ico{font-size:30px;line-height:1;margin-bottom:6px}
.welcome-card h4{margin:0 0 4px;font-size:14px;color:#0f172a}
.welcome-card p{margin:0;font-size:12px;color:#475569;line-height:1.45}
.welcome-hero{padding:20px 16px;background:linear-gradient(135deg,#dbeafe,#dcfce7);border-radius:12px;text-align:center;margin-bottom:6px}
.welcome-hero h1{margin:0;font-size:24px;color:#0f172a}
.welcome-hero p{margin:6px 0 0;color:#475569;font-size:14px}
.welcome-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}
.tour-tip{position:fixed;z-index:9999;background:white;border:2px solid #2563eb;border-radius:10px;
  padding:12px 14px;max-width:320px;box-shadow:0 8px 32px rgba(0,0,0,0.18);font-size:13px;line-height:1.5}
.tour-tip h4{margin:0 0 4px;font-size:14px;color:#1d4ed8;display:flex;align-items:center;gap:6px}
.tour-tip p{margin:0 0 10px;color:#0f172a}
.tour-tip .tour-actions{display:flex;justify-content:space-between;align-items:center;gap:6px}
.tour-tip .tour-step-info{font-size:11px;color:#64748b}
.tour-tip .tour-btns{display:flex;gap:6px}
.tour-tip .tour-btn{padding:4px 10px;font-size:12px;border:1px solid #cbd5e1;background:white;border-radius:5px;cursor:pointer}
.tour-tip .tour-btn.primary{background:#2563eb;color:white;border-color:#2563eb}
.tour-tip .tour-btn:hover{filter:brightness(0.95)}
.tour-tip::before{content:'';position:absolute;width:12px;height:12px;background:white;
  border-left:2px solid #2563eb;border-top:2px solid #2563eb;transform:rotate(-45deg)}
.tour-tip.point-left::before{left:-8px;top:18px}
.tour-tip.point-right::before{right:-8px;top:18px;transform:rotate(135deg)}
.tour-tip.point-top::before{top:-8px;left:18px;transform:rotate(45deg)}
.tour-tip.point-bottom::before{bottom:-8px;left:18px;transform:rotate(-135deg)}
.tour-spotlight{position:fixed;z-index:9998;pointer-events:none;border:3px solid #2563eb;
  border-radius:8px;box-shadow:0 0 0 9999px rgba(15,23,42,0.45);transition:all 0.25s ease}
.tool-btn .ico{width:18px;text-align:center;font-size:13px}
.tool-btn .sw{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,0.15)}
.shape-btn{flex:1;padding:4px 0;border:1px solid var(--line);background:white;border-radius:4px;cursor:pointer;font-size:14px}
.shape-btn:hover{background:var(--accent-soft)}
.shape-btn.active{background:var(--accent);color:white;border-color:var(--accent)}
.acc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px;margin-bottom:6px}
.acc-card{border:1px solid var(--line);border-radius:6px;padding:6px 8px;cursor:pointer;background:white}
.acc-card:hover{background:var(--accent-soft)}
.acc-card.active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 2px rgba(37,99,235,0.18)}
.acc-icon{width:34px;height:34px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:4px}
.filter-btn{padding:4px 10px;border:1px solid var(--line);background:white;border-radius:14px;cursor:pointer;font-size:12px}
.filter-btn:hover{background:var(--accent-soft)}
.filter-btn.active{background:var(--accent);color:white;border-color:var(--accent)}
.phase-btn{padding:2px 8px;min-width:24px;border:1px solid var(--line);background:white;border-radius:10px;cursor:pointer;font-size:12px;font-weight:600}
.phase-btn:hover{background:var(--accent-soft)}
.phase-btn.active{background:var(--accent);color:white;border-color:var(--accent)}
.phase-btn.def{outline:2px dashed #c79a3a;outline-offset:1px}
.phase-btn.small-btn{font-size:13px;padding:2px 6px}
/* Center */
.center{grid-area:center;position:relative;background:#eceae1;overflow:hidden}
#canvas2d{display:block;width:100%;height:100%;cursor:crosshair;touch-action:none}
.zoom-controls{position:absolute;right:12px;bottom:12px;display:flex;flex-direction:column;gap:4px;background:var(--panel);
  padding:4px;border-radius:6px;box-shadow:0 2px 6px rgba(0,0,0,0.1);z-index:5}
.zoom-controls button{width:30px;height:30px;border:1px solid var(--line);background:white;border-radius:4px;cursor:pointer;font-size:14px}
.zoom-controls button:hover{background:var(--accent-soft)}
.center-hint{position:absolute;left:12px;top:12px;background:rgba(255,255,255,0.92);padding:6px 10px;border-radius:5px;
  font-size:12px;color:var(--muted);max-width:520px;box-shadow:0 1px 3px rgba(0,0,0,.08);z-index:4}
/* Right sidebar */
.right{grid-area:right;background:var(--panel);border-left:1px solid var(--line);overflow-y:auto}
.right .panel{padding:12px;border-bottom:1px solid var(--line)}
.right h2{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--muted);margin:0 0 8px;letter-spacing:0.5px}
/* Validation issue items */
.issue-item{display:flex;gap:6px;padding:6px 8px;margin:3px 0;border-radius:4px;cursor:pointer;border:1px solid transparent;font-size:12px;line-height:1.35;align-items:flex-start}
.issue-item:hover{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.1)}
.issue-item .issue-icon{flex-shrink:0;font-size:14px;line-height:1;margin-top:1px}
.issue-item .issue-body{flex:1;min-width:0}
.issue-item .issue-msg{font-weight:500;color:#0f172a}
.issue-item .issue-tip{font-size:11px;color:#64748b;margin-top:2px}
.issue-error{background:#fef2f2;border-color:#fca5a5}
.issue-error:hover{background:#fee2e2;border-color:#f87171}
.issue-error .issue-msg{color:#991b1b}
.issue-warning{background:#fffbeb;border-color:#fcd34d}
.issue-warning:hover{background:#fef3c7}
.issue-warning .issue-msg{color:#92400e}
.issue-tip-sev{background:#eff6ff;border-color:#bfdbfe}
.issue-tip-sev:hover{background:#dbeafe}
.issue-tip-sev .issue-msg{color:#1e40af}
.issue-cat-chip{display:inline-block;font-size:10px;padding:1px 5px;border-radius:3px;background:rgba(0,0,0,0.07);color:#475569;margin-right:4px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px}
#validateBadge .b-err{background:#dc2626;color:white;padding:1px 6px;border-radius:9px;margin-left:3px}
#validateBadge .b-warn{background:#f59e0b;color:white;padding:1px 6px;border-radius:9px;margin-left:3px}
#validateBadge .b-tip{background:#3b82f6;color:white;padding:1px 6px;border-radius:9px;margin-left:3px}
#validateBadge .b-ok{background:#10b981;color:white;padding:1px 8px;border-radius:9px}
.val-filter{display:inline-block;padding:2px 8px;margin:0 2px 2px 0;border:1px solid #cbd5e1;border-radius:10px;cursor:pointer;background:white;font-size:11px;user-select:none}
.val-filter.on{background:#0ea5e9;color:white;border-color:#0284c7}
.val-filter:hover{border-color:#94a3b8}
.right h3{font-size:14px;font-weight:600;margin:0 0 6px}
.field{display:flex;align-items:center;gap:6px;margin:4px 0}
.field label{width:90px;color:var(--muted);font-size:12px}
.field input,.field select,.field textarea{flex:1;padding:4px 6px;border:1px solid var(--line);border-radius:4px;min-width:0;background:white}
.field input[type="number"]{width:80px;flex:0 0 auto}
.field .unit{color:var(--muted);font-size:11px}
.field .color-swatch{width:26px;height:22px;border-radius:4px;border:1px solid var(--line2);cursor:pointer}
/* Material picker karty — vizuálny výber materiálu namiesto dropdownu */
.mat-picker-field{flex-direction:column;align-items:stretch}
.mat-picker-field>label{width:auto;margin-bottom:4px}
.mat-picker-wrap{display:flex;flex-direction:column;gap:4px}
.mat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:4px;max-height:220px;overflow-y:auto;padding:2px;background:#f8fafc;border:1px solid var(--line);border-radius:4px}
.mat-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:3px;background:white;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:border-color 0.1s ease}
.mat-card:hover{border-color:#cbd5e1}
.mat-card.selected{border-color:#2563eb;background:#eff6ff}
.mat-card img{width:48px;height:48px;border-radius:3px;display:block;object-fit:cover}
.mat-card-lbl{font-size:10px;line-height:1.1;text-align:center;color:#475569;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mat-card.selected .mat-card-lbl{color:#1e3a8a;font-weight:600}
.mat-picker-select{display:none}
.btn-row{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.layer-row{display:flex;align-items:center;gap:6px;padding:3px 0}
.layer-row input{margin:0}
.chip{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;background:var(--line);color:var(--ink)}
/* Status */
.status{grid-area:status;background:var(--panel);border-top:1px solid var(--line);display:flex;align-items:center;
  padding:0 12px;font-size:11px;color:var(--muted);gap:16px}
.status .pos{margin-left:auto}
/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;z-index:100}
.modal{background:var(--panel);border-radius:8px;max-width:90vw;max-height:90vh;overflow:auto;box-shadow:0 10px 40px rgba(0,0,0,.3);display:flex;flex-direction:column}
.modal.large{width:1100px;height:780px}
.modal.med{width:640px}
.modal.lg{width:780px}
.modal.wide{width:900px}
.modal-head{padding:12px 16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-head h3{margin:0;font-size:15px}
.modal-body{padding:14px 16px;flex:1;overflow:auto}
.modal-foot{padding:10px 16px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}
.close-x{border:none;background:transparent;font-size:20px;cursor:pointer;color:var(--muted);padding:0 6px}
.close-x:hover{color:var(--ink)}
/* Tables */
table.dt{width:100%;border-collapse:collapse;margin:4px 0}
table.dt th,table.dt td{text-align:left;padding:5px 8px;border-bottom:1px solid var(--line);font-size:12px}
table.dt th{background:#f8fafc;font-weight:600;color:var(--muted)}
table.dt td.num{text-align:right;font-variant-numeric:tabular-nums}
table.dt tfoot td{font-weight:700;border-top:2px solid var(--line2)}
/* 3D modal specifics */
#three-container{width:100%;height:100%;background:#e8eef5;position:relative;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
#three-container canvas{touch-action:none}
#three-canvas{display:block;width:100%;height:100%}
.three-controls{position:absolute;left:10px;top:10px;background:rgba(255,255,255,0.94);
  border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.15);font-size:12px;
  min-width:200px;max-width:320px;transition:max-width 0.2s, max-height 0.25s ease;
  overflow:hidden;border:1px solid rgba(0,0,0,0.08)}
.three-controls.collapsed{min-width:auto;max-width:240px}
.three-controls-header{display:flex;align-items:center;gap:8px;padding:8px 10px;
  cursor:pointer;user-select:none;background:rgba(243,244,246,0.6);
  border-bottom:1px solid rgba(0,0,0,0.08);transition:background 0.15s}
.three-controls-header:hover{background:rgba(229,231,235,0.9)}
.three-controls.collapsed .three-controls-header{border-bottom:none}
.three-controls-header .chev{font-size:10px;color:#64748b;transition:transform 0.2s;margin-left:auto}
.three-controls.collapsed .three-controls-header .chev{transform:rotate(-90deg)}
.three-controls-header .compact-summary{font-weight:600;color:#0f172a}
.three-controls-body{padding:8px 10px 10px;max-height:600px;overflow:hidden;transition:max-height 0.25s ease, padding 0.2s, opacity 0.2s}
.three-controls.collapsed .three-controls-body{max-height:0;padding-top:0;padding-bottom:0;opacity:0}
.three-controls .sun-row{display:flex;align-items:center;gap:8px;margin-top:6px}
.three-controls input[type="range"]{flex:1}
.three-controls small{color:var(--muted)}
/* Plant library */
.plant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}
.plant-card{border:1px solid var(--line);border-radius:6px;padding:8px;cursor:pointer;background:white;display:flex;flex-direction:column}
.plant-card:hover{border-color:#2563eb;box-shadow:0 1px 6px rgba(37,99,235,0.12)}
.plant-card.active{border-color:#16a34a;background:#f0fdf4;box-shadow:0 1px 6px rgba(22,163,74,0.18)}
.plant-card h4{margin:0 0 2px;font-size:13.5px;color:#0f172a}
.plant-card .latin{font-style:italic;font-size:11px;color:#64748b;margin-bottom:6px}
.plant-card .plant-props{list-style:none;padding:0;margin:4px 0 6px;font-size:11px;color:#334155;line-height:1.5}
.plant-card .plant-props li{display:flex;align-items:center;gap:5px}
.plant-card .plant-props li .ico{font-size:11px;width:14px;text-align:center}
.plant-card .plant-props li .muted{color:#94a3b8}
.plant-card-actions{margin-top:auto;padding-top:6px;display:flex;gap:4px}
.plant-btn{flex:1;padding:4px 8px;font-size:11.5px;border:1px solid #cbd5e1;background:#fff;border-radius:4px;cursor:pointer;color:#334155}
.plant-btn:hover{background:#f1f5f9}
.plant-btn.primary{background:#2563eb;color:#fff;border-color:#1d4ed8}
.plant-btn.primary:hover{background:#1d4ed8}
/* Filter bar pre knižnicu */
.plant-filters{background:#f8fafc;border:1px solid #e5e7eb;border-radius:5px;padding:6px 8px;margin-bottom:8px}
.plant-filter-row{display:flex;align-items:center;gap:8px;padding:3px 0;flex-wrap:wrap}
.plant-filter-label{font-size:11px;font-weight:600;color:#475569;width:60px;flex-shrink:0;text-transform:uppercase;letter-spacing:0.4px}
.plant-filter-chips{display:flex;gap:3px;flex-wrap:wrap;flex:1}
.filter-chip{font-size:11px;padding:2px 8px;border:1px solid #cbd5e1;background:#fff;border-radius:11px;cursor:pointer;color:#475569;line-height:1.4}
.filter-chip:hover{background:#f1f5f9;border-color:#64748b}
.filter-chip.active{background:#2563eb;color:#fff;border-color:#1d4ed8;font-weight:600}
/* Replace similar modal */
.rs-current{background:#f0fdf4;border:1px solid #86efac;border-radius:5px;padding:8px 10px}
.rs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px}
.rs-card{border:1px solid #e5e7eb;border-radius:5px;padding:6px 8px;background:#fff;display:flex;flex-direction:column}
.rs-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:6px}
.rs-name{flex:1;font-size:12.5px;line-height:1.3}
.rs-score{color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:8px;flex-shrink:0}
.rs-props{display:flex;gap:6px;flex-wrap:wrap;font-size:11px;color:#475569;margin-top:4px}
.rs-actions{margin-top:6px}
.rs-actions .rs-pick{width:100%;padding:3px 6px;font-size:11px}
.plant-card:hover{border-color:var(--accent);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.plant-card.active{border-color:var(--accent);background:var(--accent-soft)}
.plant-card h4{margin:0 0 2px;font-size:13px}
.plant-card .latin{color:var(--muted);font-style:italic;font-size:11px;margin-bottom:6px}
.plant-card .meta{font-size:11px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px}
.plant-card .bloom{display:flex;gap:1px;margin-top:4px}
.plant-card .bloom .m{flex:1;height:8px;background:#eee;border-radius:1px;font-size:0}
.plant-card .bloom .m.on{background:linear-gradient(180deg,#f9a8d4,#db2777)}
.plant-card .bloom .m.autumn{background:linear-gradient(180deg,#fbbf24,#c2410c)}
/* Small helpers */
.muted{color:var(--muted)}
.small{font-size:11px}
.flex{display:flex}
.flex.gap{gap:8px}
.flex.col{flex-direction:column}
.grow{flex:1}
.nowrap{white-space:nowrap}
.danger{color:var(--danger)}
.ok{color:var(--ok)}
hr{border:none;border-top:1px solid var(--line);margin:10px 0}
.kbd{font-family:ui-monospace,monospace;background:#f1f5f9;padding:1px 5px;border-radius:3px;font-size:11px;border:1px solid var(--line)}
/* Templates */
.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}
.tpl-card{border:1px solid var(--line);border-radius:6px;padding:10px;cursor:pointer;background:white}
.tpl-card:hover{border-color:var(--accent);background:var(--accent-soft)}
.tpl-card h4{margin:0 0 4px;font-size:13px}
.tpl-card .plants{font-size:11px;color:var(--muted)}
.tpl-card .preview{height:60px;background:#f8fafc;border:1px dashed var(--line);border-radius:4px;margin-top:6px;position:relative;overflow:hidden}
/* Price table */
.price-tbl td,.price-tbl th{padding:4px 6px;border-bottom:1px solid var(--line);font-size:12px}
.price-tbl input{width:80px;padding:2px 4px;border:1px solid var(--line);border-radius:3px;text-align:right}
/* Warning */
.warn-box{background:#fef3c7;border-left:3px solid var(--warn);padding:6px 10px;border-radius:4px;margin:8px 0;font-size:12px}
.warn-box b{color:#b45309}
.ok-box{background:#dcfce7;border-left:3px solid var(--ok);padding:6px 10px;border-radius:4px;margin:8px 0;font-size:12px}
/* History dropdown */
.history-dd{position:absolute;top:38px;left:100px;background:white;border:1px solid var(--line);border-radius:6px;
  box-shadow:0 4px 12px rgba(0,0,0,.12);min-width:220px;max-height:280px;overflow-y:auto;z-index:50;display:none}
.history-dd.on{display:block}
.history-dd .h-item{padding:6px 10px;border-bottom:1px solid var(--line);cursor:pointer;font-size:12px}
.history-dd .h-item:hover{background:var(--accent-soft)}
.history-dd .h-item.cur{background:#fef3c7}
/* Heatmap legend */
.hm-legend{position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,0.95);padding:6px 10px;border-radius:5px;
  font-size:11px;box-shadow:0 1px 3px rgba(0,0,0,.1);z-index:4;display:none}
.hm-legend.on{display:block}
.hm-legend .bar{width:140px;height:10px;border-radius:2px;margin:3px 0}
.hm-legend.sun .bar{background:linear-gradient(90deg,#1e293b,#7c2d12,#f59e0b,#fde68a,#fffbeb)}
.hm-legend.irr .bar{background:linear-gradient(90deg,#7f1d1d,#dc2626,#facc15,#16a34a,#064e3b)}
.hm-legend.slope{left:170px}
.hm-legend .labels{display:flex;justify-content:space-between;color:var(--muted);font-size:10px}
/* Template preview mini drawing */
.tpl-preview svg{width:100%;height:60px}
/* Toolbar toggle button active look */
.btn.toggle-on{background:var(--accent);color:white;border-color:var(--accent)}
.btn.toggle-on:hover{background:#1d4fd6}
/* ═══════════════════════════════════════════════════════════
   TOUCH DEVICES (iPad, tablety) — väčšie ciele pre prsty
   ═══════════════════════════════════════════════════════════ */
@media (pointer: coarse){
  /* Min touch target 44×44 px per Apple HIG */
  .tool-btn{padding:8px 10px;font-size:13.5px;min-height:38px}
  .tool-btn .ico{font-size:16px}
  .btn{padding:8px 14px;font-size:13px;min-height:36px}
  .btn.btn-compact{padding:6px 10px;font-size:12px;min-height:32px}
  .btn.icon-btn{padding:8px 10px;min-width:38px;min-height:38px}
  .top-tab{padding:8px 12px;min-height:42px}
  .filter-chip,.filter-btn{padding:5px 12px;font-size:12.5px;min-height:30px}
  .lc-btn{padding:7px 6px;font-size:12px;min-height:34px}
  .shape-btn{min-width:36px;min-height:36px;font-size:14px}
  .field input,.field select{padding:7px 8px;font-size:13px}
  .field input[type=checkbox]{width:20px;height:20px}
  /* Vypnúť hover efekty na touch (nezmysl) */
  .tool-btn:hover,.btn:hover{background:initial}
  /* Aktívny stav pri tapnutí */
  .tool-btn:active{background:#dbeafe;transform:scale(0.97)}
  .btn:active{background:#e0e7ff;transform:scale(0.97)}
  /* Canvas nemá kontextové menu na long-press */
  canvas{touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
}
/* iPad portrait — užší ľavý panel, ale zachovaná funkčnosť */
@media (min-width:601px) and (max-width:1024px) and (orientation:portrait){
  .app{grid-template-columns:180px 1fr 240px}
  .left{padding:6px 4px}
  .right{padding:6px 4px;font-size:12px}
  .tool-btn span:not(.ico):not(.sw){font-size:12px}
}
/* iPad landscape — viac priestoru pre canvas */
@media (min-width:1025px) and (max-width:1366px) and (orientation:landscape){
  .app{grid-template-columns:200px 1fr 270px}
}
/* iOS Safari — disable text selection, double-tap zoom, scroll bounce */
html,body{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;
  overscroll-behavior:none;touch-action:manipulation}
.app{touch-action:manipulation}
input,textarea,select{touch-action:manipulation}
/* Modal scrollovateľný na iPade */
@media (pointer: coarse){
  .modal{max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .modal-body{-webkit-overflow-scrolling:touch}
}
/* Dimension/measure styling helpers (for SVG-like colors in JS) */
@media (max-width:900px){
  .app{grid-template-columns:56px 1fr 0;grid-template-areas:"top top top" "left center center" "status status status"}
  .right{display:none}
  .left{padding:4px}
  .left h2{font-size:9px;margin:6px 2px 2px}
  .tool-btn{font-size:0;padding:4px;justify-content:center}
  .tool-btn .ico,.tool-btn .sw{font-size:13px}
  .tool-btn span:not(.ico):not(.sw){display:none}
}
