*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy-950:#0f2137;--navy-900:#152a43;--navy-800:#1b3a5c;--navy-700:#1e4d7b;--blue-600:#2563eb;--blue-500:#3b82f6;--blue-100:#dbeafe;--blue-50:#eff6ff;--amber-600:#d97706;--amber-500:#f59e0b;--amber-400:#fbbf24;--amber-100:#fef3c7;--amber-50:#fffbeb;--green-600:#059669;--green-500:#10b981;--green-100:#d1fae5;--red-600:#dc2626;--red-100:#fee2e2;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--radius:12px;--radius-sm:8px;--header-h:60px;--tab-h:68px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 8px #00000014, 0 1px 2px #0000000a;--shadow-lg:0 8px 24px #0000001f, 0 2px 8px #0000000f;--transition:.2s cubic-bezier(.4, 0, .2, 1)}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--gray-100);color:var(--gray-900);overscroll-behavior:none;-webkit-font-smoothing:antialiased;font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}.app-header{height:var(--header-h);background:linear-gradient(135deg, var(--navy-950) 0%, var(--navy-800) 100%);color:#fff;z-index:100;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 12px #0003}.app-header h1{letter-spacing:-.3px;font-size:19px;font-weight:700}.app-header .status-badge{background:var(--amber-400);color:var(--navy-950);text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:700}.app-header .status-badge.completed{background:var(--green-500);color:#fff}.app-content{padding:calc(var(--header-h) + 16px) 16px calc(var(--tab-h) + 16px);max-width:600px;margin:0 auto}.tab-bar{height:var(--tab-h);border-top:1px solid var(--gray-200);z-index:100;padding-bottom:env(safe-area-inset-bottom,0);background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0000000f}.tab-bar button{color:var(--gray-400);cursor:pointer;transition:color var(--transition);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 0;font-family:inherit;font-size:11px;font-weight:600;display:flex;position:relative}.tab-bar button.active{color:var(--blue-600)}.tab-bar button.active:after{content:"";background:var(--blue-600);border-radius:0 0 3px 3px;height:3px;position:absolute;top:0;left:20%;right:20%}.tab-bar button svg{width:24px;height:24px}.card{border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);transition:box-shadow var(--transition);background:#fff;margin-bottom:14px;padding:18px}.card h2{color:var(--navy-800);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;margin-bottom:14px;font-size:13px;font-weight:700;display:flex}.card h2:before{content:"";background:var(--blue-600);border-radius:2px;flex-shrink:0;width:3px;height:16px}.card h3{color:var(--gray-700);margin-bottom:8px;font-size:14px;font-weight:600}.field{margin-bottom:14px}.field label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px;font-weight:700;display:block}.field input,.field select,.field textarea{border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;min-height:46px;color:var(--gray-900);transition:border-color var(--transition), box-shadow var(--transition);-webkit-appearance:none;background:#fff;padding:11px 14px;font-family:inherit;font-size:16px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue-600);box-shadow:0 0 0 3px var(--blue-100);outline:none}.field input::placeholder,.field textarea::placeholder{color:var(--gray-400)}.field textarea{resize:vertical;min-height:80px}.field-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.field-row-3{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.btn{border-radius:var(--radius-sm);cursor:pointer;min-height:46px;transition:transform var(--transition), opacity var(--transition), box-shadow var(--transition);-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:6px;padding:11px 22px;font-family:inherit;font-size:15px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--blue-600);color:#fff;box-shadow:0 2px 6px #2563eb4d}.btn-primary:active{box-shadow:0 1px 3px #2563eb33}.btn-amber{background:var(--amber-500);color:var(--navy-950);box-shadow:0 2px 6px #f59e0b4d}.btn-green{background:var(--green-600);color:#fff;box-shadow:0 2px 6px #0596694d}.btn-danger{background:var(--red-600);color:#fff;box-shadow:0 2px 6px #dc26264d}.btn-outline{color:var(--blue-600);border:1.5px solid var(--blue-600);background:#fff}.btn-sm{min-height:38px;padding:7px 16px;font-size:13px}.btn-block{width:100%}.btn-icon{border-radius:50%;width:46px;height:46px;padding:0}.btn-group{gap:8px;display:flex}.chip-row{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.chip{border:1.5px solid var(--gray-300);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;background:#fff;border-radius:20px;align-items:center;gap:4px;padding:7px 14px;font-size:13px;font-weight:600;display:inline-flex}.chip:active{transform:scale(.95)}.chip.active{background:var(--blue-100);border-color:var(--blue-600);color:var(--blue-600)}.chip-amber{background:var(--amber-50);border-color:var(--amber-500);color:var(--amber-600)}.area-card{border-left:4px solid var(--blue-600);transition:border-color var(--transition);margin-bottom:18px;padding-left:14px}.area-card.inspected{border-left-color:var(--green-600)}.area-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.area-card-header h3{margin:0;font-size:16px;font-weight:700}.area-badge{letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.area-badge.done{background:var(--green-100);color:var(--green-600)}.area-badge.pending{background:var(--gray-100);color:var(--gray-500)}.capture-item{background:var(--gray-50);border-radius:var(--radius-sm);border:1px solid var(--gray-200);transition:opacity var(--transition);align-items:flex-start;gap:10px;margin-bottom:8px;padding:12px;display:flex}.capture-item .chalk-tag{background:var(--amber-100);color:var(--amber-600);white-space:nowrap;border-radius:6px;padding:2px 10px;font-size:12px;font-weight:700;display:inline-block}.capture-item .capture-text{color:var(--gray-700);flex:1;font-size:14px;line-height:1.4}.capture-item .capture-time{color:var(--gray-400);white-space:nowrap;font-size:11px}.capture-item.promoted{opacity:.45}.finding-card{border-radius:var(--radius-sm);border-left:4px solid var(--blue-600);box-shadow:var(--shadow-sm);border-top:1px solid var(--gray-200);border-right:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);transition:box-shadow var(--transition);background:#fff;margin-bottom:10px;padding:14px}.finding-card.section-I{border-left-color:var(--red-600)}.finding-card.section-II{border-left-color:var(--amber-600)}.finding-card.section-FI{border-left-color:var(--gray-400)}.finding-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.finding-ref{color:var(--navy-800);font-size:15px;font-weight:800}.finding-section-badge{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.finding-section-badge.sec-I{background:var(--red-100);color:var(--red-600)}.finding-section-badge.sec-II{background:var(--amber-100);color:var(--amber-600)}.finding-section-badge.sec-FI{background:var(--gray-200);color:var(--gray-600)}.finding-phrase{color:var(--gray-600);margin-bottom:8px;font-size:14px;line-height:1.4}.finding-prices{gap:12px;font-size:13px;display:flex}.finding-prices .price-label{color:var(--gray-400)}.finding-prices .price-value{font-weight:700}.phrase-search{position:relative}.phrase-dropdown{border:1px solid var(--gray-200);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;background:#fff;max-height:240px;animation:.15s ease-out dropIn;position:absolute;top:100%;left:0;right:0;overflow-y:auto}@keyframes dropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.phrase-option{cursor:pointer;border-bottom:1px solid var(--gray-100);transition:background var(--transition);padding:12px 14px;font-size:14px}.phrase-option:last-child{border-bottom:none}.phrase-option:active{background:var(--blue-50)}.phrase-option .phrase-code{color:var(--navy-800);margin-right:8px;font-weight:800}.recorder{background:var(--red-100);border-radius:var(--radius);border:1px solid #dc262633;align-items:center;gap:12px;margin-bottom:12px;padding:14px;display:flex}.recorder .rec-dot{background:var(--red-600);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.recorder .rec-time{font-variant-numeric:tabular-nums;color:var(--red-600);flex:1;font-size:20px;font-weight:700}.diagram-container{border:2px solid var(--gray-300);border-radius:var(--radius);touch-action:none;background:#fff;overflow:hidden}.diagram-container canvas{width:100%;display:block}.diagram-toolbar{background:var(--gray-50);border-top:1px solid var(--gray-200);gap:6px;padding:10px;display:flex;overflow-x:auto}.diagram-toolbar button{border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;min-width:42px;height:42px;transition:all var(--transition);background:#fff;justify-content:center;align-items:center;padding:0 12px;font-family:inherit;font-size:13px;font-weight:600;display:flex}.diagram-toolbar button.active{background:var(--blue-600);color:#fff;border-color:var(--blue-600);box-shadow:0 2px 6px #2563eb4d}.timer-card{text-align:center;padding:24px}.timer-display{font-variant-numeric:tabular-nums;color:var(--navy-800);letter-spacing:-1px;margin:16px 0;font-size:52px;font-weight:800}.timer-display.warning{color:var(--amber-600)}.timer-display.done{color:var(--green-600)}.review-section{margin-bottom:18px}.review-section h3{text-transform:uppercase;letter-spacing:.8px;color:var(--gray-400);margin-bottom:8px;font-size:12px;font-weight:700}.review-row{border-bottom:1px solid var(--gray-100);justify-content:space-between;padding:8px 0;font-size:14px;display:flex}.review-row .label{color:var(--gray-500)}.review-total{color:var(--navy-800);text-align:right;padding-top:10px;font-size:20px;font-weight:800}.json-output{background:var(--gray-900);color:#86efac;border-radius:var(--radius);white-space:pre;border:1px solid var(--gray-700);max-height:400px;padding:18px;font-family:SF Mono,Fira Code,JetBrains Mono,monospace;font-size:12px;line-height:1.6;overflow:auto}.checkbox-row{border-bottom:1px solid var(--gray-100);align-items:center;gap:10px;padding:10px 0;display:flex}.checkbox-row:last-child{border-bottom:none}.checkbox-row input[type=checkbox]{width:22px;height:22px;accent-color:var(--blue-600);flex-shrink:0}.checkbox-row label{color:var(--gray-700);font-size:14px}.photo-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;display:grid}.photo-thumb{aspect-ratio:1;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%}.photo-thumb .photo-delete{color:#fff;cursor:pointer;width:26px;height:26px;transition:background var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:6px;right:6px}.photo-thumb .photo-area-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;border-radius:6px;padding:2px 8px;font-size:10px;font-weight:700;position:absolute;bottom:6px;left:6px}.empty-state{text-align:center;color:var(--gray-400);padding:40px 20px}.empty-state p{font-size:14px;line-height:1.5}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a99;justify-content:center;align-items:flex-end;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{width:100%;max-width:600px;max-height:85vh;padding:24px 20px calc(env(safe-area-inset-bottom,0px) + 20px);background:#fff;border-radius:20px 20px 0 0;animation:.25s ease-out slideUp;overflow-y:auto;box-shadow:0 -4px 24px #00000026}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-content h2{color:var(--navy-800);margin-bottom:18px;font-size:18px;font-weight:700}.section-nav{gap:6px;margin-bottom:14px;display:flex;overflow-x:auto}.section-nav button{border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);cursor:pointer;min-height:42px;color:var(--gray-600);white-space:nowrap;transition:all var(--transition);background:#fff;flex:1;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:700}.section-nav button.active{background:var(--blue-600);color:#fff;border-color:var(--blue-600);box-shadow:0 2px 6px #2563eb40}.section-nav button.done{border-color:var(--green-500);color:var(--green-600);background:var(--green-100)}.divider{background:var(--gray-200);height:1px;margin:18px 0}.text-muted{color:var(--gray-500);font-size:13px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mb-12{margin-bottom:12px}.auth-container{background:radial-gradient(ellipse at 30% 20%, #2563eb14 0%, transparent 50%), radial-gradient(ellipse at 70% 80%, #f59e0b0f 0%, transparent 50%), var(--gray-100);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.auth-card{width:100%;max-width:380px;box-shadow:var(--shadow-lg);text-align:center;border:1px solid var(--gray-200);background:#fff;border-radius:16px;padding:40px 28px}.auth-card h1{color:var(--navy-950);letter-spacing:-.5px;margin-bottom:6px;font-size:26px;font-weight:800}.auth-subtitle{color:var(--gray-500);margin-bottom:28px;font-size:14px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-form input{border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:12px 14px;font-family:inherit;font-size:15px}.auth-form input:focus{border-color:var(--blue-600);box-shadow:0 0 0 3px var(--blue-100)}.auth-form input::placeholder{color:var(--gray-400)}.auth-error{color:var(--red-600);text-align:left;font-size:13px;font-weight:500}.auth-submit{background:var(--blue-600);color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:transform var(--transition), box-shadow var(--transition);border:none;padding:12px;font-family:inherit;font-size:15px;font-weight:700;box-shadow:0 2px 8px #2563eb4d}.auth-submit:active{transform:scale(.98)}.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-toggle{color:var(--blue-600);cursor:pointer;transition:opacity var(--transition);background:0 0;border:none;margin-top:20px;font-family:inherit;font-size:13px;font-weight:500}.auth-toggle:active{opacity:.7}.header-right{align-items:center;gap:10px;display:flex}.sign-out-btn{color:#fffc;cursor:pointer;transition:all var(--transition);background:#ffffff1f;border:1px solid #ffffff26;border-radius:20px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500}.sign-out-btn:active{color:#fff;background:#fff3}
