/* ── SVETLÁ TÉMA ── */
:root{
  --bg:#f5f5f7;--surface:#ffffff;--surface2:#f0f0f3;--surface3:#e8e8ed;
  --line:rgba(0,0,0,.08);--line2:rgba(0,0,0,.12);
  --tx:#1d1d1f;--tm:rgba(60,60,67,.62);--tl:rgba(60,60,67,.4);
  --ac:#6d28d9;--acl:rgba(109,40,217,.10);--acg:rgba(109,40,217,.22);
  --ok:#34c759;--okl:rgba(52,199,89,.12);
  --wa:#ff9500;--wal:rgba(255,149,0,.14);
  --er:#ff3b30;--erl:rgba(255,59,48,.10);
  --info:#7c3aed;--infol:rgba(124,58,237,.10);
  --pu:#6d28d9;--pul:rgba(109,40,217,.10);
  --cy:#7c3aed;--cyl:rgba(124,58,237,.10);
  --shadow-s:0 1px 3px rgba(0,0,0,.05);
  --shadow-m:0 4px 16px rgba(0,0,0,.07);
  --shadow-l:0 12px 40px rgba(0,0,0,.12);
  --r:16px;--rs:12px;--rl:22px;
  --maxw:800px;
  --bubble-in:#e9e9eb;
  --field:#ffffff;
  --overlay:rgba(0,0,0,.4);
}

/* ── TMAVÁ TÉMA – teplá, pokojná, nie terminál ── */
[data-theme="dark"]{
  --bg:#000000;--surface:#1c1c1e;--surface2:#2c2c2e;--surface3:#3a3a3c;
  --line:rgba(255,255,255,.10);--line2:rgba(255,255,255,.16);
  --tx:#f5f5f7;--tm:rgba(235,235,245,.6);--tl:rgba(235,235,245,.35);
  --ac:#a855f7;--acl:rgba(168,85,247,.18);--acg:rgba(168,85,247,.32);
  --ok:#30d158;--okl:rgba(48,209,88,.16);
  --wa:#ff9f0a;--wal:rgba(255,159,10,.16);
  --er:#ff453a;--erl:rgba(255,69,58,.16);
  --info:#bf5af2;--infol:rgba(191,90,242,.16);
  --pu:#a855f7;--pul:rgba(168,85,247,.18);
  --cy:#bf5af2;--cyl:rgba(191,90,242,.16);
  --shadow-s:0 1px 3px rgba(0,0,0,.4);
  --shadow-m:0 4px 16px rgba(0,0,0,.5);
  --shadow-l:0 12px 40px rgba(0,0,0,.6);
  --bubble-in:#2c2c2e;
  --field:#2c2c2e;
  --overlay:rgba(0,0,0,.6);
}

/* ── RESET & BASE ── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overflow:hidden;background:var(--bg);}
body{
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text','Helvetica Neue',Arial,sans-serif;
  background:var(--bg);color:var(--tx);
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;
  transition:background-color .25s,color .25s;
}
.hide{display:none!important;}
/* Mono TYLKO pre technické identifikátory */
.mono{font-family:'SF Mono',ui-monospace,Menlo,monospace;font-size:.92em;}

/* ── APP SHELL ── */
.app{display:none;height:100dvh;flex-direction:column;background:var(--bg);}
.app.on{display:flex;}


/* ── AUTH ── */
.auth-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;
  padding:24px;background:var(--bg);}
.auth-card{background:var(--surface);border-radius:var(--rl);padding:40px 32px;
  width:100%;max-width:400px;box-shadow:var(--shadow-l);animation:rise .4s cubic-bezier(.2,.8,.2,1);}
@keyframes rise{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
.auth-logo{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:28px;}
.auth-logo img{width:60px;height:60px;}
.auth-logo-txt{font-size:18px;font-weight:600;letter-spacing:-.3px;color:var(--tx);}
.auth-logo-txt span{color:var(--ac);}
.auth-h{font-size:25px;font-weight:700;letter-spacing:-.5px;margin-bottom:8px;text-align:center;}
.auth-sub{color:var(--tm);font-size:15px;margin-bottom:28px;text-align:center;line-height:1.5;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:14px;font-weight:500;color:var(--tx);margin-bottom:7px;}
.field input,.field select,.field textarea{
  width:100%;background:var(--surface2);border:1.5px solid transparent;
  border-radius:var(--rs);padding:13px 15px;color:var(--tx);font-family:inherit;
  font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--ac);box-shadow:0 0 0 3px var(--acl);}
.field input::placeholder,.field textarea::placeholder{color:var(--tl);}
.btn{width:100%;padding:15px;background:var(--ac);color:#fff;border:none;
  border-radius:var(--rs);font-family:inherit;font-size:16px;font-weight:600;
  cursor:pointer;transition:opacity .2s,transform .1s;letter-spacing:-.01em;}
.btn:hover{opacity:.88;}.btn:active{transform:scale(.98);}
.btn:disabled{opacity:.32;cursor:not-allowed;transform:none;}
.btn.sec{background:var(--surface3);color:var(--tx);}
.btn.sec:hover{opacity:.8;}
.btn.ok{background:var(--ok);}
.btn.danger{background:var(--er);}
.btn.ghost{background:transparent;color:var(--ac);font-weight:600;}
.btn.sm{width:auto;padding:10px 18px;font-size:14px;}
.btn.xs{width:auto;padding:7px 14px;font-size:13px;border-radius:9px;}
.divider{display:flex;align-items:center;gap:14px;margin:22px 0;}
.divider span{font-size:13px;color:var(--tm);}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--line2);}
.lnk{background:none;border:none;color:var(--ac);font-family:inherit;font-size:15px;cursor:pointer;padding:0;font-weight:500;}
.lnk:hover{opacity:.7;}
.tc{text-align:center;}.mt12{margin-top:14px;}
.alert{border-radius:var(--rs);padding:13px 15px;font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:9px;}
.alert.ok-a{background:var(--okl);color:var(--ok);}
.otp-row{display:flex;gap:9px;justify-content:center;margin:22px 0;}
.otp-row input{width:48px;height:58px;text-align:center;font-size:24px;font-weight:600;
  font-family:'SF Mono',ui-monospace,monospace;
  background:var(--surface2);border:1.5px solid transparent;border-radius:14px;color:var(--tx);outline:none;
  transition:border-color .2s,box-shadow .2s;}
.otp-row input:focus{border-color:var(--ac);box-shadow:0 0 0 3px var(--acl);}
.otp-row input.filled{border-color:var(--ac);}

/* ── APPBAR – dvojriadkový: logo hore, taby dole ── */
.appbar{
  position:sticky;top:0;z-index:100;
  background:var(--surface);
  border-bottom:1px solid var(--line);
  flex-direction:column;
  padding:0;
}
.appbar-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;height:56px;width:100%;
}
.appbar-l{display:flex;align-items:center;gap:10px;}
.appbar-l img{width:28px;height:28px;}
.appbar-name{font-size:15px;font-weight:600;letter-spacing:-.2px;color:var(--tx);}
.appbar-name span{color:var(--ac);}
.appbar-r{display:flex;align-items:center;gap:6px;}
.icon-circle{width:36px;height:36px;border-radius:50%;background:transparent;border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:17px;color:var(--tm);transition:background .15s;}
.icon-circle:hover{background:var(--surface2);}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--ac);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;cursor:pointer;}

/* Taby v appbare */
.appbar-tabs{
  display:flex;width:100%;overflow-x:auto;padding:0 16px;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
  border-top:1px solid var(--line);
}
.appbar-tabs::-webkit-scrollbar{display:none;}
.tab-btn{
  flex-shrink:0;padding:12px 16px 11px;border:none;background:none;
  font-family:inherit;font-size:13.5px;font-weight:500;color:var(--tm);
  cursor:pointer;position:relative;transition:color .15s;white-space:nowrap;
}
.tab-btn::after{
  content:'';position:absolute;bottom:0;left:8px;right:8px;height:2px;
  border-radius:2px 2px 0 0;background:var(--ac);
  opacity:0;transition:opacity .15s;
}
.tab-btn.on{color:var(--tx);font-weight:600;}
.tab-btn.on::after{opacity:1;}
.tab-btn:hover{color:var(--tx);}
.tab-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:16px;height:16px;border-radius:99px;background:var(--er);
  color:#fff;font-size:10px;font-weight:700;margin-left:4px;padding:0 4px;
}

/* Výška appbaru pre offset sticky vecí */
.tabs-bar{display:none;}

/* Obsah pod appbarom – padding-top aby taby neprekrývali obsah */
.main{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:48px;background:var(--bg);
  -webkit-overflow-scrolling:touch;}
.container{max-width:var(--maxw);margin:0 auto;padding:24px 20px 0;}

/* ── ORDER SWITCHER ── */
.switcher{position:relative;}
.switcher-btn{display:flex;align-items:center;gap:7px;background:var(--surface2);
  border:none;border-radius:99px;padding:8px 14px;cursor:pointer;font-family:inherit;
  font-size:14px;font-weight:500;color:var(--tx);transition:background .15s;}
.switcher-btn:hover{background:var(--surface3);}
.switcher-btn .chev{font-size:10px;color:var(--tl);}
.switcher-menu{display:none;position:absolute;left:0;top:calc(100% + 8px);
  background:var(--surface);border-radius:var(--r);min-width:280px;padding:6px;
  z-index:200;box-shadow:var(--shadow-l);border:1px solid var(--line);animation:rise .18s ease;}
.switcher-menu.on{display:block;}
.switcher-item{display:flex;align-items:center;gap:12px;padding:11px 12px;
  border-radius:10px;cursor:pointer;transition:background .12s;}
.switcher-item:hover{background:var(--surface2);}
.switcher-item.active{background:var(--acl);}
.switcher-item .si-ico{font-size:22px;flex-shrink:0;}
.switcher-item .si-body{flex:1;min-width:0;}
.switcher-item .si-dev{font-size:14px;font-weight:600;}
.switcher-item .si-status{font-size:12px;color:var(--tm);}
.switcher-item .si-dot{width:8px;height:8px;border-radius:50%;background:var(--ac);flex-shrink:0;}

/* ── DROPDOWN (profil/téma) ── */
.dd{position:relative;}
.dd-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);
  background:var(--surface);border-radius:var(--r);min-width:220px;padding:6px;
  z-index:200;box-shadow:var(--shadow-l);border:1px solid var(--line);animation:rise .18s ease;}
.dd-menu.on{display:block;}
.dd-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;
  font-size:14px;cursor:pointer;color:var(--tx);transition:background .12s;}
.dd-item:hover{background:var(--surface2);}
.dd-item.red{color:var(--er);}
.dd-sep{height:1px;background:var(--line);margin:5px 4px;}
.dd-theme-label{font-size:11px;font-weight:600;color:var(--tl);padding:7px 12px 4px;letter-spacing:.4px;}
.dd-theme-switch{display:flex;gap:4px;padding:0 6px 6px;}
.dd-theme-opt{flex:1;padding:8px 4px;border-radius:8px;border:none;background:var(--surface2);
  color:var(--tm);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;}
.dd-theme-opt:hover{color:var(--tx);}
.dd-theme-opt.active{background:var(--acl);color:var(--ac);font-weight:600;}

/* ── HERO ── */
.hero{padding:28px 0 14px;}
.hero-ico{width:56px;height:56px;border-radius:16px;background:var(--surface);
  box-shadow:var(--shadow-s);display:flex;align-items:center;justify-content:center;
  font-size:30px;margin-bottom:16px;}
.hero-device{font-size:30px;font-weight:700;letter-spacing:-.7px;line-height:1.2;margin-bottom:6px;}
.hero-num{font-size:13px;color:var(--tm);margin-bottom:18px;}

/* Hlavná status karta – najdôležitejší prvok */
.hero-status-card{background:var(--surface);border-radius:20px;padding:26px;
  box-shadow:var(--shadow-s);margin-bottom:16px;}
.hss-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.hss-state{display:flex;align-items:center;gap:12px;}
.hss-pulse{width:12px;height:12px;border-radius:50%;flex-shrink:0;position:relative;}
.hss-pulse.active{background:var(--ac);}
.hss-pulse.active::after{content:'';position:absolute;inset:-4px;border-radius:50%;
  background:var(--ac);opacity:.25;animation:pulse 2.4s infinite;}
.hss-pulse.done{background:var(--ok);}
.hss-pulse.wait{background:var(--wa);}
@keyframes pulse{0%{transform:scale(1);}70%{transform:scale(2.2);opacity:0;}100%{opacity:0;}}
.hss-state-txt{font-size:22px;font-weight:700;letter-spacing:-.4px;}
.hss-eta{text-align:right;}
.hss-eta-lbl{font-size:11px;color:var(--tl);text-transform:uppercase;letter-spacing:.5px;}
.hss-eta-val{font-size:17px;font-weight:600;margin-top:2px;}
.hss-progress{height:5px;border-radius:99px;background:var(--surface3);overflow:hidden;margin-bottom:10px;}
.hss-progress-fill{height:100%;border-radius:99px;background:var(--ac);
  transition:width .7s cubic-bezier(.2,.8,.2,1);}
.hss-steps{display:flex;justify-content:space-between;font-size:11px;color:var(--tl);}
.hss-steps .on{color:var(--ac);font-weight:600;}
.hss-update{font-size:13px;color:var(--tm);margin-top:16px;display:flex;align-items:center;gap:6px;}

/* Hero detail accordion */
.hero-detail{margin-bottom:16px;}
.hero-detail-summary{list-style:none;font-size:13px;font-weight:500;color:var(--tm);
  cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:4px 0;user-select:none;}
.hero-detail-summary::-webkit-details-marker{display:none;}
.hero-detail-summary::after{content:'›';font-size:15px;transition:transform .2s;display:inline-block;color:var(--tl);}
details.hero-detail[open] .hero-detail-summary::after{transform:rotate(90deg);}
.hero-detail-body{margin-top:8px;border-radius:var(--r);overflow:hidden;animation:rise .2s ease;}
.hero-detail-row{display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;border-bottom:1px solid var(--line);font-size:14px;}
.hero-detail-row:last-child{border-bottom:none;}
.hero-detail-lbl{color:var(--tm);}
.hero-detail-val{font-weight:500;text-align:right;max-width:60%;}



/* ── SEKCIE ── */
.section{margin-top:36px;}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.section-title{font-size:17px;font-weight:600;letter-spacing:-.2px;color:var(--tm);}
.section-link{font-size:14px;color:var(--ac);font-weight:500;cursor:pointer;background:none;border:none;font-family:inherit;}
.section-link:hover{opacity:.7;}

/* Akcia zákazníka */
.action-card{background:var(--acl);border-radius:var(--r);padding:20px;
  border:1px solid var(--acg);margin-bottom:12px;}
.action-badge{display:inline-flex;align-items:center;gap:5px;color:var(--ac);
  font-size:12px;font-weight:500;padding:0;margin-bottom:8px;}
.action-title{font-size:16px;font-weight:600;margin-bottom:5px;letter-spacing:-.1px;}
.action-desc{font-size:14px;color:var(--tm);line-height:1.5;margin-bottom:12px;}
.action-items{background:var(--surface2);border-radius:var(--rs);padding:12px 14px;
  font-size:13px;line-height:1.75;color:var(--tm);white-space:pre-wrap;margin-bottom:12px;}
.action-total{font-size:16px;font-weight:700;margin-bottom:12px;}
.action-btns{display:flex;gap:10px;}
.action-btns .btn{flex:1;}

/* Unread banner */
.unread-banner{display:flex;align-items:center;gap:10px;width:100%;
  background:rgba(0,122,255,.10);color:#1a56b0;border:1px solid rgba(0,122,255,.18);
  border-radius:14px;padding:13px 16px;margin-bottom:12px;cursor:pointer;font-family:inherit;}
[data-theme="dark"] .unread-banner{background:rgba(10,132,255,.14);color:#6ab0ff;border-color:rgba(10,132,255,.22);}
.unread-banner:hover{background:rgba(0,122,255,.15);}
[data-theme="dark"] .unread-banner:hover{background:rgba(10,132,255,.20);}
.unread-banner-dot{width:7px;height:7px;border-radius:50%;background:#1a56b0;flex-shrink:0;opacity:.7;}
[data-theme="dark"] .unread-banner-dot{background:#6ab0ff;}
.unread-banner-txt{font-size:14px;font-weight:500;flex:1;}
.unread-banner-chev{font-size:15px;opacity:.5;}

/* ── ORDERS TAB ── */
.ot-card{display:flex;align-items:center;gap:14px;background:var(--surface);
  border-radius:var(--r);padding:16px;box-shadow:var(--shadow-s);
  margin-bottom:10px;cursor:pointer;transition:opacity .12s;margin-top:10px;}
.ot-card:active{opacity:.75;}
.ot-card.ot-active{border:1.5px solid var(--ac);background:var(--acl);}
.ot-ico{font-size:28px;flex-shrink:0;width:48px;height:48px;background:var(--surface2);
  border-radius:14px;display:flex;align-items:center;justify-content:center;}
.ot-body{flex:1;min-width:0;}
.ot-name{font-size:16px;font-weight:600;letter-spacing:-.2px;}
.ot-sub{font-size:13px;color:var(--tm);margin-top:2px;}
.ot-status{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap;}
.ot-dot{font-size:12px;font-weight:500;color:var(--ac);background:var(--acl);
  padding:3px 10px;border-radius:99px;}
.ot-dot.ot-dot-ac{color:var(--wa);background:var(--wal);}

/* ── MOBILE: taby ako dropdown ── */
.tab-mobile-dd{display:none;position:relative;}
.tab-mobile-btn{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;background:var(--surface);
  border:none;border-top:1px solid var(--line);border-radius:0;
  padding:12px 20px;cursor:pointer;font-family:inherit;
  font-size:14px;font-weight:500;color:var(--tx);transition:background .15s;
}
.tab-mobile-btn:hover{background:var(--surface2);opacity:1;}
.tab-mobile-btn .chev{font-size:10px;color:var(--tl);}
.tab-mobile-menu{
  display:none;position:absolute;left:0;right:0;top:100%;
  background:var(--surface);border-radius:0 0 var(--r) var(--r);padding:6px;
  z-index:200;box-shadow:var(--shadow-l);border-top:1px solid var(--line);animation:rise .18s ease;
}
.tab-mobile-menu.on{display:block;}
.tab-mobile-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;border-radius:10px;cursor:pointer;font-size:15px;
  font-weight:500;color:var(--tx);transition:background .12s;
}
.tab-mobile-item:hover{background:var(--surface2);}
.tab-mobile-item.on{background:var(--acl);color:var(--ac);font-weight:600;}

@media(max-width:599px){
  .appbar-tabs{display:none;}
  .tab-mobile-dd{display:block;}
}
@media(min-width:600px){
  .tab-mobile-dd{display:none!important;}
}

/* ── CHAT ── */
.chat-thread{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.day-div{text-align:center;font-size:12px;color:var(--tl);margin:10px 0;font-weight:500;}

/* Unread divider */
.unread-divider{display:flex;align-items:center;gap:10px;margin:14px 0 6px;}
.unread-divider::before,.unread-divider::after{content:'';flex:1;height:1px;background:var(--line2);}
.unread-divider span{font-size:12px;font-weight:500;color:var(--tm);white-space:nowrap;
  background:var(--surface2);padding:3px 12px;border-radius:99px;}



/* Správy */
.mg{display:flex;flex-direction:column;gap:2px;max-width:78%;}
.mg.out{align-self:flex-end;align-items:flex-end;}
.mg.in,.mg.tech,.mg.ai{align-self:flex-start;align-items:flex-start;}
.mg-who{font-size:12px;color:var(--tl);padding:0 5px;display:flex;align-items:center;gap:5px;}
.mg.tech .mg-who{color:var(--ok);}
.mg.ai .mg-who{color:var(--ac);}
.mg-who-ava{width:16px;height:16px;border-radius:50%;display:inline-flex;
  align-items:center;justify-content:center;font-size:9px;}
.mg-who-ava.ai{background:var(--ac);color:#fff;}
.mg-who-ava.tech{background:var(--okl);color:var(--ok);}
.bubble{padding:11px 15px;border-radius:18px;font-size:15px;line-height:1.5;}
/* Zákazník – modrá */
.mg.out .bubble{background:#3b7fd4;color:#fff;border-bottom-right-radius:5px;}
[data-theme="dark"] .mg.out .bubble{background:#4a8fd9;}
/* Technik – zelená s opacity */
.mg.in .bubble,.mg.tech .bubble{background:rgba(42,157,92,.13);color:var(--tx);
  border-bottom-left-radius:5px;border:1px solid rgba(42,157,92,.18);}
[data-theme="dark"] .mg.in .bubble,[data-theme="dark"] .mg.tech .bubble{
  background:rgba(52,199,123,.11);border-color:rgba(52,199,123,.18);}
/* Asistent servisu – jemná fialová */
.mg.ai .bubble{background:var(--acl);color:var(--tx);
  border-bottom-left-radius:5px;border:1px solid var(--acg);}
/* Systém */
.mg.sys{align-self:center;max-width:90%;}
.mg.sys .bubble{background:var(--wal);color:var(--wa);font-size:13px;
  border-radius:10px;padding:7px 14px;text-align:center;}
.mg-time{font-size:11px;color:var(--tl);padding:0 5px;}
.attach-pill{margin-top:7px;background:rgba(255,255,255,.14);border-radius:10px;
  padding:8px 12px;display:flex;align-items:center;gap:8px;font-size:13px;}
.mg.in .attach-pill,.mg.tech .attach-pill,.mg.ai .attach-pill{background:var(--surface2);}

/* Neprečítané – jemné highlight, žiadne blikanie */
.mg.unread-msg .bubble{outline:1.5px solid rgba(0,122,255,.30);}
[data-theme="dark"] .mg.unread-msg .bubble{outline-color:rgba(10,132,255,.35);}

/* Typing */
.ai-typing-bubble{display:flex;gap:5px;align-items:center;padding:3px 0;}
.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--tm);animation:aidot 1s infinite;}
.ai-dot:nth-child(2){animation-delay:.15s;}.ai-dot:nth-child(3){animation-delay:.3s;}
@keyframes aidot{0%,80%,100%{transform:scale(.6);opacity:.4;}40%{transform:scale(1);opacity:1;}}
.ai-escalate-pill{display:inline-flex;align-items:center;gap:5px;background:var(--wal);
  color:var(--wa);border-radius:99px;padding:4px 11px;font-size:12px;margin-top:4px;}

/* Servisný hint nad chatom – subtílny */
.ai-hint{padding:8px 0 6px;display:flex;align-items:center;gap:9px;margin-bottom:10px;opacity:.75;}
.ai-hint-ico{font-size:20px;flex-shrink:0;opacity:.7;}
.ai-hint-txt{flex:1;font-size:14px;color:var(--tm);line-height:1.45;}
.ai-hint-txt b{font-weight:500;color:var(--tx);}

/* Compose */
.compose{position:sticky;bottom:0;background:var(--bg);
  border-top:1px solid var(--line);padding:10px 0 14px;margin-top:8px;}
.compose-inner{display:flex;gap:8px;align-items:flex-end;background:var(--surface);
  border:1.5px solid var(--line2);border-radius:22px;padding:5px 5px 5px 8px;
  transition:border-color .2s;}
.compose-inner:focus-within{border-color:var(--ac);}
.compose-attach{width:36px;height:36px;border-radius:50%;background:none;border:none;
  cursor:pointer;font-size:18px;color:var(--tl);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;}
.compose-attach:hover{color:var(--tm);}
.compose-in{flex:1;background:none;border:none;outline:none;color:var(--tx);
  font-family:inherit;font-size:16px;resize:none;min-height:36px;max-height:110px;
  line-height:1.45;padding:8px 4px;}
.compose-in::placeholder{color:var(--tl);}
.compose-send{width:36px;height:36px;border-radius:50%;background:var(--ac);border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;transition:opacity .2s,transform .1s;}
.compose-send:hover{opacity:.85;}.compose-send:active{transform:scale(.9);}
.compose-send:disabled{opacity:.28;cursor:not-allowed;}
.compose-hint{font-size:12px;color:var(--tl);text-align:center;margin-top:7px;}

/* ── TIMELINE ── */
.timeline{padding:2px 0;}
.tl-item{display:flex;gap:14px;padding-bottom:20px;position:relative;}
.tl-item:last-child{padding-bottom:0;}
.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--surface3);flex-shrink:0;
  margin-top:4px;position:relative;z-index:1;}
.tl-dot.done{background:var(--ok);}
.tl-dot.act{background:var(--ac);box-shadow:0 0 0 4px var(--acl);}
.tl-item:not(:last-child)::after{content:'';position:absolute;left:5.5px;top:16px;
  bottom:0;width:1px;background:var(--line2);}
.tl-item.done:not(:last-child)::after{background:var(--ok);opacity:.3;}
.tl-body{flex:1;}
.tl-txt{font-size:15px;font-weight:500;}
.tl-item.act .tl-txt{color:var(--ac);font-weight:600;}
.tl-item:not(.done):not(.act) .tl-txt{color:var(--tl);}
.tl-time{font-size:12px;color:var(--tl);margin-top:2px;}

/* ── ORDER / SERVICE KARTY ── */
.track-card{background:var(--surface);border-radius:var(--r);padding:18px;
  box-shadow:var(--shadow-s);margin-bottom:12px;}
.tc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;}
.tc-name{font-size:16px;font-weight:600;letter-spacing:-.1px;}
.tc-sub{font-size:13px;color:var(--tm);margin-top:2px;}
.tc-steps{display:flex;align-items:flex-start;gap:0;margin:14px 0 4px;}
.tc-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;position:relative;}
.tc-step:not(:last-child)::after{content:'';position:absolute;right:-50%;top:10px;
  width:100%;height:1px;background:var(--surface3);z-index:0;}
.tc-step.done:not(:last-child)::after{background:var(--ok);opacity:.4;}
.tc-step-dot{width:22px;height:22px;border-radius:50%;background:var(--surface3);
  display:flex;align-items:center;justify-content:center;font-size:10px;z-index:1;color:var(--tl);}
.tc-step.done .tc-step-dot{background:var(--ok);color:#fff;}
.tc-step.act .tc-step-dot{background:var(--ac);color:#fff;box-shadow:0 0 0 3px var(--acl);}
.tc-step-lbl{font-size:10px;color:var(--tl);text-align:center;line-height:1.3;max-width:60px;}
.tc-step.done .tc-step-lbl{color:var(--ok);}
.tc-step.act .tc-step-lbl{color:var(--ac);font-weight:600;}
.tc-pay{background:var(--surface2);border-radius:var(--rs);padding:12px 14px;margin-top:12px;}
.tc-pay-row{display:flex;justify-content:space-between;font-size:14px;padding:3px 0;}
.tc-pay-row.total{font-weight:600;border-top:1px solid var(--line);margin-top:5px;padding-top:8px;}
.tc-pay-row .g{color:var(--ok);}.tc-pay-row .a{color:var(--wa);}
.tc-note{border-radius:var(--rs);padding:10px 14px;margin-top:10px;font-size:13px;
  line-height:1.5;display:flex;gap:8px;}
.tc-note.wait{background:var(--wal);color:var(--wa);}
.tc-note.ok{background:var(--okl);color:var(--ok);}

/* ── DOKUMENTY ── */
.doc-row{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:var(--r);
  padding:14px 16px;box-shadow:var(--shadow-s);margin-bottom:8px;cursor:pointer;transition:opacity .12s;}
.doc-row:active{opacity:.75;}
.doc-ico{width:40px;height:40px;border-radius:10px;background:var(--surface2);
  display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.doc-body{flex:1;min-width:0;}
.doc-name{font-size:15px;font-weight:500;}
.doc-meta{font-size:13px;color:var(--tm);margin-top:1px;}
.doc-meta .signed{color:var(--ok);}
.doc-chev{color:var(--tl);font-size:14px;flex-shrink:0;}

/* ── FOTKY ── */
.photo-grp-lbl{font-size:13px;color:var(--tm);font-weight:500;margin:14px 0 8px;}
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.photo-card{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;
  background:var(--surface2);transition:transform .15s;}
.photo-card:active{transform:scale(.97);}
.photo-card img{width:100%;height:100%;object-fit:cover;display:block;}

/* ── STATUS PILL ── */
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;
  border-radius:99px;font-size:13px;font-weight:500;}
.pill.wait{background:var(--wal);color:var(--wa);}
.pill.work{background:var(--acl);color:var(--ac);}
.pill.done{background:var(--okl);color:var(--ok);}
.pill.action{background:var(--infol);color:var(--info);}

/* ── LIGHTBOX ── */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;
  align-items:center;justify-content:center;flex-direction:column;gap:14px;}
.lightbox.on{display:flex;}
.lightbox img{max-width:92vw;max-height:80vh;border-radius:12px;object-fit:contain;}
.lb-meta{color:rgba(255,255,255,.65);font-size:14px;text-align:center;padding:0 20px;}
.lb-close{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.14);
  border:none;color:#fff;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:17px;}

/* ── MODALY ── */
.modal-wrap{display:none;position:fixed;inset:0;background:var(--overlay);z-index:500;
  align-items:flex-end;justify-content:center;}
.modal-wrap.on{display:flex;}
.modal{background:var(--surface);border-radius:22px 22px 0 0;padding:26px 22px 32px;
  width:100%;max-width:480px;animation:sheetUp .32s cubic-bezier(.2,.8,.2,1);
  max-height:90dvh;overflow-y:auto;}
@keyframes sheetUp{from{transform:translateY(100%);}to{transform:translateY(0);}}
.modal-grip{width:36px;height:4px;border-radius:99px;background:var(--line2);margin:0 auto 18px;}
.modal h3{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-bottom:8px;}
.modal p{font-size:15px;color:var(--tm);margin-bottom:18px;line-height:1.5;}
.modal-foot{display:flex;gap:10px;margin-top:18px;}
.modal-foot .btn{flex:1;}
.sign-clause{background:var(--acl);border-radius:var(--rs);padding:12px 14px;
  font-size:13px;color:var(--ac);line-height:1.55;margin:12px 0;}
.sign-record{background:var(--okl);border-radius:var(--rs);padding:13px 15px;
  font-size:14px;color:var(--ok);line-height:1.75;margin-top:12px;}
.sign-record strong{font-weight:700;}
@media(min-width:560px){
  .modal-wrap{align-items:center;}
  .modal{border-radius:22px;max-width:440px;}
}

/* ── REJECT MODAL ── */
.reject-wrap{display:none;position:fixed;inset:0;background:var(--overlay);z-index:600;
  align-items:flex-end;justify-content:center;}
.reject-wrap.on{display:flex;}
.reject-modal{background:var(--surface);border-radius:22px 22px 0 0;padding:26px 22px 32px;
  width:100%;max-width:480px;animation:sheetUp .32s cubic-bezier(.2,.8,.2,1);
  max-height:90dvh;overflow-y:auto;}
.reject-modal h3{font-size:19px;font-weight:700;color:var(--er);margin-bottom:8px;}
.reject-modal p{font-size:15px;color:var(--tm);margin-bottom:16px;line-height:1.5;}
.reject-item{font-size:14px;font-weight:600;background:var(--surface2);
  border-radius:var(--rs);padding:11px 14px;margin:12px 0;}
.reject-reason-label{font-size:13px;color:var(--tm);margin-bottom:6px;display:block;}
.reject-reason-input{width:100%;background:var(--field);border:1.5px solid var(--line2);
  border-radius:var(--rs);padding:11px 13px;color:var(--tx);font-family:inherit;
  font-size:15px;outline:none;resize:none;}
.reject-reason-input:focus{border-color:var(--er);}
.reject-foot{display:flex;gap:10px;margin-top:18px;}
@media(min-width:560px){.reject-wrap{align-items:center;}.reject-modal{border-radius:22px;max-width:440px;}}

/* ── PDF VIEWER ── */
.pdfv-wrap{display:none;position:fixed;inset:0;background:var(--bg);z-index:700;flex-direction:column;}
.pdfv-wrap.on{display:flex;}
.pdfv-header{background:var(--surface);border-bottom:1px solid var(--line);padding:0 16px;height:54px;
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.pdfv-title{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px;}
.pdfv-actions{display:flex;gap:8px;}
.pdfv-body{flex:1;overflow-y:auto;background:var(--surface2);display:flex;
  flex-direction:column;align-items:center;padding:18px 14px;gap:12px;}
.pdfv-footer{background:var(--surface);border-top:1px solid var(--line);padding:10px 16px;
  display:flex;align-items:center;justify-content:center;gap:14px;flex-shrink:0;}
.pdfv-pg-info{font-size:13px;color:var(--tm);}
.pdfv-zoom{display:flex;align-items:center;gap:6px;}
.pdfv-zoom-lbl{font-size:13px;color:var(--tm);min-width:40px;text-align:center;}
.pdfv-spinner{display:flex;align-items:center;justify-content:center;
  padding:60px;color:var(--tm);font-size:14px;gap:10px;}
.spinner-ico{width:18px;height:18px;border:2px solid var(--line2);border-top-color:var(--ac);
  border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--surface);box-shadow:var(--shadow-l);border-radius:99px;
  padding:11px 20px;font-size:14px;font-weight:500;z-index:900;
  white-space:nowrap;animation:rise .3s ease;border:1px solid var(--line);}

/* ── EMPTY ── */
.empty{text-align:center;padding:36px 20px;color:var(--tl);font-size:15px;}

/* ════════════════════════════════════════
   RESPONSIVITA
   ════════════════════════════════════════ */

/* Malý telefón */
@media(max-width:360px){
  .container{padding:0 14px;}
  .appbar{padding:0 14px;}
  .hero-device{font-size:22px;}
  .auth-card{padding:28px 16px;}
  .otp-row{gap:6px;}
  .otp-row input{width:38px;height:48px;font-size:20px;}
  .section-title{font-size:15px;}
  .hss-state-txt{font-size:17px;}
  .hss-steps{font-size:9px;}
}

/* Štandardný telefón */
@media(max-width:600px){
  .hero{padding:22px 0 8px;}
  .hero-ico{width:50px;height:50px;font-size:26px;margin-bottom:14px;}
  .hero-device{font-size:25px;}
  .hero-status-card{padding:18px;}
  .hss-state-txt{font-size:18px;}
  .section{margin-top:28px;}
  .action-card{padding:16px;}
  .track-card{padding:15px;}
  .compose-in{font-size:16px;}
  .compose{padding:8px 0 max(12px,env(safe-area-inset-bottom));}
  .appbar{padding:0 max(16px,env(safe-area-inset-left)) 0 max(16px,env(safe-area-inset-right));}
}

/* Tablet + */
@media(min-width:600px){
  :root{--maxw:720px;}
  .auth-card{padding:44px 36px;}
  .photo-grid{grid-template-columns:repeat(4,1fr);gap:8px;}
  .otp-row input{width:52px;height:62px;}
}

/* Desktop */
@media(min-width:900px){
  :root{--maxw:800px;}
  .appbar-top{padding:0 40px;height:60px;}
  .appbar-tabs{padding:0 32px;}
  .container{padding:0 32px;}
  .hero{padding:40px 0 14px;}
  .hero-device{font-size:34px;}
  .hss-state-txt{font-size:21px;}
  .section{margin-top:44px;}
  .section-title{font-size:16px;}
  .compose{position:static;border-top:1px solid var(--line);padding:16px 0 20px;}
  .photo-grid{grid-template-columns:repeat(5,1fr);}
  .doc-row:hover{background:var(--surface2);}
  .hero-status-card{padding:28px;}
  .auth-card{max-width:460px;}
}

/* Wide */
@media(min-width:1200px){
  :root{--maxw:840px;}
  .appbar-top{padding:0 48px;}
  .appbar-tabs{padding:0 40px;}
}

/* Landscape telefón */
@media(max-height:500px) and (orientation:landscape){
  .hero{padding:10px 0 4px;}
  .hero-ico{width:34px;height:34px;font-size:18px;margin-bottom:8px;}
  .hero-device{font-size:19px;}
  .section{margin-top:14px;}
  .appbar{height:44px;}
}

/* Reduce motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;}
}