:root{--bg-main: #0f172a;--bg-card: #1e293b;--bg-card-hover: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--primary-color: #4f46e5;--primary-hover: #4338ca;--success-color: #16a34a;--success-hover: #15803d;--border-color: #334155;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06)}body{margin:0;padding:0;background-color:var(--bg-main);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}.app-wrapper{min-height:100vh;width:100%;background-color:var(--bg-main)}.container{width:100%;max-width:1024px;margin:0 auto;padding:24px 16px}.header{text-align:center;margin-bottom:32px}.header h1{font-size:2rem;font-weight:700;margin:0 0 8px;color:#fff}.header p{color:var(--text-secondary);margin:0;font-size:.9rem}.main-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}@media (min-width: 640px){.main-grid{grid-template-columns:1fr 1fr}}.section-title{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;display:flex;align-items:center}.step-badge{background-color:#334155;color:#cbd5e1;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-right:8px;font-size:10px}.card{background-color:var(--bg-card);padding:16px;border-radius:8px;box-shadow:var(--shadow);border:1px solid rgba(51,65,85,.5)}.input-group label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:4px}.input-field{width:100%;background-color:var(--bg-main);border:1px solid #475569;border-radius:4px;padding:12px;color:#cbd5e1;margin-bottom:16px;font-family:monospace;font-size:.875rem}.input-field:focus{outline:none;border-color:var(--primary-color)}.btn{width:100%;padding:12px 16px;border-radius:4px;font-weight:600;font-size:.875rem;cursor:pointer;transition:background-color .2s;border:none;display:flex;align-items:center;justify-content:center;color:#fff}.btn-primary{background-color:var(--primary-color)}.btn-primary:hover{background-color:var(--primary-hover)}.btn-success{background-color:var(--success-color);padding:20px 16px;border-bottom:4px solid #14532d}.btn-success:hover{background-color:var(--success-hover)}.btn-success:active{border-bottom-width:0;transform:translateY(4px)}.btn-secondary{background-color:#374151}.btn-secondary:hover{background-color:#4b5563}.text-center{text-align:center}.mb-2{margin-bottom:8px}.mr-2{margin-right:8px}.ml-1{margin-left:4px}.mr-3{margin-right:12px}.gap-2{gap:8px}.gap-3{gap:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.space-y-6>*+*{margin-top:24px}.icon{width:20px;height:20px}.icon-lg{width:24px;height:24px}.icon-side{width:28px;height:28px}.w-4{width:1rem}.h-4{height:1rem}.w-5{width:1.25rem}.h-5{height:1.25rem}.w-6{width:1.5rem}.h-6{height:1.5rem}.status-panel{background-color:#1e293b80;padding:12px;border-radius:4px;border:1px solid #1e293b;text-align:center;margin-top:24px}.status-active{color:#22c55e;font-weight:700}.text-xs{font-size:.75rem}.text-xxs{font-size:10px}.footer{margin-top:40px;text-align:center;color:#475569;font-size:.75rem;padding-top:16px;border-top:1px solid rgba(51,65,85,.5)}.map-wrapper{position:relative;width:100%;height:100dvh;display:flex;flex-direction:column;background-color:var(--bg-card)}.map-container-leaflet{flex:1;width:100%;height:100%;z-index:1}.leaflet-tile{max-width:none!important;max-height:none!important}.map-controls{position:absolute;bottom:32px;left:16px;z-index:1000;display:flex;flex-direction:column;gap:16px}.map-btn-float{background-color:var(--bg-card);color:#fff;width:56px;height:56px;padding:0;border-radius:50%;border:1px solid #475569;cursor:pointer;box-shadow:0 4px 6px #0000004d;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.map-btn-float:hover{background-color:var(--bg-card-hover)}.wms-yellow-filter{filter:invert(100%)}.auth-header h3{margin:0;font-size:1.125rem;display:flex;align-items:center;color:#fff}.file-list-container{background-color:var(--bg-main);border-radius:4px;padding:12px;border:1px solid #334155;margin-top:16px}.file-list-ul{list-style:none;padding:0;margin:0}.file-list-item{color:#cbd5e1;font-size:.75rem;padding:4px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center}.camera-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000;z-index:9999;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none;overflow:hidden}.camera-video{width:100%;height:100%;object-fit:cover}.camera-click-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;cursor:crosshair}.focus-indicator{position:absolute;width:60px;height:60px;border:2px solid #fbbf24;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 10px #00000080;z-index:11;opacity:0}.focus-indicator.active{animation:focus-pulse 1s ease-out forwards}@keyframes focus-pulse{0%{transform:translate(-50%,-50%) scale(1.5);opacity:0}20%{transform:translate(-50%,-50%) scale(1);opacity:1}50%{opacity:1;border-color:#fff}80%{opacity:.5}to{transform:translate(-50%,-50%) scale(1);opacity:0}}.zoom-controls{position:absolute;top:50%;left:0;width:60vh;max-width:320px;transform:translate(calc(-50% + 40px),-50%) rotate(-90deg);display:flex;align-items:center;justify-content:center;gap:12px;z-index:25;pointer-events:auto}.zoom-slider{-webkit-appearance:none;width:100%;height:6px;background:#ffffff4d;border-radius:3px;outline:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 0 5px #00000080}.zoom-label{color:#fff;font-size:.875rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.8);min-width:30px;text-align:center;transform:rotate(90deg)}.camera-ui-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;z-index:20}.camera-top-bar{display:flex;justify-content:space-between;width:100%;pointer-events:none}.camera-top-bar>*{pointer-events:auto}.camera-bottom-dock{pointer-events:none;position:absolute;bottom:0;left:0;width:100%;padding:0 10px 40px;display:flex;flex-direction:row;align-items:center;justify-content:space-evenly;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);z-index:25}.camera-bottom-dock>*{pointer-events:auto}.camera-btn-side{width:64px;height:64px;border-radius:12px;background-color:#00000080;border:1px solid rgba(255,255,255,.3);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px;gap:2px;position:relative;overflow:hidden}.camera-btn-side:active{background-color:#fff3;transform:scale(.95)}.camera-btn-icon-wrapper{position:relative;width:100%;flex:1;display:flex;align-items:center;justify-content:center}.camera-btn-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;line-height:1.2;margin-bottom:2px;text-shadow:0 1px 2px rgba(0,0,0,.8)}.camera-btn-thumb{width:32px;height:32px;object-fit:cover;border-radius:6px;opacity:.9}.camera-btn-thumb-full{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.camera-btn-badge{position:absolute;top:-4px;right:6px;background-color:var(--primary-color);color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:1px solid var(--bg-main);z-index:10;box-shadow:0 2px 4px #0000004d}.gallery-badge{top:4px!important;right:4px!important;z-index:10}.shutter-button{width:80px;height:80px;border-radius:50%;background-color:#fff3;border:4px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s;flex-shrink:0}.shutter-button:active{transform:scale(.95);background-color:#fff6}.shutter-inner{width:60px;height:60px;border-radius:50%;background-color:#fff}@media (orientation: landscape){.camera-ui-overlay{flex-direction:row;justify-content:flex-end}.camera-top-bar{position:absolute;top:0;left:0;width:100%;z-index:21}.camera-bottom-dock{left:20px;bottom:20px;right:auto;width:auto;height:auto;flex-direction:column;gap:16px;background:none;padding:0;align-items:center;justify-content:flex-start}.shutter-button{position:fixed;right:30px;top:50%;transform:translateY(-50%);background-color:#ffffff1a}.zoom-controls{bottom:20px;right:130px;left:auto;top:auto;transform:none;width:220px;max-width:none}.zoom-label{transform:none}}.camera-flash{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#fff;opacity:0;pointer-events:none;transition:opacity .15s ease-out;z-index:30}.camera-flash.active{opacity:.8}.error-state{justify-content:center;align-items:center;color:#fff;padding:20px;text-align:center}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000d9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px}.modal-container{background-color:var(--bg-card);width:100%;max-width:1000px;height:90vh;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 10px 25px #00000080;overflow:hidden;border:1px solid var(--border-color)}.modal-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background-color:#1e293be6}.modal-header h2{margin:0;font-size:1.25rem;color:#fff;display:flex;align-items:center}.badge-count{background-color:var(--primary-color);font-size:.75rem;padding:2px 8px;border-radius:12px;margin-left:8px}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:50%}.modal-close-btn:hover{background-color:#ffffff1a;color:#fff}.modal-body{flex:1;overflow-y:auto;padding:16px}.gallery-section{margin-bottom:32px}.gallery-section-header{margin-bottom:12px;border-bottom:1px solid #334155;padding-bottom:4px;display:flex;justify-content:space-between;align-items:baseline}.gallery-section-header h3{margin:0;font-size:1rem;color:#e2e8f0}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}@media (min-width: 600px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}}.gallery-thumb-wrapper{aspect-ratio:1;background-color:#0f172a;border-radius:8px;overflow:hidden;position:relative;cursor:pointer;border:1px solid transparent}.gallery-thumb-wrapper:hover{border-color:var(--primary-color)}.gallery-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.gallery-thumb-wrapper:hover .gallery-thumb-img{transform:scale(1.05)}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.gallery-thumb-skeleton{width:100%;height:100%;background-color:#334155}.thumb-status-icon{position:absolute;bottom:4px;right:4px;background-color:#00000080;padding:2px;border-radius:4px}.detail-modal{max-width:900px;height:auto;max-height:95vh;flex-direction:row;background-color:transparent;border:none;box-shadow:none;position:relative}.detail-content{display:flex;flex-direction:column;width:100%;background-color:var(--bg-card);border-radius:12px;overflow:hidden;height:100%}@media (min-width: 768px){.detail-content{flex-direction:row}}.detail-image-wrapper{flex:2;background-color:#000;display:flex;align-items:center;justify-content:center;position:relative;min-height:300px}.detail-image{max-width:100%;max-height:100%;object-fit:contain}.detail-info{flex:1;padding:24px;overflow-y:auto;background-color:var(--bg-card);border-left:1px solid var(--border-color)}.detail-point-name{font-size:1.25rem;font-weight:700;margin:0 0 4px;color:#fff}.detail-date{color:var(--text-secondary);font-size:.875rem;margin-bottom:24px}.sigpac-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;background-color:#0f172a80;padding:12px;border-radius:8px;margin-bottom:24px}.sigpac-item{display:flex;flex-direction:column}.sigpac-item label{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase}.sigpac-item span{font-size:.9rem;color:#fff;font-weight:500}.geo-info{font-family:monospace;font-size:.75rem;color:var(--text-secondary);margin-bottom:24px}.status-badge{display:inline-block;padding:6px 12px;border-radius:4px;background-color:#334155;font-size:.875rem;color:#fff}.panel-container{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--bg-main);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:50;padding:16px}.panel-card{width:100%;max-width:600px;background-color:var(--bg-card);border-radius:16px;box-shadow:0 25px 50px -12px #00000080;overflow:hidden;border:1px solid var(--border-color);display:flex;flex-direction:column;max-height:85vh}.panel-header{padding:20px;background-color:#1e293bcc;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.panel-title{font-size:1.1rem;font-weight:700;color:#fff;margin:0}.badge{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:20px;display:inline-flex;align-items:center}.badge-warning{background-color:#eab30833;color:#facc15;border:1px solid rgba(234,179,8,.4)}.icon-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.icon-btn:hover{color:#fff}.panel-content{flex:1;overflow-y:auto;padding:20px;background-color:#0f172a}.empty-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);text-align:center}.point-item{background-color:var(--bg-card);border-radius:8px;padding:16px;margin-bottom:12px;border:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.point-info{display:flex;flex-direction:column}.point-id{font-weight:800;font-size:1rem;color:#fff;font-family:monospace;letter-spacing:-.02em}.point-meta{font-size:.75rem;color:#64748b;margin-top:2px;text-transform:uppercase}.point-actions{display:flex;align-items:center;gap:8px}.btn-pill{background-color:var(--primary-color);color:#fff;border:none;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;cursor:pointer;display:flex;align-items:center}.btn-pill:hover{background-color:var(--primary-hover)}.action-icon-btn{background:none;border:none;color:var(--text-secondary);padding:6px;cursor:pointer;border-radius:4px}.action-icon-btn:hover{color:#fff;background-color:#ffffff1a}.action-icon-btn.delete:hover{color:#f87171;background-color:#f871711a}.panel-notification{margin-top:16px;text-align:center;font-size:.8rem;padding:8px;border-radius:4px}.panel-notification.success{color:#22c55e;background-color:#22c55e1a}.panel-footer{padding:16px;background-color:var(--bg-card);border-top:1px solid var(--border-color);display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn-footer{padding:12px;border-radius:8px;font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.btn-footer.primary{background-color:#334155;color:#fff}.btn-footer.primary:hover{background-color:#475569}.btn-footer.secondary{background-color:transparent;border:1px solid #475569;color:#94a3b8}.btn-footer.secondary:hover{border-color:#fff;color:#fff}
