@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-color:#0b0c10;--surface-color:#ffffff0d;--surface-border:#ffffff1a;--text-primary:#e0e6ed;--text-secondary:#94a3b8;--day-color:#10b981;--day-bg:#10b98126;--day-border:#10b98166;--night-color:#ef4444;--night-bg:#ef444426;--night-border:#ef444466;--off-color:#94a3b8;--off-bg:#ffffff08;--off-border:#ffffff14;--primary-accent:#3b82f6}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);background-image:radial-gradient(circle at 15%,#10b9810d,#0000 25%),radial-gradient(circle at 85% 30%,#ef44440d,#0000 25%);flex-direction:column;min-height:100vh;font-family:Outfit,system-ui,Avenir,Helvetica,Arial,sans-serif;display:flex;overflow-x:hidden}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:600}button{cursor:pointer;border:none;outline:none;font-family:Outfit,sans-serif}.glass-panel{background:var(--surface-color);-webkit-backdrop-filter:blur(16px);border:1px solid var(--surface-border);border-radius:16px;box-shadow:0 4px 30px #0000001a}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--surface-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:3rem}.header h1{background:linear-gradient(135deg,#e0e6ed,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:700}.header p{color:var(--text-secondary);font-size:1.1rem}.legend{justify-content:center;gap:2rem;margin-top:1.5rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.legend-color{border-radius:50%;width:12px;height:12px}.legend-color.day{background:var(--day-color);box-shadow:0 0 10px #10b98180}.legend-color.night{background:var(--night-color);box-shadow:0 0 10px #ef444480}.legend-color.off{background:var(--off-color)}.year-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}@media (width<=768px){.app-container{padding:1rem}.header h1{font-size:2rem}.year-grid{grid-template-columns:1fr}}.month-container{padding:1.5rem;transition:transform .3s,box-shadow .3s}.month-container:hover{transform:translateY(-5px);box-shadow:0 10px 40px #0003}.month-header{text-align:center;color:var(--text-primary);text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.weekdays{text-align:center;color:var(--text-secondary);grid-template-columns:repeat(7,1fr);margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:grid}.days-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.day-cell{aspect-ratio:1;cursor:pointer;border:1px solid #0000;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;font-size:.9rem;font-weight:500;transition:all .2s;display:flex;position:relative}.day-cell.empty{visibility:hidden}.day-cell.day{background:var(--day-bg);color:var(--day-color);border-color:var(--day-border)}.day-cell.day:hover{background:#10b98140;box-shadow:0 0 15px #10b9814d}.day-cell.night{background:var(--night-bg);color:var(--night-color);border-color:var(--night-border)}.day-cell.night:hover{background:#ef444440;box-shadow:0 0 15px #ef44444d}.day-cell.off{background:var(--off-bg);color:var(--text-primary);border-color:var(--off-border)}.day-cell.selected{outline:3px solid var(--primary-accent);outline-offset:-2px;z-index:10;transform:scale(.95);box-shadow:0 0 15px #3b82f680}.day-cell.off:hover{background:#ffffff14;border-color:#fff3}.event-indicator{background-color:var(--primary-accent);width:4px;height:4px;box-shadow:0 0 5px var(--primary-accent);border-radius:50%;position:absolute;bottom:4px}.day-cell:active{transform:scale(.95)}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{border:1px solid var(--surface-border);background:#1e293b;border-radius:16px;width:90%;max-width:400px;padding:2rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) slideUp;box-shadow:0 20px 50px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-header h3{color:var(--text-primary);font-size:1.5rem}.close-btn{color:var(--text-secondary);background:0 0;font-size:1.5rem;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-primary)}.event-list{max-height:200px;margin-bottom:1.5rem;overflow-y:auto}.event-item{background:#ffffff0d;border:1px solid #ffffff0d;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem 1rem;display:flex}.event-info{flex-direction:column;display:flex}.event-title{color:var(--text-primary);font-weight:500}.event-time{color:var(--text-secondary);font-size:.8rem}.delete-btn{color:#ef4444;background:#ef44441a;border-radius:4px;padding:.25rem .5rem;font-size:.8rem;transition:all .2s}.delete-btn:hover{background:#ef444433}.add-event-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.9rem}.form-group input{border:1px solid var(--surface-border);color:var(--text-primary);background:#0003;border-radius:8px;outline:none;padding:.75rem;font-family:Inter,sans-serif;transition:border-color .2s}.form-group input:focus{border-color:var(--primary-accent)}.add-btn{background:var(--primary-accent);color:#fff;border-radius:8px;margin-top:.5rem;padding:.75rem;font-weight:600;transition:background .2s}.add-btn:hover{background:#2563eb}.not-allowed{text-align:center;color:var(--text-secondary);padding:2rem 0}.schedule-management{border-bottom:1px solid var(--surface-border);margin-bottom:1.5rem;padding-bottom:1.5rem}.schedule-management h3,.events-section h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:0;margin-bottom:.75rem;font-size:.85rem}.override-actions{gap:.5rem;margin-bottom:.5rem;display:flex}.override-btn{color:#fff;border-radius:8px;flex:1;padding:.5rem;font-size:.8rem;font-weight:600;transition:transform .1s,filter .2s}.override-btn:active{transform:scale(.95)}.override-btn:hover{filter:brightness(1.2)}.override-btn.day{background:var(--day-color)}.override-btn.night{background:var(--night-color)}.override-btn.off{background:var(--off-color);border:1px solid var(--off-border)}.reset-btn{width:100%;color:var(--text-secondary);border:1px dashed var(--surface-border);background:#ffffff0d;border-radius:8px;padding:.5rem;font-size:.85rem;transition:all .2s}.reset-btn:hover{color:var(--text-primary);background:#ffffff1a}.shift-badge{text-transform:uppercase;color:#fff;border-radius:999px;margin-top:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-block}.shift-badge.day{background:var(--day-color)}.shift-badge.night{background:var(--night-color)}.shift-badge.off{background:var(--off-color);border:1px solid var(--off-border)}.shift-warning{color:var(--text-secondary);text-align:center;border:1px dashed var(--surface-border);background:#ffffff0d;border-radius:8px;padding:1rem;font-size:.9rem}.share-modal-content{border:1px solid var(--surface-border);background:#1e293b;border-radius:16px;width:90%;max-width:400px;padding:2rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) slideUp;box-shadow:0 20px 50px #00000080}.share-form{flex-direction:column;gap:1rem;display:flex}.share-input{border:1px solid var(--surface-border);color:var(--text-primary);background:#0003;border-radius:8px;outline:none;padding:.75rem;font-family:Inter,sans-serif;transition:border-color .2s}.share-input:focus{border-color:var(--primary-accent)}.share-list{flex-direction:column;gap:.5rem;margin-top:1.5rem;display:flex}.share-item{background:#ffffff0d;border-radius:8px;justify-content:space-between;align-items:center;padding:.5rem 1rem;font-size:.9rem;display:flex}.auth-container{background-color:var(--bg-color);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-panel{-webkit-backdrop-filter:blur(12px);border:1px solid var(--surface-border);text-align:center;background:#1e293bb3;border-radius:16px;width:100%;max-width:400px;padding:3rem 2rem;box-shadow:0 25px 50px -12px #00000080}.auth-panel h2{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem}.auth-panel p{color:var(--text-secondary);margin-bottom:2rem}.auth-form{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.auth-input{color:#fff;background:#0003;border:1px solid #ffffff1a;border-radius:8px;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.auth-input:focus{border-color:var(--primary-accent);outline:none}.auth-btn{background:var(--primary-accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:.75rem;font-size:1rem;font-weight:600;transition:all .2s}.auth-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-2px)}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.divider{text-align:center;color:var(--text-secondary);align-items:center;margin:1.5rem 0;font-size:.875rem;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid #ffffff1a;flex:1}.divider:not(:empty):before{margin-right:1rem}.divider:not(:empty):after{margin-left:1rem}.google-btn{color:#333;background:#fff;justify-content:center;align-items:center;gap:.5rem;display:flex}.google-btn:hover:not(:disabled){background:#f8f9fa;transform:translateY(-2px)}.google-icon{width:20px;height:20px}.auth-error{color:#ef4444;background:#ef44441a;border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.auth-message{color:#10b981;background:#10b9811a;border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.family-hub-container{color:var(--text-primary);max-width:1000px;margin:0 auto;padding:20px;font-family:Outfit,sans-serif}.family-hub-header{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.family-hub-header h1{margin:0;font-size:28px;font-weight:600}.family-shift-status{color:#10b981;background-color:#10b9811a;border:1px solid #10b9814d;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:500;display:flex}.family-shift-status:before{content:"";background-color:#10b981;border-radius:50%;width:8px;height:8px;display:block;box-shadow:0 0 10px #10b981}.family-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}@media (width<=768px){.family-grid{grid-template-columns:1fr}}.family-card{border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#1e293b99;border-radius:16px;margin-bottom:24px;padding:24px}.family-card-title{color:#fff;align-items:center;gap:10px;margin-bottom:15px;font-size:18px;font-weight:600;display:flex}.task-item{cursor:pointer;background-color:#0003;border:1px solid #ffffff0d;border-radius:8px;align-items:center;margin-bottom:10px;padding:12px;transition:all .2s;display:flex}.task-item:hover{background-color:#ffffff0d}.task-checkbox{border:2px solid var(--primary-accent);border-radius:6px;justify-content:center;align-items:center;width:20px;height:20px;margin-right:15px;transition:all .2s;display:flex}.task-checkbox.checked{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);border:none}.task-checkbox.checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.task-text{flex:1;font-size:15px;transition:all .2s}.task-text.checked{color:var(--text-secondary);text-decoration:line-through}.task-tag{color:var(--text-secondary);background-color:#ffffff1a;border-radius:6px;padding:4px 8px;font-size:11px}.timeline-item{margin-bottom:20px;padding-left:24px;position:relative}.timeline-item:before{content:"";background-color:var(--primary-accent);width:10px;height:10px;box-shadow:0 0 10px var(--primary-accent);border-radius:50%;position:absolute;top:6px;left:0}.timeline-item:after{content:"";background-color:#ffffff1a;width:2px;position:absolute;top:20px;bottom:-20px;left:4px}.timeline-item:last-child:after{display:none}.timeline-time{color:var(--primary-accent);margin-bottom:4px;font-size:12px;font-weight:600}.timeline-event{color:#fff;font-size:15px}.widget-box{background:linear-gradient(135deg,#f59e0b1a 0%,#f59e0b05 100%);border:1px solid #f59e0b33;border-radius:12px;padding:20px}.widget-title{color:#f59e0b;margin-bottom:8px;font-size:14px;font-weight:600}
