*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{color:#0f172a;background:radial-gradient(circle at top,#dbeafe 0%,#eff6ff 35%,#f8fafc 100%);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}button,input,textarea{font:inherit}.family-app{max-width:1080px;margin:28px auto;padding:16px}.family-shell{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#ffffffeb;border:1px solid #bfdbfe;border-radius:14px;overflow:hidden;box-shadow:0 16px 38px #1e40af1f}.family-header{color:#eff6ff;background:linear-gradient(120deg,#1d4ed8,#2563eb);border-bottom:1px solid #dbeafe;justify-content:space-between;align-items:center;gap:14px;padding:20px 22px;display:flex}.family-header h1{margin:0;font-size:1.4rem}.family-header p{color:#bfdbfe;margin:.35rem 0 0;font-size:.9rem}.header-actions{align-items:center;gap:10px;display:flex}.user-chip{border:1px solid #ffffff59;border-radius:999px;padding:6px 10px;font-size:.85rem}.portal-btn,.submit-btn,.cancel-btn,.edit-btn,.delete-btn,.login-link{cursor:pointer;border:0;border-radius:10px;justify-content:center;align-items:center;padding:9px 12px;font-weight:600;text-decoration:none;display:inline-flex}.portal-btn,.submit-btn,.login-link{color:#fff;background:#0f172a}.portal-btn:hover,.submit-btn:hover,.login-link:hover{background:#020617}.family-content{display:block}.form-grid{gap:10px;display:grid}.form-grid label{color:#334155;gap:4px;font-size:.88rem;font-weight:600;display:grid}.form-grid input,.form-grid select,.form-grid textarea{background:#fff;border:1px solid #cbd5e1;border-radius:9px;padding:9px 10px}.form-grid textarea{resize:vertical;min-height:80px}.form-actions{gap:8px;display:flex}.submit-btn,.cancel-btn{flex:1}.cancel-btn{color:#0f172a;background:#e2e8f0}.events-panel{padding:20px}.top-actions{margin-bottom:12px}.events-panel h2{margin:0 0 14px}.view-switch{background:#f8fafc;border:1px solid #cbd5e1;border-radius:12px;gap:6px;margin-bottom:12px;padding:4px;display:inline-flex}.view-btn{cursor:pointer;color:#334155;background:0 0;border:0;border-radius:8px;padding:7px 12px;font-weight:600}.view-btn.active{color:#fff;background:#2563eb}.view-btn:hover{background:#e2e8f0}.view-btn.active:hover{background:#1d4ed8}.month-nav{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.month-nav h2{text-transform:capitalize;margin:0}.month-nav-actions{gap:8px;display:flex}.nav-btn{color:#0f172a;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:10px;padding:8px 10px;font-weight:600}.nav-btn:hover{background:#eef2ff;border-color:#93c5fd}.error-box{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;margin-bottom:12px;padding:10px 12px}.empty-state{color:#64748b}.month-day-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.month-day-item{border:1px solid #cbd5e1;border-radius:10px;padding:10px}.month-day-item.weekday{background:#fff}.month-day-item.weekend,.month-day-item.holiday{background:#fef3c7;border-color:#fcd34d}.month-day-item.today{background:#eff6ff;border-width:2px;border-color:#2563eb}.month-day-item.today .month-day-header{color:#2563eb}.month-day-header{color:#1e293b;text-transform:capitalize;font-size:.92rem;font-weight:700}.month-day-header-row,.day-head-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.month-day-empty{color:#64748b;margin:0;font-size:.88rem}.holiday-label{color:#92400e;margin:0 0 8px;font-size:.78rem;font-weight:700}.month-day-events{gap:8px;margin:0;padding:0;list-style:none;display:grid}.month-table-wrap{overflow-x:auto}.month-table{border-collapse:collapse;table-layout:fixed;width:100%}.month-table th,.month-table td{vertical-align:top;border:1px solid #dbeafe}.month-table th{color:#1e3a8a;text-align:left;background:#eff6ff;padding:8px;font-size:.82rem;font-weight:700}.month-table td{background:#fff;min-height:120px}.month-table td.out-month{background:#f8fafc}.month-table td.holiday{background:#fef3c7}.month-table td.today{outline-offset:-2px;background:#eff6ff;outline:2px solid #2563eb}.month-table td.today .day-number{color:#2563eb;font-size:1rem}.day-cell{flex-direction:column;gap:6px;min-height:120px;padding:8px;display:flex}.day-number{color:#334155;font-size:.85rem;font-weight:700}.add-day-btn{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #93c5fd;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;line-height:1;display:inline-flex}.add-day-btn:hover{background:#dbeafe}.no-events{color:#94a3b8;font-size:.78rem}.day-events{gap:5px;margin:0;padding:0;list-style:none;display:grid}.day-event{border-radius:8px;gap:2px;padding:4px 6px;font-size:.76rem;display:grid}.day-event.family{color:#1e3a8a;background:#dbeafe}.day-event.photo{color:#92400e;background:#fef3c7}.day-event-time{font-weight:700}.day-event-title{line-height:1.2}.event-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.event-item{background:#fff;border:1px solid #cbd5e1;border-radius:10px;padding:12px}.event-item.photo{background:#fffbeb;border-left:4px solid #f59e0b}.event-item.family{border-left:4px solid #2563eb}.event-title-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.event-title{margin:0;font-size:1rem}.event-badges{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:6px;display:flex}.source-badge,.creator-badge{white-space:nowrap;border-radius:999px;padding:3px 8px;font-size:.74rem}.source-badge{color:#1e40af;background:#dbeafe}.creator-badge{color:#475569;background:#f1f5f9;border:1px solid #cbd5e1}.source-badge.photo{color:#92400e;background:#fde68a}.event-meta{color:#334155;gap:5px;margin-top:8px;font-size:.9rem;display:grid}.event-actions{gap:8px;margin-top:10px;display:flex}.edit-btn{color:#1e3a8a;background:#dbeafe}.delete-btn{color:#991b1b;background:#fee2e2}.loading,.login-shell{background:#fff;border:1px solid #bfdbfe;border-radius:12px;max-width:560px;margin:84px auto;padding:20px;box-shadow:0 8px 24px #1e40af17}.modal-backdrop{z-index:40;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #cbd5e1;border-radius:12px;width:min(560px,100%);max-height:calc(100vh - 40px);padding:18px;overflow:auto;box-shadow:0 20px 45px #0f172a59}.modal-card h2{margin:0 0 12px;font-size:1.12rem}@media (width<=920px){.header-actions{flex-wrap:wrap;justify-content:flex-end}.month-nav{flex-direction:column;align-items:flex-start}.view-switch{box-sizing:border-box;justify-content:space-between;width:100%}.view-btn{text-align:center;flex:1}.month-table{min-width:760px}}
