:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: #151c30;--bg-card-hover: #1c2440;--bg-surface: #1a2138;--gold-primary: #c9a84c;--gold-light: #f0d060;--gold-dark: #8a6d2e;--gold-glow: rgba(201, 168, 76, .3);--gold-glow-strong: rgba(201, 168, 76, .6);--text-primary: #e8e0d0;--text-secondary: #8b95a8;--text-gold: #d4a843;--text-dim: #5a6478;--border-gold: rgba(201, 168, 76, .25);--border-subtle: rgba(255, 255, 255, .06);--success: #4ade80;--success-bg: rgba(74, 222, 128, .1);--warning: #fbbf24;--warning-bg: rgba(251, 191, 36, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--info: #60a5fa;--radius: 8px;--radius-lg: 12px;--font-display: "Cinzel", serif;--font-body: "Noto Sans KR", sans-serif}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}.particles-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.app{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0a0e1ad9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-gold);position:sticky;top:0;z-index:100}.header-left,.header-right{display:flex;gap:8px;min-width:100px}.header-right{justify-content:flex-end}.header-center{text-align:center}.app-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--gold-primary);text-shadow:0 0 20px var(--gold-glow);letter-spacing:2px;display:flex;align-items:center;gap:8px}.title-icon{font-size:1.4rem}.app-content{flex:1;max-width:960px;margin:0 auto;padding:24px 16px;width:100%}.app-footer{text-align:center;padding:20px;color:var(--text-dim);font-size:.8rem;border-top:1px solid var(--border-subtle)}.firebase-warning{background:var(--warning-bg);border:1px solid rgba(251,191,36,.3);color:var(--warning);padding:12px 24px;text-align:center;font-size:.85rem}.firebase-warning code{background:#0000004d;padding:2px 6px;border-radius:4px;font-size:.8rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px}.loading-emblem{font-size:3rem;animation:pulse-glow 2s ease-in-out infinite}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-gold);border-top-color:var(--gold-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-text{color:var(--text-gold);font-family:var(--font-display);font-size:.95rem;letter-spacing:1px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{text-shadow:0 0 10px var(--gold-glow)}50%{text-shadow:0 0 30px var(--gold-glow-strong),0 0 60px var(--gold-glow)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-gold{background:linear-gradient(135deg,var(--gold-dark),var(--gold-primary));color:#0a0e1a;font-weight:600;box-shadow:0 2px 12px var(--gold-glow)}.btn-gold:hover{background:linear-gradient(135deg,var(--gold-primary),var(--gold-light));box-shadow:0 4px 20px var(--gold-glow-strong);transform:translateY(-1px)}.btn-gold.btn-saved{background:linear-gradient(135deg,#2d6a30,#4ade80);color:#fff;box-shadow:0 2px 12px #4ade804d}.btn-large{padding:14px 28px;font-size:1rem}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-gold)}.btn-outline:hover{background:#c9a84c1a;border-color:var(--gold-primary)}.btn-danger{background:linear-gradient(135deg,#7f1d1d,var(--danger));color:#fff}.btn-danger:hover{background:linear-gradient(135deg,var(--danger),#f87171)}.btn-danger-outline{border-color:#ef44444d;color:var(--danger)}.btn-danger-outline:hover{background:var(--danger-bg)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 12px;border:none;font-size:1.1rem}.btn-ghost:hover{color:var(--gold-primary);background:#c9a84c14}.btn-icon{padding:6px 10px;font-size:.85rem}.btn-mode{padding:10px 20px;font-weight:600;border:2px solid}.mode-available{background:#4ade801a;color:var(--success);border-color:#4ade804d}.mode-unavailable{background:var(--danger-bg);color:var(--danger);border-color:#ef44444d}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.member-select{display:flex;flex-direction:column;gap:28px}.select-title-area{text-align:center}.select-title{font-family:var(--font-display);font-size:1.6rem;color:var(--gold-primary);text-shadow:0 0 15px var(--gold-glow);margin-bottom:8px}.select-subtitle{color:var(--text-secondary);font-size:.9rem}.submit-status{margin-top:12px;display:inline-flex;align-items:baseline;gap:2px;padding:6px 16px;background:#c9a84c14;border-radius:20px;border:1px solid var(--border-gold)}.submit-count{font-family:var(--font-display);font-size:1.3rem;color:var(--gold-primary);font-weight:700}.submit-total{color:var(--text-secondary);font-size:.85rem}.member-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.member-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease;overflow:hidden}.member-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(201,168,76,.03) 0%,transparent 70%);pointer-events:none}.member-card:hover,.member-card.hovered{background:var(--bg-card-hover);border-color:var(--gold-primary);box-shadow:0 0 25px var(--gold-glow),inset 0 0 25px #c9a84c0d;transform:translateY(-3px)}.member-card.submitted{border-color:#4ade8066}.member-card.submitted:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--success),transparent)}.card-corner{position:absolute;width:14px;height:14px;border-color:var(--gold-dark);border-style:solid;opacity:.6;transition:opacity .3s}.member-card:hover .card-corner{opacity:1;border-color:var(--gold-primary)}.card-corner.top-left{top:4px;left:4px;border-width:2px 0 0 2px}.card-corner.top-right{top:4px;right:4px;border-width:2px 2px 0 0}.card-corner.bottom-left{bottom:4px;left:4px;border-width:0 0 2px 2px}.card-corner.bottom-right{bottom:4px;right:4px;border-width:0 2px 2px 0}.submitted-badge{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:var(--success);color:#0a0e1a;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.member-icon{font-size:2rem;margin-bottom:4px}.member-name{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.member-class{font-size:.8rem;color:var(--text-gold);letter-spacing:1px}.select-actions{display:flex;justify-content:center}.time-input{display:flex;flex-direction:column;gap:20px}.input-header{text-align:center}.input-title{font-family:var(--font-display);font-size:1.3rem;color:var(--gold-primary);margin-bottom:6px}.input-subtitle{color:var(--text-secondary);font-size:.85rem}.input-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.time-grid-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border-gold);border-radius:var(--radius-lg);background:var(--bg-card)}.time-grid{width:100%;border-collapse:collapse;user-select:none;-webkit-user-select:none}.time-grid th,.time-grid td{text-align:center;padding:0}.time-header-corner{width:60px;min-width:60px;background:var(--bg-surface)}.day-header{padding:12px 8px;font-weight:600;color:var(--text-gold);background:var(--bg-surface);border-bottom:1px solid var(--border-gold);cursor:pointer;transition:background .2s;font-size:.95rem}.day-header:hover{background:#c9a84c1a}.hour-label{padding:2px 8px 0;font-size:.8rem;color:var(--text-secondary);background:var(--bg-surface);border-right:1px solid var(--border-subtle);font-weight:500;vertical-align:top;line-height:1;white-space:nowrap}.time-cell{width:14.28%;min-width:48px;height:48px;border:1px solid var(--border-subtle);cursor:pointer;transition:background .15s;font-size:.85rem;font-weight:600;position:relative}.time-cell:hover{background:#c9a84c1f}.time-cell.cell-available{background:#4ade8033;color:var(--success);border-color:#4ade8033}.time-cell.cell-available:hover{background:#4ade804d}.time-cell.cell-unavailable{background:#ef444433;color:var(--danger);border-color:#ef444433}.time-cell.cell-unavailable:hover{background:#ef44444d}.input-footer{display:flex;flex-direction:column;gap:12px;align-items:center}.selection-count{color:var(--text-secondary);font-size:.85rem}.footer-buttons{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.results{display:flex;flex-direction:column;gap:20px}.results-header{text-align:center}.results-title{font-family:var(--font-display);font-size:1.3rem;color:var(--gold-primary);margin-bottom:6px}.results-subtitle{color:var(--text-secondary);font-size:.85rem}.results-tabs{display:flex;gap:4px;background:var(--bg-card);border-radius:var(--radius);padding:4px;border:1px solid var(--border-subtle)}.tab-btn{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.tab-btn.active{background:#c9a84c26;color:var(--gold-primary);box-shadow:0 0 10px var(--gold-glow)}.tab-btn:hover:not(.active){background:#ffffff08;color:var(--text-primary)}.recommend-section{display:flex;flex-direction:column;gap:16px}.empty-result{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-result p{margin-bottom:8px}.result-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;overflow:hidden}.result-card-title{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;margin-bottom:14px;color:var(--text-primary)}.result-icon{font-size:1.1rem}.result-all-available{border-color:#4ade804d;background:linear-gradient(135deg,var(--bg-card),rgba(74,222,128,.03))}.result-one-missing{border-color:#fbbf2433}.result-adjustments{border-color:#60a5fa33}.result-two-missing{border-color:var(--border-subtle)}.result-list{list-style:none;display:flex;flex-direction:column;gap:8px}.result-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;background:#ffffff05;border-radius:var(--radius);font-size:.9rem;border-left:3px solid var(--border-subtle)}.result-item-gold{border-left-color:var(--gold-primary);background:#c9a84c0f;color:var(--gold-light);font-weight:600}.result-item-adjust{border-left-color:var(--info);font-size:.85rem}.result-time{font-weight:600;color:var(--text-primary);min-width:120px}.result-detail{color:var(--text-secondary);font-size:.85rem}.missing-name{color:var(--warning);margin-left:4px}.no-result{color:var(--text-dim);font-size:.85rem;padding:8px 0}.heatmap-section{display:flex;flex-direction:column;gap:14px}.heatmap-legend{display:flex;align-items:center;justify-content:center;gap:10px;font-size:.8rem;color:var(--text-secondary)}.legend-gradient{width:120px;height:12px;border-radius:6px;background:linear-gradient(to right,#c9a84c0d,#c9a84c40,#c9a84c80,#f0d060d9);border:1px solid var(--border-subtle)}.heatmap-container{overflow-x:auto;border:1px solid var(--border-gold);border-radius:var(--radius-lg)}.heatmap-grid{width:100%;border-collapse:collapse}.heatmap-grid th,.heatmap-grid td{text-align:center;padding:0}.heatmap-day{padding:10px 8px;font-weight:600;color:var(--text-gold);background:var(--bg-surface);border-bottom:1px solid var(--border-gold);font-size:.9rem}.heatmap-hour{padding:2px 8px 0;font-size:.8rem;color:var(--text-secondary);background:var(--bg-surface);border-right:1px solid var(--border-subtle);vertical-align:top;line-height:1}.heatmap-cell{width:14.28%;min-width:44px;height:44px;border:1px solid rgba(255,255,255,.04);font-size:.85rem;font-weight:600;color:var(--text-primary);transition:all .2s}.heatmap-cell.heatmap-full{box-shadow:inset 0 0 12px #f0d0604d;color:#fff;font-weight:700}.heatmap-cell.heatmap-selected{outline:2px solid var(--gold);outline-offset:-2px}.slot-detail{margin-top:12px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--gold);border-radius:var(--radius-md)}.slot-detail-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.slot-detail-count{color:var(--text-secondary);font-size:.85rem}.slot-detail-close{margin-left:auto;padding:2px 6px;font-size:.8rem}.slot-detail-group{display:flex;align-items:baseline;gap:8px;margin-top:4px;font-size:.9rem}.slot-detail-label{flex-shrink:0;padding:1px 8px;border-radius:4px;font-size:.8rem;font-weight:600}.available-label{background:#4ade8033;color:var(--success)}.unavailable-label{background:#ef444433;color:var(--danger)}.slot-detail-names{color:var(--text-primary)}.results-footer{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.settings{display:flex;flex-direction:column;gap:24px}.settings-header{text-align:center}.settings-title{font-family:var(--font-display);font-size:1.3rem;color:var(--gold-primary);margin-bottom:6px}.settings-subtitle{color:var(--text-secondary);font-size:.85rem}.settings-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px}.settings-danger{border-color:#ef444433}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.member-edit-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.member-edit-row{display:flex;align-items:center;gap:8px}.member-number{width:24px;text-align:center;font-size:.8rem;color:var(--text-dim);font-weight:600}.input-field{flex:1;padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;outline:none;transition:border-color .2s}.input-field:focus{border-color:var(--gold-primary);box-shadow:0 0 8px var(--gold-glow)}.input-field::placeholder{color:var(--text-dim)}.select-field{padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;outline:none;cursor:pointer;transition:border-color .2s}.select-field:focus{border-color:var(--gold-primary)}.btn-add-member{width:100%}.time-range-setting{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.time-range-input{flex:1;min-width:140px}.time-range-input label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:6px}.time-range-separator{color:var(--text-dim);font-size:1.2rem;padding-bottom:10px}.setting-hint{color:var(--text-secondary);font-size:.8rem;margin-top:10px}.reset-confirm{margin-top:12px}.reset-warning{color:var(--danger);font-size:.9rem;margin-bottom:14px;padding:12px;background:var(--danger-bg);border-radius:var(--radius)}.reset-buttons{display:flex;gap:10px}.settings-footer{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}@media (max-width: 768px){.app-header{padding:10px 12px;position:sticky;top:0;z-index:100;background:var(--bg-primary);border-bottom:1px solid var(--border-subtle)}.app-title{font-size:.95rem;letter-spacing:1px}.header-left,.header-right{min-width:auto}.app-content{padding:14px 10px}.member-grid{gap:10px}.member-card{padding:16px 10px}.member-icon{font-size:1.5rem}.member-name{font-size:.9rem}.member-class{font-size:.7rem}.select-title{font-size:1.2rem}.select-subtitle{font-size:.8rem}.input-subtitle{font-size:.78rem;line-height:1.4}.input-title{font-size:1.1rem}.time-cell{min-width:40px;height:44px;font-size:.8rem}.day-header{padding:10px 2px;font-size:.8rem}.hour-label{padding:2px 4px 0;font-size:.7rem}.time-header-corner{width:40px;min-width:40px}.input-controls{gap:6px}.input-controls .btn{padding:8px 12px;font-size:.78rem}.btn-large{padding:12px 20px;font-size:.9rem;width:100%}.select-actions{padding:0 4px}.footer-buttons{width:100%}.footer-buttons .btn{flex:1;min-width:0}.result-item{flex-direction:column;align-items:flex-start;gap:4px;font-size:.85rem}.result-time{min-width:auto}.result-card-title{font-size:.95rem}.result-item-adjust{font-size:.82rem;word-break:keep-all}.heatmap-cell{min-width:36px;height:36px;font-size:.75rem}.heatmap-cell.heatmap-selected{outline-width:2px}.slot-detail{padding:10px 12px;font-size:.85rem}.slot-detail-header{font-size:.9rem}.results-tabs{gap:0}.tab-btn{flex:1;font-size:.85rem;padding:10px 8px}.member-edit-row{flex-wrap:wrap}.member-edit-row .input-field{min-width:0;flex:1}.member-edit-row .select-field{min-width:80px}.app-footer{font-size:.7rem;padding:12px}.settings-title{font-size:1.1rem}.section-title{font-size:.95rem}}@media (max-width: 360px){.app-content{padding:10px 6px}.member-grid{gap:8px}.member-card{padding:14px 8px}.time-cell{min-width:34px;height:40px}.heatmap-cell{min-width:30px;height:30px;font-size:.7rem}.hour-label{font-size:.65rem;padding:2px 2px 0}.time-header-corner{width:34px;min-width:34px}.day-header{font-size:.7rem}}@media (min-width: 960px){.member-grid{grid-template-columns:repeat(4,1fr)}.time-cell{min-width:56px;height:52px}.time-cell:hover{box-shadow:inset 0 0 8px #c9a84c26}.heatmap-cell{min-width:52px;height:48px}}.member-select,.time-input,.results,.settings{animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold-primary)}.time-grid-container{-webkit-touch-callout:none}.time-unit-selector{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.time-unit-label{color:var(--text-secondary);font-size:.85rem;white-space:nowrap}.time-unit-buttons{display:flex;gap:8px}.btn-unit,.btn-unit-sm{padding:6px 16px;border-radius:var(--radius);font-size:.85rem;cursor:pointer;transition:all .2s}.btn-unit-sm{padding:4px 12px;font-size:.8rem}.btn-unit-active{background:var(--gold-primary);color:var(--bg-primary);border:1px solid var(--gold-primary);font-weight:600}.btn-unit-active:hover{background:var(--gold-light)}.setting-warning{color:var(--warning);font-size:.8rem;margin-top:8px}.time-grid-compact .time-cell,.time-cell-compact{padding:4px 2px;font-size:.7rem;min-height:28px}.hour-label-sub{font-size:.7rem;color:var(--text-dim)}.heatmap-grid-compact .heatmap-cell{padding:3px 2px;font-size:.7rem;min-height:24px}.heatmap-hour-sub{font-size:.7rem;color:var(--text-dim)}.memo-input-section{margin:12px 0}.memo-input{width:100%;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem;transition:border-color .2s}.memo-input:focus{outline:none;border-color:var(--gold-primary)}.memo-input::placeholder{color:var(--text-dim)}.result-memos{border-color:#60a5fa4d}.result-item-memo{display:flex;gap:8px;align-items:baseline}.memo-author{color:var(--gold-primary);font-weight:600;white-space:nowrap;flex-shrink:0}.memo-author:after{content:":"}.memo-content{color:var(--text-secondary);word-break:break-word}
