:root{--bg:#000;--bg-card:#141414;--bg-card-2:#1c1c1e;--bg-elevated:#2c2c2e;--bg-input:#2a2a2a;--text:#fff;--text-muted:#8e8e93;--text-dim:#636366;--text-link:#707a8c;--accent:#22c55e;--accent-glow:#34d058;--accent-soft:#22c55e26;--danger:#ef4444;--purple-from:#5b21b6;--purple-to:#312e81;--green-btn:#1b4332;--green-btn-text:#4ade80;--yellow-icon:#facc15;--nav-height:88px;--safe-bottom:env(safe-area-inset-bottom,0px);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{background:var(--bg);min-height:100%;margin:0}body{overflow-x:hidden}button,input,textarea{font:inherit}a{color:inherit;text-decoration:none}.app-shell{min-height:100dvh;padding-bottom:calc(var(--nav-height) + var(--safe-bottom));background:var(--bg)}.screen{padding:0 16px 24px}.top-bar{color:var(--text-muted);grid-template-columns:1fr auto 1fr;align-items:center;padding:10px 16px 6px;font-size:13px;display:grid}.top-bar__left{justify-self:start;align-items:center;gap:4px;display:flex}.top-bar__center{opacity:.7;justify-self:center}.top-bar__title{color:var(--text-muted);font-size:13px;font-weight:400}.top-bar__right{justify-self:end;align-items:center;gap:10px;font-size:13px;display:flex}.top-bar__lang{text-transform:lowercase}.top-bar__time{align-items:center;gap:4px;display:inline-flex}.tab-bar{gap:6px;padding:0 16px 14px;display:flex}.tab-bar__item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 8px;font-size:14px;display:inline-flex}.tab-bar__item--active{background:var(--bg-card-2);color:var(--text);font-weight:500}.tab-bar__dot{background:var(--accent-glow);width:7px;height:7px;box-shadow:0 0 6px var(--accent-glow);border-radius:50%}.bottom-nav{left:16px;right:16px;bottom:calc(10px + var(--safe-bottom));-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:100;background:#1c1c1ef0;border-radius:22px;justify-content:space-around;align-items:center;height:62px;padding:0 6px;display:flex;position:fixed}.bottom-nav__item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:18px;flex-direction:row;justify-content:center;align-items:center;gap:6px;min-width:44px;padding:10px 14px;font-size:12px;display:flex}.bottom-nav__item--active{color:var(--text);background:#ffffff1a}.bottom-nav__item--icon-only{padding:10px 12px}.card{background:var(--bg-card);border-radius:18px;padding:16px}.card+.card,.card+.form-section{margin-top:12px}.form-section{margin-bottom:12px}.form-section__head{justify-content:space-between;align-items:center;margin-bottom:10px;font-size:15px;font-weight:600;display:flex}.form-section__help{color:var(--text-dim);font-size:13px;font-weight:400}.field{background:var(--bg-input);width:100%;color:var(--text);border:none;border-radius:14px;outline:none;padding:15px 16px;font-size:15px}.field::placeholder{color:var(--text-dim)}.field--underline{text-align:center;background:0 0;border-bottom:1px solid #ffffff1f;border-radius:0;padding:12px 0}.input-label-row{justify-content:space-between;align-items:center;margin-bottom:10px;font-size:15px;font-weight:600;display:flex}.input-label-row small{color:var(--text-dim);font-size:13px;font-weight:400}.btn{cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:15px 20px;font-size:15px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--purple-from), var(--purple-to));color:#fff;box-shadow:0 8px 24px #5b21b659}.btn-glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text);background:#2c2c2ee0;border:1px solid #ffffff0f}.btn-green{background:var(--green-btn);color:var(--green-btn-text);border-radius:14px;padding:12px 16px;font-size:14px}.btn-icon-square{background:var(--bg-elevated);width:42px;height:42px;color:var(--text-muted);border-radius:12px;padding:0;font-size:16px}.btn-icon-square--danger{color:#fca5a5;background:#7f1d1d73}.btn-block{width:100%}.floating-action{left:16px;right:16px;bottom:calc(var(--nav-height) + var(--safe-bottom) + 4px);z-index:90;flex-direction:column;gap:10px;display:flex;position:fixed}.dashboard-stats{margin-bottom:12px}.dashboard-metrics{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px;display:grid}.metric{text-align:center;flex-direction:column;align-items:center;display:flex}.metric__label{color:var(--text-muted);margin-bottom:4px;font-size:14px}.metric__value{letter-spacing:-.02em;font-size:26px;font-weight:700;line-height:1.15}.metric__sub{color:var(--text-muted);margin-top:2px;font-size:13px}.project-record{text-align:center;color:var(--text-muted);margin:8px 0 4px;font-size:13px}.workers-card__head{justify-content:space-between;align-items:baseline;margin-bottom:14px;font-size:15px;font-weight:600;display:flex}.workers-card__cols{color:var(--text-muted);gap:16px;font-size:12px;font-weight:400;display:flex}.worker-row{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:11px 0;font-size:14px;display:flex}.worker-row:last-child{border-bottom:none}.worker-row__left{align-items:center;gap:10px;display:flex}.worker-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.chart-area{touch-action:pan-y;height:176px;margin:8px 0 16px;position:relative}.chart-area svg{width:100%;height:132px;display:block;overflow:visible}.chart-area__hit{cursor:crosshair}.chart-area__line,.chart-area__fill{transition:d .45s}.chart-area__dot,.chart-area__cursor{pointer-events:none;transition:transform .15s ease-out}.chart-area__label{transition:fill .15s}.chart-area__tooltip-wrap{height:36px;margin-top:2px;position:relative}.chart-area__tooltip{background:var(--bg-card-2);pointer-events:none;white-space:nowrap;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;transition:left .15s ease-out;display:flex;position:absolute;bottom:0;transform:translate(-50%)}.chart-area__tooltip-value{color:var(--accent-glow);font-size:18px;font-weight:700;line-height:1}.chart-area__tooltip-unit{color:var(--text-muted);font-size:11px}.pin-screen{min-height:100dvh;padding:56px 24px calc(28px + var(--safe-bottom));background:var(--bg);flex-direction:column;justify-content:space-between;align-items:center;display:flex}.pin-screen__header{text-align:center;width:100%}.pin-screen__emoji{margin-bottom:20px;font-size:64px;line-height:1}.pin-screen__title{margin:0 0 12px;font-size:20px;font-weight:500}.pin-screen__user{color:var(--text-link);align-items:center;gap:6px;font-size:14px;display:inline-flex}.pin-screen__error{color:#fca5a5;margin-top:8px;font-size:14px}.pin-dots{justify-content:center;gap:16px;margin:28px 0 0;display:flex}.pin-dot{background:#555b66;border-radius:50%;width:12px;height:12px}.pin-dot--filled{background:#8e99a8}.pin-pad{grid-template-columns:repeat(3,1fr);gap:16px 32px;width:min(300px,100%);display:grid}.pin-pad button{color:var(--text);cursor:pointer;background:0 0;border:none;padding:14px;font-size:30px;font-weight:300}.pin-pad__empty{visibility:hidden}.segmented{background:var(--bg-input);border-radius:12px;padding:3px;display:inline-flex}.segmented button{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:10px;padding:6px 10px;font-size:12px}.segmented button.active{background:var(--bg-card-2);color:var(--text)}.icon-carousel{align-items:center;gap:8px;margin:12px 0;display:flex}.icon-carousel__list{flex:1;justify-content:center;align-items:center;gap:16px;display:flex;overflow:hidden}.icon-option{background:var(--bg-input);text-align:center;cursor:pointer;white-space:pre-line;border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:68px;height:68px;padding:6px;font-size:10px;font-weight:700;line-height:1.15;transition:transform .2s,border-color .2s;display:flex;overflow:hidden}.icon-option--active{border-color:#ffffffd9;transform:scale(1.08)}.icon-option--side{opacity:.55;transform:scale(.92)}.icon-carousel__nav{background:var(--bg-elevated);width:34px;height:34px;color:var(--text);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;font-size:18px}.icon-carousel__label{color:var(--text-muted);text-align:center;margin-top:10px;font-size:14px}.icon-survey-stripes{flex-direction:column;align-items:center;gap:4px;width:100%;display:flex}.icon-survey-stripes__bars{gap:5px;display:flex;transform:rotate(-35deg)}.icon-survey-stripes__bars span{background:#111;border-radius:2px;width:7px;height:28px}.icon-survey-stripes__text{letter-spacing:.04em;font-size:8px;font-weight:800}.build-icon{background:var(--yellow-icon);color:#111;text-align:center;white-space:pre-line;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:9px;font-weight:800;line-height:1.1;display:flex}.build-card__info{flex:1;min-width:0}.build-card__title{margin:0;font-size:16px;font-weight:600}.build-card__sub{color:var(--text-muted);margin-top:2px;font-size:13px}.build-card__actions{flex-direction:column;align-items:stretch;gap:8px;margin-left:auto;display:flex}.build-card__icon-row{gap:8px;display:flex}.history-card__top{align-items:flex-start;gap:12px;display:flex}.history-card__right{text-align:right;flex-direction:column;align-items:flex-end;gap:8px;margin-left:auto;display:flex}.progress-card__top{align-items:flex-start;gap:12px;display:flex}.progress-card__body{flex:1;min-width:0}.progress-card__date{color:var(--text-muted);white-space:nowrap;font-size:12px}.progress-card__time-left{color:var(--text-muted);margin-top:6px;font-size:13px}.progress-card__footer{align-items:center;gap:10px;margin-top:14px;display:flex}.progress-bar{background:#2a2a2a;border-radius:999px;flex:1;height:5px;overflow:hidden}.progress-bar__fill{background:#a1a1aa;border-radius:999px;height:100%;transition:width .3s}.progress-card__percent{color:var(--text);min-width:28px;font-size:13px}.screen-picker{text-align:center;padding-top:8px}.screen-picker__title{margin:0 0 8px;font-size:22px;font-weight:700}.screen-picker__subtitle{color:var(--text-muted);margin:0 0 20px;padding:0 12px;font-size:14px;line-height:1.4}.screen-picker__wrap{justify-content:center;align-items:center;gap:8px;margin-bottom:16px;display:flex;position:relative}.screen-picker__phone{background:#111;border:3px solid #333;border-radius:28px;flex-direction:column;width:min(240px,72vw);min-height:380px;padding:10px 12px 14px;display:flex;position:relative;overflow:hidden}.phone-status{color:var(--text-muted);justify-content:space-between;margin-bottom:8px;font-size:11px;display:flex}.phone-status__icons{gap:4px;display:flex}.phone-app-icon{background:linear-gradient(135deg,#f59e0b,#ec4899,#6366f1);border-radius:18px;width:72px;height:72px;margin:48px auto 16px}.phone-title{margin-bottom:4px;font-size:15px;font-weight:600}.phone-subtitle{color:var(--text-muted);font-size:12px}.phone-permission{color:#111;text-align:left;background:#fff;border-radius:14px;margin-top:auto;padding:14px;font-size:12px;line-height:1.35}.phone-permission__icon{color:#fff;background:#2563eb;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;margin-bottom:8px;font-size:14px;display:inline-flex}.screen-picker__select{z-index:2;width:calc(100% - 48px);position:absolute;bottom:72px;left:50%;transform:translate(-50%)}.screen-picker__webview{color:#111;text-align:left;background:#fff;border-radius:8px;flex:1;margin-top:8px;padding:8px;font-size:10px;overflow:hidden}.screen-picker__webview-bar{gap:4px;margin-bottom:6px;display:flex}.screen-picker__webview-dot{background:#ccc;border-radius:50%;width:6px;height:6px}.preset-buttons{grid-template-columns:1fr 1fr;gap:10px;display:grid}.preset-btn{color:#fff;cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:14px;font-weight:600;display:flex}.preset-btn--photo{background:#14532d}.preset-btn--video{background:#581c87}.preset-label{color:var(--text-muted);margin:14px 0 10px;font-size:13px}.status-badge{white-space:nowrap;border-radius:999px;align-items:center;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.status-badge--success{color:var(--accent-glow);background:#22c55e2e}.status-badge--running{color:var(--text-muted);background:#ffffff14}.status-badge--failed{color:var(--danger);background:#ef444426}.modal-overlay{z-index:200;background:#000000c7;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:24px;width:100%;max-width:480px;max-height:85dvh;padding:20px;overflow-y:auto}.modal__header{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.modal__header-info{flex:1}.modal__edit-row{align-items:center;gap:6px;font-size:16px;font-weight:600;display:flex}.modal__edit-row--sub{color:var(--text-muted);margin-top:2px;font-size:14px;font-weight:400}.modal__save{color:var(--text);cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px}.modal__section-title{color:var(--text-dim);text-transform:lowercase;margin-bottom:10px;font-size:12px}.modal__param-row{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:10px 0;font-size:14px;display:flex}.modal__param-row:last-child{border-bottom:none}.modal__param-label{align-items:center;gap:6px;display:flex}.modal__param-value{color:var(--text-muted);text-align:right;word-break:break-word;max-width:55%}.modal__actions{grid-template-columns:1fr 1fr;gap:12px;margin-top:18px;display:grid}.modal__btn-cancel{background:var(--bg-elevated);color:var(--text)}.modal__btn-confirm{color:var(--text);background:#111;border:1px solid #ffffff14}.toggle-row{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:12px 0;font-size:14px;display:flex}.toggle-row:last-child{border-bottom:none}.toggle-row__label{align-items:center;gap:6px;display:flex}.toggle{cursor:pointer;background:#3a3a3c;border:none;border-radius:999px;flex-shrink:0;width:46px;height:28px;transition:background .2s;position:relative}.toggle--on{background:var(--accent)}.toggle:after{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle--on:after{transform:translate(18px)}.stats-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.stat-value{font-size:28px;font-weight:700}.stat-sub{color:var(--text-muted);font-size:13px}.empty-state{text-align:center;color:var(--text-muted);padding:48px 16px;font-size:14px}.loading-screen{min-height:100dvh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.error-banner{color:#fca5a5;background:#ef44441f;border-radius:14px;margin-bottom:12px;padding:12px 16px;font-size:13px}.device-card{justify-content:space-between;align-items:center;gap:12px;display:flex}.device-card__meta{color:var(--text-muted);margin-top:4px;font-size:12px}.online-dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 8px var(--accent);border-radius:50%}.offline-dot{background:#52525b;border-radius:50%;width:8px;height:8px}.status-tab-content{font-size:14px;line-height:1.6}.status-tab-content p{margin:0 0 8px}.maintenance-screen{text-align:center;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:32px 24px;display:flex}.maintenance-screen__emoji{margin-bottom:20px;font-size:56px}.maintenance-screen__title{margin:0 0 12px;font-size:24px;font-weight:600}.maintenance-screen__text{color:var(--text-muted);margin:0;font-size:15px;line-height:1.5}
