/* Брама — тепла палітра бренду «Софія від Мартинова»:
   кремово-бежева база + сонячно-золотий акцент + бронзово-коричневий «офіційний» тон.
   (--green* історично названі так, але тримають теплу бронзу — щоб не перейменовувати всюди.) */
:root{
  --bg:#f4ecdb; --bg2:#efe4cd;
  --card:#fffdf7; --card2:#fbf6ea;
  --ink:#2b2620; --ink-soft:#6f6553; --line:#e7dcc4;
  --gold:#e6a91f; --gold-2:#fcd316; --gold-deep:#c5860d;
  --green:#8a5a12; --green-2:#a9741a; --green-deep:#5a3c0a;   /* тепла бронза/коричневий */
  --red:#c0392b; --red-soft:#e74c3c;
  --shadow:0 10px 30px rgba(120,90,20,.12); --shadow-sm:0 4px 14px rgba(120,90,20,.10);
  --r:20px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
:focus-visible{outline:3px solid var(--green-2);outline-offset:2px;border-radius:6px}
body{
  font-family:'Roboto',system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--ink); background:
    radial-gradient(1100px 460px at 50% -200px, #fff1cf 0%, rgba(255,241,207,0) 62%),
    radial-gradient(760px 420px at 88% 4%, rgba(197,134,13,.10) 0%, rgba(197,134,13,0) 60%),
    linear-gradient(180deg,var(--bg) 0%, var(--bg2) 100%);
  min-height:100vh; -webkit-font-smoothing:antialiased;
}
.app{max-width:460px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:0 14px 16px}
.hidden{display:none !important}

/* Шапка */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 4px 10px}
.brand{display:flex;align-items:center;gap:10px}
.logo{display:grid;place-items:center;width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#c5860d,#9a6a1a 55%,#6b4410);box-shadow:0 6px 16px rgba(122,80,10,.35)}
.brand-text strong{display:block;font-size:21px;font-weight:900;letter-spacing:.2px;line-height:1}
.brand-text small{display:block;color:var(--ink-soft);font-size:12px;font-weight:500;margin-top:3px}
.top-actions{display:flex;gap:8px;align-items:center}
.icon-btn{border:none;background:var(--card);box-shadow:var(--shadow-sm);width:44px;height:44px;border-radius:13px;font-size:18px;cursor:pointer}
.tg-toggle{position:relative;border:none;background:var(--card);box-shadow:var(--shadow-sm);width:44px;height:44px;border-radius:13px;font-size:18px;cursor:pointer}
.badge{position:absolute;top:-5px;right:-5px;min-width:19px;height:19px;border-radius:10px;background:var(--red-soft);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;padding:0 5px}

/* Перемикач ролей */
.roles{display:flex;gap:6px;background:var(--card2);border:1px solid var(--line);padding:5px;border-radius:15px;margin-top:4px}
.roles button{flex:1;border:none;background:transparent;padding:10px 6px;border-radius:11px;font-weight:700;font-size:13.5px;color:var(--ink-soft);cursor:pointer;transition:.15s}
.roles button.active{background:#fff;color:var(--green-deep);box-shadow:var(--shadow-sm)}
.demo-hint{font-size:11.5px;color:var(--ink-soft);text-align:center;padding:7px 2px 2px}

main{flex:1}
.view{padding:8px 0 4px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* Картки */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:18px;margin-bottom:14px}
.card.tight{padding:14px}
.card h3{margin:0 0 4px;font-size:16px;font-weight:900}
.muted{color:var(--ink-soft);font-size:13px}
.row{display:flex;gap:10px;align-items:center}
.spread{justify-content:space-between}
.chip{display:inline-flex;align-items:center;gap:5px;background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:5px 11px;font-size:12.5px;font-weight:700;color:var(--ink-soft)}
.chip.green{background:rgba(197,134,13,.12);border-color:rgba(122,78,7,.3);color:#7a4e07}
.chip.gold{background:rgba(230,169,31,.16);border-color:rgba(197,134,13,.45);color:#7a4e07}

/* Привітальна картка жильця */
.hello{display:flex;align-items:center;gap:14px;background:
  linear-gradient(135deg,#a4731f 0%, #6b4410 58%, #43290a 100%);color:#fff7e8;border:none}
.hello .ava{width:52px;height:52px;border-radius:15px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:24px}
.hello strong{font-size:18px;font-weight:900}
.hello small{opacity:.85}
.hello .addr{margin-top:5px;font-size:13px;opacity:.95}

/* Велика кнопка «Відчинити» */
.opener{display:grid;place-items:center;padding:26px 0 8px;text-align:center}
.bigbtn{
  width:200px;height:200px;border-radius:50%;border:none;cursor:pointer;position:relative;
  background:radial-gradient(circle at 50% 36%, #ffe79a 0%, #f4b733 46%, #d8920f 100%);
  box-shadow:0 18px 44px rgba(200,135,15,.45), inset 0 -8px 22px rgba(120,70,0,.3), 0 0 0 6px rgba(122,78,7,.16);
  color:#5a3c00;font-weight:900;font-size:19px;letter-spacing:.3px;
  display:grid;place-items:center;transition:transform .12s;
}
.bigbtn:active{transform:scale(.97)}
.bigbtn .ic{font-size:46px;line-height:1;margin-bottom:6px;filter:drop-shadow(0 2px 4px rgba(120,70,0,.3))}
.bigbtn span small{display:block;font-weight:700;font-size:12.5px;opacity:.8;margin-top:2px}
.bigbtn.pulse{animation:pulse 1.4s infinite}
@keyframes pulse{0%{box-shadow:0 18px 44px rgba(200,135,15,.45), inset 0 -8px 22px rgba(120,70,0,.3), 0 0 0 0 rgba(216,146,15,.55)}
  70%{box-shadow:0 18px 44px rgba(200,135,15,.45), inset 0 -8px 22px rgba(120,70,0,.3), 0 0 0 26px rgba(216,146,15,0)}
  100%{box-shadow:0 18px 44px rgba(200,135,15,.45), inset 0 -8px 22px rgba(120,70,0,.3), 0 0 0 0 rgba(216,146,15,0)}}
.bigbtn[disabled]{filter:grayscale(.25) brightness(.97);cursor:default}

/* Таймлайн статусу */
.timeline{margin:18px 4px 4px;display:none}
.timeline.show{display:block;animation:fade .3s}
.tl-step{display:flex;align-items:center;gap:12px;padding:7px 0;opacity:.4;transition:.3s}
.tl-step.on{opacity:1}
.tl-step .dot{width:26px;height:26px;border-radius:50%;background:var(--card2);border:2px solid var(--line);display:grid;place-items:center;font-size:13px;flex:none}
.tl-step.on .dot{background:var(--green);border-color:var(--green);color:#fff}
.tl-step.bad .dot{background:var(--red);border-color:var(--red);color:#fff}
.tl-step b{font-size:14px}
.tl-step small{display:block;color:var(--ink-soft);font-size:12px}
.tl-line{height:14px;width:2px;background:var(--line);margin-left:12px}
.tl-step.on + .tl-line{background:var(--green)}

/* Форми */
label.fld{display:block;margin-bottom:11px}
label.fld span{display:block;font-size:12.5px;font-weight:700;color:var(--ink-soft);margin-bottom:5px}
input,select,textarea{width:100%;border:1.5px solid var(--line);background:var(--card2);border-radius:12px;padding:12px;font:inherit;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);background:#fff}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Кнопки */
.btn{border:none;border-radius:13px;padding:13px 16px;font:inherit;font-weight:800;cursor:pointer;font-size:15px;width:100%;transition:.15s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn:active{transform:translateY(1px)}
.btn.green{background:linear-gradient(135deg,#a4731f,#6b4410);color:#fff7e8;box-shadow:0 8px 20px rgba(122,80,10,.3)}
.btn.gold{background:linear-gradient(135deg,#f4b733,#e09a12);color:#5a3c00;box-shadow:0 8px 20px rgba(224,154,18,.3)}
.btn.ghost{background:var(--card2);color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn.red{background:linear-gradient(135deg,#e35c4c,#c0392b);color:#fff}
.btn.sm{padding:9px 12px;font-size:13px;width:auto;border-radius:11px}
.btn[disabled]{opacity:.55;cursor:default}

/* Перепустка / пас */
.pass{border:1.5px dashed var(--gold);background:linear-gradient(135deg,#fffef9,#fff7e4);border-radius:16px;padding:16px;margin-top:12px}
.pass .code{font-size:30px;font-weight:900;letter-spacing:5px;color:#8a5a06;text-align:center;margin:8px 0}
.linkbox{display:flex;gap:8px;margin-top:8px}
.linkbox input{font-size:12px;color:var(--ink-soft)}
.passlist .item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:11px 0;border-top:1px solid var(--line)}
.passlist .item:first-child{border-top:none}

/* Стрічка охорони */
.feed-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.stat-pills{display:flex;gap:8px}
.pill{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:8px 12px;text-align:center;box-shadow:var(--shadow-sm)}
.pill b{display:block;font-size:20px;font-weight:900;line-height:1}
.pill small{font-size:10.5px;color:var(--ink-soft)}
.reqcard{background:var(--card);border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:16px;padding:14px;margin-bottom:11px;box-shadow:var(--shadow-sm);animation:slidein .3s}
.reqcard.guest{border-left-color:#b5651d}
.reqcard.resolved{opacity:.6;border-left-color:var(--line)}
@keyframes slidein{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:none}}
.reqcard .top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.reqcard .who{font-size:16px;font-weight:900}
.reqcard .meta{font-size:13px;color:var(--ink-soft);margin-bottom:10px}
.reqcard .car{display:inline-block;background:#2b2620;color:#ffe;border-radius:6px;padding:3px 9px;font-weight:800;letter-spacing:1px;font-size:13px;margin-top:4px;font-family:'Roboto'}
.reqcard .acts{display:flex;gap:9px}
.reqcard .ago{font-size:11.5px;color:var(--ink-soft);white-space:nowrap}
.tag{font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}
.tag.r{background:rgba(230,169,31,.18);color:#7a4e07}
.tag.g{background:rgba(181,101,29,.16);color:#8a4e10}
.tag.ok{background:rgba(122,80,10,.16);color:#5a3c0a}
.tag.no{background:rgba(192,57,43,.12);color:var(--red)}

/* Логін персоналу */
.gate{max-width:320px;margin:30px auto;text-align:center}
.pinpad{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin:16px 0}
.pinpad button{padding:16px;font-size:20px;font-weight:800;border:1px solid var(--line);background:var(--card);border-radius:13px;cursor:pointer}
.pin-dots{font-size:26px;letter-spacing:8px;height:30px;color:var(--green)}

/* Управління */
.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:14px}
.statgrid .pill b{font-size:22px}
.hours{display:flex;align-items:flex-end;gap:2px;height:54px;margin-top:8px}
.hours .bar{flex:1;background:linear-gradient(180deg,#fcd316,#e09a12);border-radius:3px 3px 0 0;min-height:2px;opacity:.92}
.cplist{display:flex;gap:7px;overflow-x:auto;padding-bottom:6px;margin-bottom:10px}
.cplist button{white-space:nowrap;border:1px solid var(--line);background:var(--card);padding:8px 13px;border-radius:999px;font-weight:700;font-size:13px;cursor:pointer;color:var(--ink-soft)}
.cplist button.active{background:var(--green);color:#fff;border-color:var(--green)}
.modrow{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:12px 0;border-top:1px solid var(--line)}
.modrow:first-child{border-top:none}
.modrow .acts{display:flex;gap:7px}
.auditrow{font-size:12.5px;padding:8px 0;border-top:1px solid var(--line);color:var(--ink-soft);display:flex;justify-content:space-between;gap:8px}
.auditrow:first-child{border-top:none}
.empty{text-align:center;color:var(--ink-soft);padding:26px 10px;font-size:14px}

/* Оголошення */
.ann{background:linear-gradient(135deg,rgba(197,134,13,.08),rgba(197,134,13,.03));border:1px solid rgba(197,134,13,.2);border-left:4px solid var(--gold);border-radius:13px;padding:12px 13px;margin-bottom:9px}
.ann-t{font-weight:800;font-size:14.5px;color:var(--green-deep)}
.ann-b{font-size:13.5px;color:var(--ink);margin-top:3px;line-height:1.45;white-space:pre-wrap}
.ann-m{font-size:11.5px;color:var(--ink-soft);margin-top:6px}
.ann-del{margin-top:9px}

/* Шухляда Telegram — у теплих/смарагдових тонах бренду */
.drawer{position:fixed;right:0;top:0;bottom:0;width:min(380px,92vw);background:var(--bg2);box-shadow:-12px 0 40px rgba(80,60,10,.25);z-index:50;display:flex;flex-direction:column;animation:slidedraw .25s}
@keyframes slidedraw{from{transform:translateX(100%)}to{transform:none}}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:linear-gradient(135deg,#a4731f,#6b4410);color:#fff7e8}
.drawer-head button{background:rgba(255,255,255,.22);border:none;color:#fff;width:30px;height:30px;border-radius:8px;font-size:15px;cursor:pointer}
.drawer-tabs{display:flex;gap:5px;padding:9px;background:var(--card2);border-bottom:1px solid var(--line)}
.drawer-tabs button{flex:1;border:none;background:#fff;padding:8px;border-radius:9px;font-weight:700;font-size:12.5px;cursor:pointer;color:var(--ink-soft)}
.drawer-tabs button.active{background:var(--green);color:#fff}
.drawer-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px}
.tgmsg{background:#fff;border:1px solid var(--line);border-radius:12px 12px 12px 4px;padding:11px 13px;box-shadow:var(--shadow-sm);max-width:92%;white-space:pre-wrap;font-size:13.5px;line-height:1.45}
.tgmsg .btns{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap}
.tgmsg .tgbtn{background:var(--card2);border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700;color:var(--green-deep);cursor:default}
.tgmsg .t{font-size:10px;color:var(--ink-soft);margin-top:6px}
.drawer-note{padding:10px 16px;font-size:11px;color:var(--ink-soft);background:var(--card2);text-align:center}

/* QR */
.qrwrap{display:inline-block;background:#fff;padding:12px;border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow-sm);cursor:pointer;line-height:0}
.qrwrap svg{width:190px;height:190px;display:block}
.qrmodal{position:fixed;inset:0;background:rgba(43,38,32,.66);z-index:70;display:none;align-items:center;justify-content:center;padding:20px}
.qrmodal.show{display:flex;animation:fade .2s}
.qrmodal-in{background:var(--card);border-radius:22px;padding:24px;max-width:360px;width:100%;text-align:center;position:relative;box-shadow:0 24px 60px rgba(0,0,0,.3);max-height:92vh;overflow:auto}
.qrmodal-in h3{margin:0 0 12px;font-size:18px}
.qrmodal-x{position:absolute;top:12px;right:12px;border:none;background:var(--card2);width:32px;height:32px;border-radius:10px;font-size:15px;cursor:pointer}
.qrbig svg{width:min(72vw,300px);height:min(72vw,300px)}

/* Сканер */
.scan-overlay{position:fixed;inset:0;background:#0e0d0b;z-index:80;display:none;flex-direction:column}
.scan-overlay.show{display:flex;animation:fade .2s}
.scan-top{display:flex;justify-content:space-between;align-items:center;padding:16px;color:#fff;font-size:16px}
.scan-x{background:rgba(255,255,255,.18);border:none;color:#fff;width:34px;height:34px;border-radius:10px;font-size:16px;cursor:pointer}
.scan-stage{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#000}
#scanVid{width:100%;height:100%;object-fit:cover}
.scan-frame{position:absolute;width:min(64vw,260px);height:min(64vw,260px);border:3px solid rgba(244,183,51,.9);border-radius:22px;box-shadow:0 0 0 100vmax rgba(0,0,0,.45);pointer-events:none}
.scan-result{position:absolute;left:16px;right:16px;bottom:16px;border-radius:18px;padding:18px;text-align:center;display:none}
.scan-result.show{display:block;animation:slidein .25s}
.scan-result.ok{background:linear-gradient(135deg,#159a5f,#11613f);color:#fff}
.scan-result.bad{background:linear-gradient(135deg,#e35c4c,#c0392b);color:#fff}
.scan-result .big{font-size:24px;font-weight:900}
.scan-result .who{margin-top:6px;font-size:15px;font-weight:600;line-height:1.4}
.scan-result .who small{opacity:.8;font-weight:400}
.scan-result .who span{opacity:.92;font-size:13.5px}
.scan-bottom{padding:16px;background:#16140f;color:#fff}
.scan-hint{text-align:center;font-size:13.5px;opacity:.85;margin-bottom:12px}
.scan-manual{display:flex;gap:8px}
.scan-manual input{flex:1;border:1.5px solid #3a352b;background:#221f19;color:#fff;border-radius:12px;padding:12px;font:inherit}
.scan-manual input::placeholder{color:#8a8275}

/* Інструкція (повноекранний аркуш) */
.sheet{position:fixed;inset:0;z-index:55;background:var(--bg);display:flex;flex-direction:column;max-width:460px;margin:0 auto;animation:fade .2s}
.sheet-head{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,#a4731f,#6b4410);color:#fff7e8}
.sheet-head strong{font-size:17px;font-weight:900}
.sheet-head button{background:rgba(255,255,255,.22);border:none;color:#fff;width:32px;height:32px;border-radius:9px;font-size:15px;cursor:pointer}
.sheet-tabs{display:flex;gap:6px;padding:9px;overflow-x:auto;background:var(--card2);border-bottom:1px solid var(--line)}
.sheet-tabs button{white-space:nowrap;border:none;background:#fff;padding:8px 12px;border-radius:10px;font-weight:700;font-size:12.5px;cursor:pointer;color:var(--ink-soft)}
.sheet-tabs button.active{background:var(--green);color:#fff}
.sheet-body{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}
.sheet-body h4{margin:18px 0 8px;font-size:15px;color:var(--green-deep);font-weight:900}
.sheet-body section > h4:first-child{margin-top:6px}
.sheet-body p{font-size:14px;line-height:1.55;margin:6px 0}
.sheet-body ol,.sheet-body ul{margin:6px 0;padding-left:20px}
.sheet-body li{font-size:14px;line-height:1.55;margin-bottom:8px}
.sheet-body b{color:var(--ink)}
.hintbar{background:rgba(197,134,13,.1);border:1px solid rgba(197,134,13,.25);border-radius:12px;padding:11px 13px;font-size:13.5px;color:var(--green-deep);font-weight:600;margin-bottom:6px}
.tip{background:var(--card2);border-left:3px solid var(--gold);border-radius:8px;padding:9px 12px;font-size:13px;color:var(--ink-soft);margin:12px 0 4px}
.sheet-body code{background:#2b2620;color:#ffe2a8;padding:2px 6px;border-radius:5px;font-size:12.5px;font-family:ui-monospace,Menlo,Consolas,monospace}

/* Вхід для персоналу (бойовий режим) */
.staff-link{background:none;border:none;color:var(--ink-soft);font-size:12px;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}
.staff-pop{position:fixed;inset:0;z-index:58;background:rgba(43,38,32,.45);display:grid;place-items:center;padding:20px;animation:fade .15s}
.staff-pop-card{background:var(--card);border-radius:18px;box-shadow:var(--shadow);padding:20px;width:min(320px,90vw);display:flex;flex-direction:column;gap:10px}
.staff-pop-card b{font-size:16px;text-align:center;margin-bottom:4px}
.home-btn{position:fixed;right:16px;bottom:18px;z-index:40;width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(135deg,#a4731f,#6b4410);color:#fff;font-size:22px;box-shadow:0 8px 22px rgba(122,80,10,.4);cursor:pointer}

/* Підвал + тости */
.foot{display:flex;justify-content:space-between;align-items:center;color:var(--ink-soft);font-size:11.5px;padding:14px 4px 4px}
.conn{width:9px;height:9px;border-radius:50%;background:var(--red-soft);box-shadow:0 0 0 3px rgba(231,76,60,.15)}
.conn.on{background:#5b9c3a;box-shadow:0 0 0 3px rgba(91,156,58,.2)}
.toast-wrap{position:fixed;left:0;right:0;bottom:18px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:60;pointer-events:none}
.toast{background:#2b2620;color:#fff;padding:11px 18px;border-radius:13px;font-size:13.5px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.25);animation:fade .25s;max-width:90vw}
.toast.ok{background:var(--green)}
.toast.bad{background:var(--red)}
.toast.gold{background:var(--gold-deep)}
