:root{--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-faint: #94a3b8;--primary: #4f46e5;--primary-light: #eef2ff;--urgent: #ef4444;--urgent-light: #fef2f2;--warning: #f59e0b;--warning-light: #fffbeb;--ok: #10b981;--ok-light: #f0fdf4;--radius: 14px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 14px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.04)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5}header{background:transparent}.header-inner{max-width:520px;margin:0 auto;padding:20px 20px 16px;display:flex;align-items:center;justify-content:center}.logo{display:flex;align-items:center;gap:8px}.logo h1{font-size:17px;font-weight:700;color:var(--text-muted);letter-spacing:-.01em;line-height:1}main{max-width:520px;margin:0 auto;padding:4px 16px 40px}.loading{color:var(--text-faint);font-size:13px;padding:24px 0;text-align:center}.bday-list{display:flex;flex-direction:column;gap:10px;padding-left:28px;padding-right:28px}.bday-card{background:var(--surface);border-radius:20px;box-shadow:0 2px 8px #0000000f,0 0 0 1px #0000000a;display:flex;align-items:center;overflow:visible;cursor:pointer;transition:box-shadow .15s,transform .12s;-webkit-tap-highlight-color:transparent}.bday-divider{display:flex;align-items:center;gap:10px;padding:6px 2px;color:var(--text-faint);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.bday-divider:before,.bday-divider:after{content:"";flex:1;height:1px;background:var(--border)}.bday-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.bday-card:active{transform:scale(.99)}.bday-avatar{width:52px;height:52px;border-radius:50%;color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:-26px;margin-right:14px;border:3px solid var(--bg);position:relative;z-index:1}.bday-info{flex:1;min-width:0;padding:16px 0;display:flex;flex-direction:column;gap:0}.bday-name{font-size:19px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.02em}.bday-date{font-size:11px;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.bday-actions{display:flex;flex-wrap:wrap;gap:5px;align-items:center;margin-top:7px}.bday-actions svg{width:16px;height:16px}.action-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-icon--card{background:#ede9fe;color:#5b21b6}.action-icon--call{background:#dcfce7;color:#15803d}.action-icon--gift{background:#fce7f3;color:#be185d}.bday-age{width:52px;height:52px;border-radius:50%;color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:8px;margin-right:-26px;border:3px solid var(--bg);position:relative;z-index:1;letter-spacing:-.02em}.bday-countdown{font-size:11px;font-weight:700;text-align:right;line-height:1.25;white-space:nowrap;flex-shrink:0}.bday-countdown.urgent{color:var(--urgent)}.bday-countdown.warning{color:var(--warning)}.bday-countdown.ok{color:var(--ok)}.urgency-badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap;align-self:flex-start}.urgency-badge.urgent{background:var(--urgent-light);color:var(--urgent)}.urgency-badge.warning{background:var(--warning-light);color:#b45309}.urgency-badge.ok{background:var(--ok-light);color:#065f46}.urgency-badge.far{background:var(--bg);color:var(--text-faint)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;transition:opacity .2s ease}.modal-overlay--open{opacity:1}.modal{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;box-shadow:0 -8px 40px #0000002e;width:100%;max-width:520px;max-height:88vh;display:flex;flex-direction:column;transform:translateY(20px);transition:transform .25s ease}.modal-overlay--open .modal{transform:translateY(0)}.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 0;flex-shrink:0}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-shrink:0}.modal-contact-info{display:flex;align-items:center;gap:12px}.modal-avatar{width:42px;height:42px;border-radius:50%;color:#fff;font-size:17px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-contact-name{font-size:16px;font-weight:700;color:var(--text)}.modal-contact-meta{font-size:12px;color:var(--text-muted);text-transform:capitalize;margin-top:1px}.modal-close{width:30px;height:30px;border:none;background:var(--bg);border-radius:50%;font-size:15px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .1s,color .1s}.modal-close:hover{background:var(--border);color:var(--text)}.modal-body{padding:18px 20px;overflow-y:auto;flex:1}.modal-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.modal-entries{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.modal-empty{font-size:13px;color:var(--text-faint);padding:6px 0}.modal-entry{border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px;background:var(--bg);display:flex;flex-direction:column;gap:9px}.modal-field-row{display:flex;gap:10px}.modal-field-row .modal-field{flex:1}.modal-field{display:flex;flex-direction:column;gap:4px}.modal-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.modal-label-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-faint)}.modal-input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);background:var(--surface);outline:none;font-family:inherit;transition:border-color .1s,box-shadow .1s}.modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.modal-entry-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.modal-status-select{padding:4px 10px;border-radius:99px;font-size:11px;font-weight:600;border:1px solid transparent;cursor:pointer;outline:none;font-family:inherit}.modal-status-select.status-not_ordered{background:var(--urgent-light);color:var(--urgent);border-color:#fecaca}.modal-status-select.status-ordered{background:var(--warning-light);color:#b45309;border-color:#fde68a}.modal-status-select.status-sent{background:var(--ok-light);color:#065f46;border-color:#a7f3d0}.btn-add-entry{width:100%;padding:10px;border:1.5px dashed var(--border);border-radius:var(--radius-sm);background:none;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:border-color .12s,color .12s,background .12s}.btn-add-entry:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.btn-remove-entry{font-size:11px;font-weight:600;color:var(--urgent);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;font-family:inherit;transition:background .1s}.btn-remove-entry:hover{background:var(--urgent-light)}.modal-entry-type{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:99px;width:fit-content}.modal-entry-type--card{background:#ede9fe;color:#5b21b6}.modal-entry-type--call{background:#dcfce7;color:#15803d}.modal-entry-type--gift{background:#fce7f3;color:#be185d}.modal-status-select.status-not_done{background:var(--urgent-light);color:var(--urgent);border-color:#fecaca}.modal-status-select.status-done,.modal-status-select.status-given{background:var(--ok-light);color:#065f46;border-color:#a7f3d0}.add-reminder-row{display:flex;gap:8px}.btn-add-reminder{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:9px 6px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;border:1.5px dashed;background:none;transition:background .12s,border-color .12s,color .12s}.btn-add-reminder--card{color:#5b21b6;border-color:#c4b5fd}.btn-add-reminder--call{color:#15803d;border-color:#86efac}.btn-add-reminder--gift{color:#be185d;border-color:#f9a8d4}.btn-add-reminder--card:hover{background:#ede9fe;border-style:solid}.btn-add-reminder--call:hover{background:#dcfce7;border-style:solid}.btn-add-reminder--gift:hover{background:#fce7f3;border-style:solid}@media (min-width: 521px){.modal-overlay{align-items:center;padding:16px}.modal{border-radius:var(--radius);max-height:85vh}.modal-handle{display:none}}
