:root{--bg: #141414;--bg2: #1c1c1c;--bg3: #1a1a1a;--bgi: #2a2a2a;--bge: #252525;--brd: #2a2a2a;--brd2: #333;--brdi: #444;--t1: #eee;--t2: #999;--t3: #777;--t4: #555;--acc: #f5a623;--accd: #e8891c;--blue: #4fc3f7;--green: #66bb6a;--red: #ef5350;--purple: #ab47bc;--font: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "Space Mono", monospace;--safe-b: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font);background:var(--bg);color:var(--t1);min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}#root{min-height:100vh;min-height:100dvh;position:relative}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--brd2);border-radius:3px}::selection{background:#f5a6234d}input:-webkit-autofill{-webkit-text-fill-color:var(--t1);-webkit-box-shadow:0 0 0 1000px var(--bgi) inset}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.spin{animation:spin .8s linear infinite}.app:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;opacity:.03;background-image:repeating-linear-gradient(0deg,#fff 0,#fff 1px,transparent 1px,transparent 60px),repeating-linear-gradient(90deg,#fff 0,#fff 1px,transparent 1px,transparent 60px);pointer-events:none;z-index:0}.app{position:relative}.page{max-width:860px;margin:0 auto;padding:24px 20px;position:relative;z-index:1}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg);flex-direction:column;gap:16px}.loading-logo{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--acc),var(--accd));display:flex;align-items:center;justify-content:center}.loading-spinner{width:32px;height:32px;border:3px solid var(--brd2);border-top-color:var(--acc);border-radius:50%;animation:spin .8s linear infinite}.offline-bar{position:fixed;top:env(safe-area-inset-top,0);left:0;right:0;background:var(--red);color:#fff;text-align:center;padding:6px;font-size:12px;font-weight:700;z-index:1000;animation:slideUp .3s}.header{margin-bottom:28px;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:14px}.header__brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}.header__logo{width:40px;height:40px;background:linear-gradient(135deg,var(--acc),var(--accd));border-radius:10px;display:flex;align-items:center;justify-content:center}.header__title{font-size:30px;font-weight:900;letter-spacing:-.02em;background:linear-gradient(135deg,#f5a623,#ffd080);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header__sub{color:var(--t3);font-size:13px;font-family:var(--mono)}.header__actions{display:flex;gap:8px;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:28px}.stat-card{background:var(--bg2);border:1px solid var(--brd);border-radius:14px;padding:16px 14px}.stat-card__label{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;font-family:var(--mono);margin-bottom:5px}.stat-card__value{font-size:20px;font-weight:800}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.project-card{background:var(--bg2);border:1px solid var(--brd);border-radius:16px;cursor:pointer;overflow:hidden;transition:transform .2s,border-color .2s}.project-card:hover{transform:translateY(-2px)}.project-card__bar{height:4px}.project-card__body{padding:18px 20px}.project-card__top{display:flex;justify-content:space-between;margin-bottom:12px}.project-card__name{font-size:17px;font-weight:800;margin-bottom:3px}.project-card__client{font-size:12px;color:#888}.project-card__addr{font-size:11px;color:#666;font-family:var(--mono);margin-top:2px}.project-card__stats{display:flex;gap:14px;font-size:12px;color:var(--t2)}.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap}.detail-header__name{font-size:21px;font-weight:800;margin:0}.detail-header__sub{font-size:12px;color:var(--t3)}.btn-back{background:var(--bg2);border:1px solid var(--brd2);border-radius:10px;padding:8px 10px;cursor:pointer;color:#ccc;display:flex;align-items:center}.tabs{display:flex;gap:4px;margin-bottom:22px;background:var(--bg3);border-radius:14px;padding:4px;border:1px solid var(--brd)}.tab{flex:1;padding:10px 8px;border-radius:10px;border:none;cursor:pointer;background:transparent;color:#888;font-weight:500;font-size:13px;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.tab--active{font-weight:700}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;flex-wrap:wrap;gap:10px}.section-title{font-size:16px;font-weight:700;color:#ddd;margin:0}.section-sub{margin:4px 0 0;font-size:13px;color:#666}.empty-state{text-align:center;padding:70px 20px;color:var(--t4)}.empty-state--sm{padding:50px 20px;background:var(--bg3);border-radius:16px;border:2px dashed var(--brd2)}.empty-state__title{font-weight:600;font-size:15px;margin-top:12px}.empty-state__desc{font-size:13px;color:#444;margin-top:4px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.photo-card{border-radius:12px;overflow:hidden;background:var(--bg2);border:1px solid var(--brd)}.photo-card__img{width:100%;height:150px;object-fit:cover;display:block}.photo-card__footer{padding:7px 10px;display:flex;justify-content:space-between;align-items:center}.list{display:flex;flex-direction:column;gap:8px}.list-item{background:var(--bg2);border-radius:12px;padding:13px 16px;border:1px solid var(--brd);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.list-item__name{font-weight:700;font-size:15px}.list-item__cls{font-weight:400;color:var(--acc);margin-left:8px;font-size:11px}.list-item__sub{font-weight:400;color:#888;margin-left:8px;font-size:12px}.list-item__meta{font-size:11px;color:var(--t3);margin-top:2px}.list-item__note{font-size:12px;color:var(--t2);margin-top:3px;font-style:italic}.mono-sm{font-size:11px;color:var(--t3);font-family:var(--mono);margin-top:2px}.big-value{font-size:20px;font-weight:800;font-family:var(--mono)}.scanned-badge{font-size:9px;background:#ab47bc22;color:#ce93d8;padding:2px 6px;border-radius:4px;font-weight:600;text-transform:uppercase;margin-left:6px}.priority-badge{font-size:10px;font-weight:700;padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:1px;font-family:var(--mono);flex-shrink:0}.calc-box{background:var(--bgi);border-radius:10px;padding:10px 14px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}.cls-badge-sm{font-size:10px;color:var(--acc);background:#f5a6231a;padding:2px 8px;border-radius:4px}.task-check{width:26px;height:26px;border-radius:8px;border:2px solid var(--t4);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:transparent;transition:all .2s}.task-check--done{border:none;color:#111}.btn-primary{padding:11px 24px;background:linear-gradient(135deg,var(--acc),var(--accd));border:none;border-radius:10px;color:#111;font-weight:700;font-size:14px;cursor:pointer;font-family:var(--font);box-shadow:0 4px 16px #f5a6234d;transition:transform .15s}.btn-primary:hover{transform:translateY(-1px)}.btn--disabled{background:#555!important;color:#888!important;box-shadow:none!important;cursor:default!important;transform:none!important}.btn-secondary{padding:11px 24px;background:transparent;border:1px solid var(--t4);border-radius:10px;color:#ccc;font-weight:600;font-size:14px;cursor:pointer;font-family:var(--font)}.btn-delete{background:#ff3c3c1a;border:1px solid rgba(255,60,60,.3);border-radius:8px;padding:6px 8px;cursor:pointer;color:#f55;display:flex;align-items:center;flex-shrink:0;transition:background .2s}.btn-delete:hover{background:#ff3c3c33}.btn-edit{background:#f5a6231a;border:1px solid rgba(245,166,35,.3);border-radius:8px;padding:6px 8px;cursor:pointer;color:var(--acc);display:flex;align-items:center}.text-btn{background:none;border:none;color:var(--acc);font-size:12px;cursor:pointer;font-family:var(--font);font-weight:600;text-align:right;display:block;margin:-4px 0 12px auto}.field{margin-bottom:14px}.field__label{display:block;font-size:11px;color:var(--t2);margin-bottom:5px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.field__input{width:100%;padding:10px 14px;background:var(--bgi);border:1px solid var(--brdi);border-radius:10px;color:var(--t1);font-size:14px;font-family:var(--font);outline:none;box-sizing:border-box;transition:border-color .2s}.field__input:focus{border-color:var(--acc)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.emp-selected{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bgi);border:1px solid var(--brdi);border-radius:10px;cursor:pointer}.emp-selected__name{color:var(--t1);font-size:14px;font-weight:600}.emp-selected__cls{margin-left:8px;font-size:11px;color:var(--acc)}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bgi);border:1px solid var(--t4);border-radius:10px;margin-top:4px;z-index:50;overflow:hidden;box-shadow:0 8px 24px #0006}.autocomplete-item{padding:9px 14px;cursor:pointer;font-size:13px;color:#ddd;border-bottom:1px solid var(--brd2);transition:background .15s}.autocomplete-item:hover{background:var(--brd2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:16px}.modal{background:#1e1e1e;border-radius:16px;padding:28px;width:100%;max-width:440px;border:1px solid var(--brd2);box-shadow:0 24px 48px #0006;max-height:90vh;overflow-y:auto;animation:fadeIn .2s}.modal--wide{max-width:600px}.modal__title{margin:0 0 20px;font-size:18px;color:var(--acc);font-weight:700}.modal__actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.sub-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg3);border-radius:10px;padding:3px}.sub-tab{flex:1;padding:9px 8px;border-radius:8px;border:none;cursor:pointer;background:transparent;color:#888;font-weight:500;font-size:13px;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px}.sub-tab--active{background:var(--acc);color:#111;font-weight:700}.form-section{background:var(--bge);border-radius:12px;padding:16px;margin-bottom:16px}.form-section__title{font-size:12px;color:var(--acc);font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.color-dot{width:30px;height:30px;border-radius:8px;cursor:pointer;transition:border .2s}.cls-chip{display:flex;align-items:center;gap:6px;background:#f5a62314;border:1px solid rgba(245,166,35,.2);border-radius:8px;padding:8px 12px}.cls-chip span{font-size:13px;color:var(--acc);font-weight:600}.cls-chip__x{background:none;border:none;color:#888;cursor:pointer;padding:0;font-size:16px;line-height:1}.scan-error{background:#3a1c1c;border:1px solid #5a2a2a;border-radius:10px;padding:10px 14px;margin-bottom:14px;color:#f88;font-size:13px}.weather-card{background:#1c3a5c;border-radius:10px;padding:12px 16px;margin-top:4px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.report-list{display:flex;flex-direction:column;gap:10px}.report-btn{background:var(--bg2);border:1px solid var(--brd2);border-radius:12px;padding:16px 18px;cursor:pointer;text-align:left;transition:border-color .2s;display:flex;align-items:center;gap:10px}.report-btn:hover{border-color:var(--acc)}.report-btn--inline{display:block;cursor:default}.report-btn--inline:hover{border-color:var(--brd2)}.report-btn__icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-btn__label{font-weight:700;font-size:14px;color:var(--t1)}.report-btn__desc{font-size:12px;color:#888;margin-top:1px}.install-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--brd2);padding:16px 20px;padding-bottom:calc(16px + var(--safe-b));display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:900;animation:slideUp .3s;box-shadow:0 -4px 24px #0006}.install-banner__title{font-weight:700;font-size:14px}.install-banner__desc{font-size:12px;color:var(--t3);margin-top:2px}.install-banner__x{background:none;border:none;color:#888;cursor:pointer;font-size:20px;padding:4px 8px}@media (max-width:480px){.page{padding:16px}.header{margin-bottom:20px}.header__title{font-size:24px}.project-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.detail-header{gap:8px}.section-header{flex-direction:column;align-items:flex-start}.field-row{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}}.auth-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:var(--bg2);border:1px solid var(--brd);border-radius:20px;padding:36px 32px;width:100%;max-width:400px;animation:fadeIn .3s}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:24px;justify-content:center}.auth-logo__icon{width:44px;height:44px;background:linear-gradient(135deg,var(--acc),var(--accd));border-radius:12px;display:flex;align-items:center;justify-content:center}.auth-logo__text{font-size:28px;font-weight:900;background:linear-gradient(135deg,#f5a623,#ffd080);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-subtitle{text-align:center;color:var(--t3);font-size:13px;margin-bottom:28px;font-family:var(--mono)}.auth-error{background:#3a1c1c;border:1px solid #5a2a2a;border-radius:10px;padding:10px 14px;margin-bottom:14px;color:#f88;font-size:13px;text-align:center}.auth-success{background:#1c3a1c;border:1px solid #2a5a2a;border-radius:10px;padding:10px 14px;margin-bottom:14px;color:#8f8;font-size:13px;text-align:center}.auth-toggle{text-align:center;margin-top:20px;font-size:13px;color:var(--t3)}.auth-toggle button{background:none;border:none;color:var(--acc);font-weight:700;cursor:pointer;font-family:var(--font);font-size:13px;text-decoration:underline}.auth-divider{text-align:center;color:var(--t4);font-size:11px;margin:16px 0;position:relative}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 20px);height:1px;background:var(--brd)}.auth-divider:before{left:0}.auth-divider:after{right:0}.user-bar{display:flex;align-items:center;gap:8px;padding:4px 12px;background:var(--bgi);border-radius:8px;font-size:12px;color:var(--t2)}.user-bar__email{font-weight:600;color:var(--t1);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-bar__logout{background:none;border:none;color:var(--red);cursor:pointer;font-size:11px;font-weight:700;font-family:var(--font);padding:4px 8px}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#141414cc;display:flex;align-items:center;justify-content:center;z-index:500;flex-direction:column;gap:12px}.loading-overlay__text{color:var(--t2);font-size:13px}.sync-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}.sync-dot--ok{background:var(--green)}.sync-dot--saving{background:var(--acc);animation:spin .8s linear infinite}.sync-dot--error{background:var(--red)}@media print{.no-print{display:none!important}body{background:#fff;color:#000;padding:0}}
