*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fafafa;color:#1a1a1a;min-height:100dvh}.container{max-width:480px;margin:0 auto;padding:24px 16px}h1{font-size:24px;font-weight:700;margin-bottom:8px}h2{font-size:18px;font-weight:600;margin-bottom:16px}.subtitle{font-size:14px;color:#666;margin-bottom:32px}button{width:100%;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s}button:active{opacity:.8}button.primary{background:#2563eb;color:#fff}button.primary:disabled{background:#93c5fd;cursor:not-allowed}button.secondary{background:#f3f4f6;color:#374151}input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:16px;outline:none;transition:border-color .2s}input:focus{border-color:#2563eb}label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-group{margin-bottom:16px}.helper-text{color:#6b7280;font-size:14px;line-height:1.5;margin-bottom:16px}.card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 3px #00000014;margin-bottom:16px}.timeline-header{position:sticky;top:0;z-index:5;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 0 10px;margin-bottom:8px;background:#fafafa}.timeline-name{position:relative;overflow:hidden;border-radius:10px;background:#fff;padding:10px 8px 8px;text-align:center;font-size:14px;font-weight:600;color:#374151;box-shadow:0 1px 3px #00000014}.timeline-name:before,.timeline-cell:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.timeline-name.first:before,.timeline-cell.first-child:before{background:#5b9bd5}.timeline-name.second:before,.timeline-cell.second-child:before{background:#f2a7b3}.timeline-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.timeline-row{display:contents}.timeline-cell{position:relative;border-radius:12px;overflow:hidden;background:#f3f4f6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.timeline-cell img{width:100%;aspect-ratio:1;object-fit:cover;cursor:pointer}.timeline-cell.empty{border:2px dashed #d1d5db;color:#9ca3af;font-size:12px;text-align:center;padding:8px}.timeline-cell.matched{box-shadow:0 0 0 3px #2563eb33}.age-label{grid-column:1 / -1;font-size:12px;font-weight:600;color:#6b7280;padding:12px 0 4px}.drop-zone{border:2px dashed #d1d5db;border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone.active{border-color:#2563eb;background:#eff6ff}.drop-zone p{color:#6b7280;font-size:14px}.match-card{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.match-card-content{background:#fff;border-radius:20px;padding:24px;max-width:360px;width:100%;text-align:center}.match-card-content h3{font-size:16px;margin-bottom:16px;color:#1a1a1a}.match-photos{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.match-photos img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px}.photo-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease}.photo-viewer-content{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:60px 16px 80px}.photo-viewer-content img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.photo-viewer-loading{color:#ffffffb3;font-size:14px}.photo-viewer-close{position:absolute;top:max(16px,env(safe-area-inset-top));right:16px;width:40px;height:40px;border-radius:50%;background:#ffffff26;color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;padding:0}.photo-viewer-delete{position:absolute;bottom:max(32px,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);width:auto;padding:12px 32px;border-radius:12px;background:#ef4444e6;color:#fff;font-size:14px;font-weight:600;border:none;cursor:pointer}.photo-viewer-confirm{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:24px}.photo-viewer-confirm-card{background:#fff;border-radius:16px;padding:24px;max-width:300px;width:100%;text-align:center}.photo-viewer-confirm-card p{font-size:15px;color:#374151;margin-bottom:20px;line-height:1.5}.photo-viewer-error{color:#ef4444;font-size:13px;margin-bottom:16px}.photo-viewer-confirm-actions{display:flex;gap:8px}.photo-viewer-confirm-actions button{flex:1}.photo-viewer-confirm-delete{background:#ef4444;color:#fff}.photo-viewer-confirm-delete:disabled{background:#fca5a5;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.nav-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;padding:12px 0;padding-bottom:max(12px,env(safe-area-inset-bottom));z-index:10}.nav-bar a{text-decoration:none;color:#6b7280;font-size:12px;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:4px}.nav-bar a.active{color:#2563eb}
