:root{--bg:#f8f9fa;--bg-card:#fff;--bg-header:#1a1a2e;--text:#334;--text-muted:#6b7280;--text-inv:#fff;--border:#e2e8f0;--accent:#4f46e5;--accent-hover:#4338ca;--accent-light:#eef2ff;--danger:#dc2626;--danger-hover:#b91c1c;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow:0 4px 6px #00000012, 0 2px 4px #0000000f;--radius:8px;--radius-lg:12px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.6}@media (prefers-color-scheme:dark){:root{--bg:#0f1117;--bg-card:#1a1b26;--bg-header:#0d0e18;--text:#e2e8f0;--text-muted:#94a3b8;--border:#2d3748;--accent:#818cf8;--accent-hover:#6366f1;--accent-light:#1e1b4b;--shadow-sm:0 1px 3px #0006;--shadow:0 4px 6px #0000004d}}*{box-sizing:border-box}body{margin:0}a{color:var(--accent)}.loading,.empty{color:var(--text-muted);text-align:center;padding:2rem}.error{color:var(--danger)}p.error{text-align:center;padding:2rem}#login-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:100svh;display:flex}#login-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow);padding:2.5rem 2rem}#login-box h1{text-align:center;color:var(--text);margin:0 0 1.5rem;font-size:1.5rem;font-weight:700}.field{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.field label{color:var(--text-muted);font-size:.85rem;font-weight:600}.field input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);outline:none;padding:.55rem .75rem;font-size:.95rem;transition:border-color .2s}.field input:focus{border-color:var(--accent)}#login-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:.5rem;padding:.65rem;font-size:1rem;font-weight:600;transition:background .2s}#login-btn:hover:not(:disabled){background:var(--accent-hover)}#login-btn:disabled{opacity:.6;cursor:default}#login-error{color:var(--danger);text-align:center;margin:.5rem 0 0;font-size:.875rem}#app{flex-direction:column;min-height:100svh;display:flex}#site-header{background:var(--bg-header);color:var(--text-inv);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.site-title{letter-spacing:.02em;font-size:1.1rem;font-weight:700}#logout-btn{color:var(--text-inv);border-radius:var(--radius);cursor:pointer;background:0 0;border:1px solid #fff6;padding:.35rem .85rem;font-size:.85rem;transition:background .2s}#logout-btn:hover{background:#ffffff26}#main-content{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:1.5rem}.upload-area{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:var(--bg-card);margin-bottom:2rem;padding:2.5rem 1.5rem;transition:border-color .2s,background .2s}.upload-area:hover,.upload-area.drag-over{border-color:var(--accent);background:var(--accent-light)}.upload-hint{color:var(--text);margin:0 0 .25rem;font-size:1.05rem;font-weight:600}.upload-sub{color:var(--text-muted);margin:0 0 1rem;font-size:.85rem}.progress-bar{background:var(--border);border-radius:99px;max-width:360px;height:6px;margin:.5rem auto 0;overflow:hidden}.progress-fill{background:var(--accent);border-radius:99px;width:0;height:100%;transition:width .3s}#progress-text{color:var(--text-muted);margin:.4rem 0 0;font-size:.85rem}.gallery{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;display:grid}.gallery-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.gallery-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.thumb-wrap{aspect-ratio:4/3;background:var(--bg);overflow:hidden}.thumb{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.gallery-card:hover .thumb{transform:scale(1.04)}.card-info{flex:1;padding:.75rem .9rem .4rem}.card-name{white-space:nowrap;text-overflow:ellipsis;margin:0 0 .2rem;font-size:.875rem;font-weight:600;overflow:hidden}.card-date{color:var(--text-muted);margin:0 0 .2rem;font-size:.8rem}.card-gps{color:var(--text-muted);margin:0;font-size:.75rem}.card-actions{border-top:1px solid var(--border);gap:.5rem;padding:.6rem .9rem;display:flex}.btn-detail{text-align:center;background:var(--accent);color:#fff;border-radius:var(--radius);flex:1;padding:.35rem .5rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .2s}.btn-detail:hover{background:var(--accent-hover)}.btn-delete{border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.35rem .6rem;font-size:.82rem;font-weight:600;transition:background .2s,color .2s}.btn-delete:hover{background:var(--danger);color:#fff}.page-detail{max-width:1200px;margin:0 auto}.breadcrumb{margin-bottom:1.25rem}.breadcrumb a{color:var(--accent);font-size:.9rem;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.detail-grid{grid-template-columns:1fr 1fr;align-items:start;gap:2rem;display:grid}@media (width<=900px){.detail-grid{grid-template-columns:1fr}}.detail-left{flex-direction:column;gap:1rem;display:flex}.detail-image-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow);overflow:hidden}.original-dl{background:var(--bg);border-top:1px solid var(--border);text-align:center;margin:0;padding:.5rem .75rem;font-size:.82rem}.detail-image{object-fit:contain;width:100%;max-height:60vh;display:block}.map-container{border-radius:var(--radius-lg);border:1px solid var(--border);height:320px;box-shadow:var(--shadow-sm);overflow:hidden}@media (width<=600px){#main-content{padding:.9rem}.breadcrumb{margin-bottom:.75rem}.detail-grid{gap:.9rem}.detail-left{gap:.7rem}.detail-image{max-height:21vh}.map-container{height:165px}.detail-meta{gap:.7rem}.detail-uploaded{margin-top:-.25rem}.shot-at-badge{padding:.4rem .75rem;font-size:.9rem}}.detail-meta{flex-direction:column;gap:1rem;display:flex}.detail-filename{word-break:break-all;margin:0;font-size:1.1rem;font-weight:700}.detail-uploaded{color:var(--text-muted);margin:-.5rem 0 0;font-size:.85rem}.shot-at-badge{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);padding:.5rem 1rem;font-size:.95rem;font-weight:700;display:inline-block}.shot-at-utc{color:var(--text-muted);margin-top:.2rem;font-size:.88em;font-weight:500;display:inline-block}.no-gps{color:var(--text-muted);font-size:.9rem}.gps-info{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem}.gps-table{border-collapse:collapse;width:100%;font-size:.875rem}.gps-table th{text-align:left;width:8rem;color:var(--text-muted);padding:.25rem .4rem .25rem 0;font-weight:500}.gps-table td{font-variant-numeric:tabular-nums;padding:.25rem 0}.gps-actions{margin-top:.6rem}.gps-go-btn{border:1px solid var(--accent);background:var(--accent-light);color:var(--accent);cursor:pointer;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.82rem;font-weight:700;display:inline-flex}.gps-go-btn:hover{background:var(--accent);color:#fff}.gps-go-icon{font-size:.75rem}.coord-label{letter-spacing:.03em;border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:700;display:inline-block}.wgs84-label{color:#1d4ed8;background:#dbeafe}.gcj02-label{color:#15803d;background:#dcfce7}@media (prefers-color-scheme:dark){.wgs84-label{color:#93c5fd;background:#1e3a5f}.gcj02-label{color:#86efac;background:#14532d}}.gps-ref-note{color:var(--text-muted);font-size:.82em}.exif-primary,.exif-details{margin-top:.25rem}.exif-details summary{cursor:pointer;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;padding:.5rem .6rem;font-size:.85rem;font-weight:600;list-style:none;display:flex}.exif-details summary:before{content:"▶";font-size:.7rem;transition:transform .2s}.exif-details[open] summary:before{transform:rotate(90deg)}.exif-details summary::-webkit-details-marker{display:none}.exif-table{border-collapse:collapse;width:100%;margin-top:.5rem;font-size:.82rem}.exif-table th{text-align:left;background:var(--bg);border-bottom:2px solid var(--border);color:var(--text-muted);padding:.4rem .6rem;font-weight:600}.exif-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:.35rem .6rem}.exif-key{color:var(--text-muted);white-space:nowrap;width:45%;font-weight:500}.exif-val{word-break:break-all}.exif-table tr:hover td{background:var(--accent-light)}@media print{#site-header,.breadcrumb,.btn-delete,.btn-detail{display:none!important}#main-content{max-width:100%;padding:0}.detail-grid{grid-template-columns:1fr 1fr;gap:1rem}.detail-image{max-height:40vh}.map-container{height:260px}.exif-details{display:block}.exif-details summary{display:none}*{box-shadow:none!important}}
