*{--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.5rem}.dashboard-header{height:48px!important;padding:0 1rem!important}.header-left .logo-icon{width:28px!important;height:28px!important}.header-user{padding:.375rem .75rem!important}.user-avatar{width:22px!important;height:22px!important}.dashboard-nav{min-height:auto!important}.nav-tab{padding:.625rem 1rem!important;min-height:40px!important}.nav-tab-icon{width:18px!important;height:18px!important}.nav-tab-label{font-size:.875rem!important;line-height:1.2!important}.dashboard-content{padding:1rem!important}.page-header{margin-bottom:1rem!important}.page-title h2{font-size:1.5rem!important;line-height:1.2!important}.stat-cards{gap:.75rem!important;margin-bottom:1rem!important}.stat-card{padding:1rem!important;min-height:auto!important}.stat-content h3{font-size:.75rem!important;margin-bottom:.375rem!important}.stat-value{font-size:1.75rem!important;line-height:1!important}.stat-trend{margin-top:.375rem!important;padding:.2rem .4rem!important;font-size:.7rem!important}.reservation-list-header{padding:.75rem 1rem!important;margin-bottom:.75rem!important}.list-title{font-size:1.125rem!important}.reservation-item{padding:.875rem!important;margin-bottom:.625rem!important}.reservation-item-header{margin-bottom:.5rem!important}.reservation-item-body{gap:.5rem!important}.reservation-info-row{margin-bottom:.375rem!important}.reservation-info-label{font-size:.75rem!important}.reservation-info-value{font-size:.875rem!important}.option-tag{padding:.2rem .5rem!important;font-size:.7rem!important;line-height:1!important}.calendar-header{padding:.75rem!important;margin-bottom:.75rem!important}.calendar-title{font-size:1.125rem!important}.calendar-day{min-height:80px!important;padding:.5rem!important}.calendar-day-number{font-size:.875rem!important;margin-bottom:.25rem!important}.calendar-day-content{font-size:.75rem!important;line-height:1.2!important}.reservation-block{padding:.25rem .375rem!important;margin-bottom:.25rem!important;font-size:.7rem!important;line-height:1.2!important}.modal-header{padding:1rem 1.25rem!important}.modal-title{font-size:1.125rem!important}.modal-body{padding:1rem 1.25rem!important}.modal-footer{padding:.75rem 1.25rem!important}.form-group{margin-bottom:.875rem!important}.form-label{font-size:.8125rem!important;margin-bottom:.375rem!important}.form-control{padding:.5rem .75rem!important;font-size:.875rem!important}.btn{padding:.5rem 1rem!important;font-size:.875rem!important;line-height:1.2!important}.btn-sm{padding:.375rem .75rem!important;font-size:.8125rem!important}.btn-lg{padding:.625rem 1.25rem!important;font-size:.9375rem!important}.table th{padding:.625rem!important;font-size:.8125rem!important}.table td{padding:.5rem!important;font-size:.875rem!important}@media (max-width: 768px){.dashboard-header{height:44px!important}.nav-tab{padding:.5rem .2rem!important;min-height:44px!important}.nav-tab-icon{width:16px!important;height:16px!important}.nav-tab-label{font-size:.625rem!important}.dashboard-content{padding:.75rem!important}.stat-card{padding:.75rem!important;min-height:70px!important}.stat-value{font-size:1.25rem!important}.stat-content h3{font-size:.7rem!important}.reservation-item{padding:.75rem!important;margin-bottom:.5rem!important}.calendar-day{min-height:60px!important;padding:.375rem!important}.calendar-day-number{font-size:.75rem!important}.reservation-block{font-size:.625rem!important;padding:.2rem .25rem!important}.modal-header,.modal-body{padding:.875rem 1rem!important}.modal-footer{padding:.625rem 1rem!important}.mobile-page-title{padding:.75rem .875rem!important;margin-bottom:.875rem!important}.mobile-page-title h2{font-size:1rem!important}}@media (max-width: 480px){.dashboard-header{height:40px!important}.nav-tab{min-height:40px!important;padding:.4rem .15rem!important}.nav-tab-icon{width:14px!important;height:14px!important}.nav-tab-label{font-size:.5625rem!important}.dashboard-content{padding:.5rem!important}.stat-card{padding:.625rem!important;min-height:60px!important}.stat-value{font-size:1rem!important}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0000004d}.compact-mode{font-size:90%!important}.compact-mode .dashboard-header{height:42px!important}.compact-mode .nav-tab{min-height:36px!important;padding:.5rem .75rem!important}.compact-mode .stat-card{padding:.75rem!important}.compact-mode .reservation-item{padding:.625rem!important;margin-bottom:.5rem!important}@media print{.dashboard-header,.dashboard-nav,.mobile-menu-trigger,.btn-logout{display:none!important}.dashboard-content{padding:0!important}.stat-card,.reservation-item{page-break-inside:avoid}}*{transition-duration:.2s!important}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (hover: none) and (pointer: coarse){.btn,.nav-tab,.reservation-item{min-height:44px}.clickable:before{content:"";position:absolute;inset:-8px}}@media (prefers-color-scheme: dark){*{border-width:.5px!important}.stat-value{font-weight:600!important}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}.no-margin{margin:0!important}.no-padding{padding:0!important}.p-compact{padding:.5rem!important}.m-compact{margin:.5rem!important}.line-compact{line-height:1.2!important}.text-compact{font-size:.875rem!important}.text-xs-compact{font-size:.75rem!important}.pricing-settings{padding:1.25rem!important}.pricing-settings .settings-header{margin-bottom:1.25rem!important}.pricing-settings .settings-header h2{font-size:1.5rem!important}.pricing-tabs{margin-bottom:1.25rem!important}.pricing-tabs button{padding:.5rem 1rem!important}.price-setting-section{padding:1.25rem!important}.price-setting-section .section-header{margin-bottom:1.25rem!important}.room-price-grid{gap:1rem!important}.room-price-card{padding:1rem!important}.room-price-card h4{margin:0 0 .75rem!important;font-size:1rem!important}.price-inputs{gap:.75rem!important}.price-input-group{gap:.375rem!important}.price-input-group label{font-size:.8125rem!important}.price-input-group input{padding:.5rem!important;font-size:.875rem!important}.holidays-section{padding:1.25rem!important}.holidays-info{padding:1rem!important;margin-bottom:1.25rem!important}.holidays-info p{margin:0 0 .375rem!important}.holidays-list h4{margin:1rem 0 .75rem!important}.holiday-grid{gap:.5rem!important;margin-bottom:1rem!important}.holiday-item{padding:.5rem!important;font-size:.8125rem!important}.price-calendar-section{padding:1.25rem!important}.price-calendar-section h3{margin:0 0 1rem!important}.room-selector{padding:.75rem!important;margin-bottom:1rem!important}.calendar-header{margin-bottom:1rem!important}.calendar-header h4{font-size:1.25rem!important}.calendar-day{min-height:90px!important;padding:.5rem!important}.day-header{margin-bottom:.375rem!important}.day-number{font-size:.875rem!important}.price-amount{font-size:1rem!important}.calendar-footer{margin-top:1.25rem!important;padding:1rem!important}.rules-section{padding:1.25rem!important}.rules-list{gap:1rem!important}.rule-header{padding:1rem!important}.rule-info h4{font-size:1.125rem!important}.rule-details{padding:1rem!important}.room-season-price{padding:.875rem!important}.options-settings{padding:1.25rem!important}.options-settings .settings-header{margin-bottom:1.25rem!important}.options-settings .settings-header h2{font-size:1.5rem!important}.option-tabs{margin-bottom:1.25rem!important}.option-tabs button{padding:.5rem 1rem!important}.options-section{padding:1.25rem!important}.options-section h3{margin:0 0 1rem!important}.option-card{padding:1rem!important;margin-bottom:.75rem!important}.option-header{margin-bottom:.75rem!important}.option-header h4{font-size:1rem!important}.option-type,.room-badge{padding:.25rem .5rem!important;font-size:.75rem!important}.option-actions button{padding:.25rem .5rem!important;font-size:.8125rem!important}.option-details{font-size:.8125rem!important}.option-details p{margin:.375rem 0!important}.room-info{margin-top:.75rem!important;padding-top:.75rem!important}.room-settings-grid{gap:.375rem!important;margin-top:.375rem!important}.room-setting-item{padding:.25rem .5rem!important;font-size:.75rem!important}.room-mapping-section{padding:1.25rem!important}.room-mapping-grid{gap:1rem!important}.room-mapping-card{padding:1rem!important}.room-mapping-card h4{margin:0 0 .75rem!important;font-size:1rem!important;padding-bottom:.5rem!important}.applied-options{gap:.375rem!important}.applied-option{padding:.375rem!important;font-size:.8125rem!important}.modal-content{padding:1.5rem!important}.modal-content h3{margin:0 0 1rem!important}.form-group{margin-bottom:1rem!important}.form-group label{margin-bottom:.375rem!important;font-size:.875rem!important}.form-group input,.form-group select,.form-group textarea{padding:.5rem!important;font-size:.875rem!important}.room-checkboxes{gap:.5rem!important;margin-top:.375rem!important}.checkbox-label{padding:.375rem!important}.individual-settings{gap:.5rem!important}.room-setting{padding:.5rem!important}.form-actions{margin-top:1.25rem!important}.btn-save,.btn-cancel{padding:.375rem 1rem!important}.info-section{padding:1rem!important;margin-bottom:1rem!important}.info-section h3{margin:0 0 .75rem!important;font-size:1rem!important}.extra-charges-grid{gap:.5rem!important}.charge-item{padding:.5rem!important}@media (max-width: 768px){.pricing-settings,.options-settings{padding:1rem!important}.settings-header{margin-bottom:1rem!important}.settings-header h2{font-size:1.25rem!important}.pricing-tabs,.option-tabs{margin-bottom:1rem!important}.pricing-tabs button,.option-tabs button{padding:.4rem .75rem!important;font-size:.8125rem!important}.price-setting-section,.options-section,.holidays-section,.price-calendar-section,.rules-section,.room-mapping-section{padding:1rem!important}.room-price-card,.option-card,.room-mapping-card{padding:.75rem!important}.calendar-day{min-height:70px!important;padding:.375rem!important}.day-number{font-size:.75rem!important}.price-amount{font-size:.875rem!important}.modal-content{padding:1.25rem!important}.form-group{margin-bottom:.875rem!important}.form-group label{font-size:.8125rem!important}.form-group input,.form-group select,.form-group textarea{padding:.4rem!important;font-size:.8125rem!important}}@media (max-width: 480px){.pricing-settings,.options-settings{padding:.75rem!important}.settings-header h2{font-size:1.125rem!important}.pricing-tabs button,.option-tabs button{padding:.375rem .625rem!important;font-size:.75rem!important}.room-price-card,.option-card{padding:.625rem!important}.calendar-day{min-height:60px!important;padding:.25rem!important}.option-type,.room-badge{font-size:.625rem!important;padding:.15rem .375rem!important}.modal-content{padding:1rem!important}}.settings-compact .pricing-settings,.settings-compact .options-settings{padding:1rem!important}.settings-compact .settings-header{margin-bottom:.875rem!important}.settings-compact .room-price-card,.settings-compact .option-card{padding:.75rem!important;margin-bottom:.5rem!important}.settings-compact .form-group{margin-bottom:.75rem!important}.pricing-settings *,.options-settings *{transition-duration:.15s!important}.option-form,.modal-content{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.option-form::-webkit-scrollbar,.modal-content::-webkit-scrollbar{width:6px}.option-form::-webkit-scrollbar-thumb,.modal-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}@media print{.pricing-settings,.options-settings{padding:0!important}.btn-add,.btn-edit,.btn-delete,.option-actions,.form-actions{display:none!important}}.summary-card.total *,.summary-card.total .summary-value,.summary-card.total h4,.summary-card.total .summary-details,.summary-card.total span,.summary-card.total strong,.cumulative-card.highlight *,.cumulative-card.highlight .cumulative-label,.cumulative-card.highlight .cumulative-value,.stat-card.total *,.stat-card.total .stat-header,.stat-card.total .stat-title,.stat-card.total .stat-value,.stat-card.total .stat-sub,.platform-detail-card *,.kpi-card *{text-shadow:none!important}.reservation-options{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.option-item{display:inline-flex;align-items:center;gap:3px;padding:2px 6px!important;border-radius:4px;font-size:.7rem!important;font-weight:500}.option-label{font-size:.65rem!important;font-weight:600}.option-note{font-size:.6rem!important;opacity:.8}.option-item.included,.option-included{background:#e3f2fd!important;color:#1565c0!important;border:1px solid #90caf9}.option-item.onsite,.option-onsite{background:#fff3e0!important;color:#e65100!important;border:1px solid #ffb74d}.date-detail-panel.mobile .option-item{font-size:.65rem!important;padding:2px 4px!important}.date-detail-panel.mobile .option-label{font-size:.6rem!important}.date-detail-panel.mobile .option-note{font-size:.55rem!important}.reservation-details .options-info{margin-top:8px;padding:6px;background:#f8f9fa;border-radius:4px}.reservation-details .option-item{margin-right:4px;margin-bottom:4px}[style*="background: linear-gradient"] *,[style*="background-image: linear-gradient"] *,[style*="background: #667eea"] *,[style*="background: #764ba2"] *,[style*="background: #9b59b6"] *,[style*="background: #8e44ad"] *,.integrated-stats *,.ad-efficiency-dashboard *,.marketing-stats-v2 *{text-shadow:none!important}*{box-sizing:border-box}.app{width:100%;min-height:100vh;background-color:#f8f9fa;color:var(--text-primary, #374151);display:flex;flex-direction:column}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.loading-spinner{width:50px;height:50px;border:3px solid #e8f5e9;border-top:3px solid #2d5016;border-right:3px solid #558b2f;border-radius:50%;animation:spin .8s ease-in-out infinite;margin-bottom:20px}.loading-screen p{color:#666;font-size:16px}.error-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:20px;text-align:center}.error-screen h2{color:#dc3545;margin-bottom:16px}.error-screen p{color:#666;margin-bottom:24px;max-width:400px}.error-screen button{padding:12px 24px;background-color:#2d5016;color:var(--text-inverse, white);border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.error-screen button:hover{background-color:#3a6a1d}.error-screen button:active{transform:translateY(1px)}@media (max-width: 768px){.loading-screen p,.error-screen p{font-size:14px}.error-screen button{font-size:14px;padding:10px 20px}}.customer-badge-wrapper{display:inline-flex;align-items:center;gap:4px}.customer-badge-wrapper .customer-name{font-weight:inherit;font-size:inherit;color:inherit}.reservation-count-badge{display:inline-flex!important;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 4px;border-radius:10px;background:#ff6b6b;color:#fff;font-size:12px;font-weight:700;line-height:1;flex-shrink:0;transition:all .2s ease;vertical-align:middle;margin-left:4px;box-shadow:0 1px 3px #0003}.reservation-count-badge.vip{background:linear-gradient(135deg,gold,#ffed4e);color:#333;box-shadow:0 0 0 2px #ffd7004d,0 2px 4px #ffd70080;font-weight:800;animation:vipPulse 2s ease-in-out infinite}@keyframes vipPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.reservation-count-badge:hover{transform:scale(1.1);cursor:help}@media (prefers-color-scheme: dark){.reservation-count-badge{background:#4a4a4a;color:#fff}.reservation-count-badge.vip{background:linear-gradient(135deg,gold,#ffed4e);color:#333}}@media (max-width: 768px){.reservation-count-badge{min-width:18px;height:18px;font-size:11px;padding:0 3px}}.reservation-table .customer-badge-wrapper{white-space:nowrap}.reservation-card .customer-badge-wrapper{font-weight:500}.calendar-booking .customer-badge-wrapper .reservation-count-badge{width:14px;height:14px;font-size:9px}.booking-detail-chip.room-forest{background:linear-gradient(135deg,#e9e3ff,#d4c5fd);border-color:#a78bfa}.booking-detail-chip.room-forest .booking-main-info,.booking-detail-chip.room-forest .booking-sub-info{color:#4c1d95;font-weight:600}.booking-detail-chip.room-forest-mini{background:linear-gradient(135deg,#fef0f9,#fdd8ee);border-color:#f9a8d4}.booking-detail-chip.room-forest-mini .booking-main-info,.booking-detail-chip.room-forest-mini .booking-sub-info{color:#831843;font-weight:600}.booking-detail-chip.room-forest-family{background:linear-gradient(135deg,#e6f2ff,#cce7ff);border-color:#93c5fd}.booking-detail-chip.room-forest-family .booking-main-info,.booking-detail-chip.room-forest-family .booking-sub-info{color:#1e3a8a;font-weight:600}.booking-detail-chip.room-forest-mini-family{background:linear-gradient(135deg,#e6fffa,#b2f5ea);border-color:#67e8f9}.booking-detail-chip.room-forest-mini-family .booking-main-info,.booking-detail-chip.room-forest-mini-family .booking-sub-info{color:#134e4a;font-weight:600}.booking-detail-chip.room-lakeview{background:linear-gradient(135deg,#fff9e6,#fff0b3);border-color:#fbbf24}.booking-detail-chip.room-lakeview .booking-main-info,.booking-detail-chip.room-lakeview .booking-sub-info{color:#78350f;font-weight:600}.booking-detail-chip.room-group{background:linear-gradient(135deg,#eef2ff,#ddd6fe);border-color:#a5b4fc}.booking-detail-chip.room-group .booking-main-info,.booking-detail-chip.room-group .booking-sub-info{color:#312e81;font-weight:600}.addon-info{display:inline-flex;align-items:center;gap:2px;padding:1px 4px;border-radius:3px;background:#ffffffb3;font-size:.9em;font-weight:600;white-space:nowrap;color:#111827}.addon-info.onsite{background:#ef444426;color:#b91c1c;font-weight:700;border:1px solid rgba(239,68,68,.4)}.calendar-grid>.calendar-cell:nth-child(7n){border-right:4px solid #6366f1!important}.calendar-grid>.calendar-cell:nth-child(n+1):nth-child(-n+7):not(.today):not(.weekend):not(.empty){background-color:#fff}.calendar-grid>.calendar-cell:nth-child(n+15):nth-child(-n+21):not(.today):not(.weekend):not(.empty){background-color:#fff}.calendar-grid>.calendar-cell:nth-child(n+29):nth-child(-n+35):not(.today):not(.weekend):not(.empty){background-color:#fff}.calendar-grid>.calendar-cell:nth-child(n+8):nth-child(-n+14):not(.today):not(.weekend):not(.empty){background-color:#f1f5f9}.calendar-grid>.calendar-cell:nth-child(n+22):nth-child(-n+28):not(.today):not(.weekend):not(.empty){background-color:#f1f5f9}.calendar-grid>.calendar-cell:nth-child(n+36):nth-child(-n+42):not(.today):not(.weekend):not(.empty){background-color:#f1f5f9}.custom-calendar{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:auto;width:100%;min-width:0}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.month-nav-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:#fff;border:1px solid #ddd;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;color:var(--color-dark)}.month-nav-btn:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.month-display{display:flex;align-items:center;gap:1rem}.month-display h2{margin:0;font-size:1.5rem;color:var(--color-dark)}.today-btn{padding:.5rem 1rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.today-btn:hover{background-color:var(--color-secondary);transform:translateY(-1px)}.weekdays{display:grid;grid-template-columns:repeat(7,1fr);background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;width:100%}.weekday{padding:1rem;text-align:center;font-weight:600;font-size:.875rem;color:var(--color-dark);border-right:1px solid #e9ecef}.weekday:last-child{border-right:none}.weekday.weekend{color:var(--color-danger)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:0;background-color:#e0e0e0;border:1px solid #e0e0e0;width:100%;align-items:stretch}.calendar-cell{background-color:#fff;min-height:60px;height:100%;padding:.25rem;cursor:pointer;transition:all .2s ease;position:relative;overflow:visible;border-right:2px solid #dee2e6;border-bottom:2px solid #dee2e6;display:flex;flex-direction:column}.calendar-cell:nth-child(7n):not(.empty){border-right:2px solid #dee2e6}.calendar-cell:hover:not(.past):not(.empty){background-color:#f0f9ff;box-shadow:inset 0 0 0 2px #93c5fd;z-index:5}.calendar-cell.selected,.calendar-cell[aria-selected=true]{background-color:#eff6ff!important;box-shadow:inset 0 0 0 3px #3b82f6!important;z-index:10}.calendar-cell.selected:hover,.calendar-cell[aria-selected=true]:hover{box-shadow:inset 0 0 0 3px #2563eb!important}.calendar-cell[aria-selected=false],.calendar-cell:not(.selected)[aria-selected=false]{box-shadow:none!important;background-color:inherit}.calendar-cell:not(.selected):not(:hover){box-shadow:none!important}.calendar-cell:focus{outline:none}.calendar-cell:focus-visible:not(.selected){outline:2px solid #93c5fd;outline-offset:-2px}.calendar-cell.past{background-color:#f8f9fa;cursor:pointer;opacity:.7}.calendar-cell.today{background-color:#e8f5e9}.calendar-cell.weekend:not(.past){background-color:#fef9f9}.calendar-cell.empty{background-color:#fafafa;cursor:default;pointer-events:none}.calendar-cell.empty:focus,.calendar-cell.empty:focus-visible{outline:none!important;box-shadow:none!important}.cell-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem;flex-shrink:0}.cell-day{font-weight:700;font-size:1.1rem;color:var(--color-dark);background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:.25rem .5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;min-width:2rem;text-align:center}.calendar-cell.weekend .cell-day{color:var(--color-danger)}.occupancy-badge{font-size:.7rem;padding:.125rem .375rem;border-radius:.75rem;font-weight:600;line-height:1}.occupancy-badge.high{background-color:#ffebee;color:#c62828}.occupancy-badge.medium{background-color:#fff3e0;color:#e65100}.occupancy-badge.low{background-color:#e8f5e9;color:#2e7d32}.occupancy-badge.zero{background-color:#f5f5f5;color:#9e9e9e}.cell-content{display:flex;flex-direction:column;gap:0!important;width:100%}.room-info{display:flex;flex-direction:column;gap:0!important;margin-bottom:0!important;position:relative;z-index:1}.room-status{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;padding:.05rem .25rem;border-radius:.25rem;line-height:1.2;margin-bottom:0!important;position:relative;z-index:2}.room-status.available{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#1b5e20;font-weight:500}.room-status.full{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#b71c1c;font-weight:600}.room-info.has-booking{background:linear-gradient(135deg,#fef9c366,#fef08a4d);border-radius:4px;padding:1px;margin:-1px;position:relative}.room-info.has-booking:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(254,240,138,.2) 0%,transparent 70%);pointer-events:none;border-radius:4px;z-index:0}.room-status.has-booking{background:linear-gradient(135deg,#fef08af2,#facc15d9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#713f12;font-weight:600;border:1px solid rgba(250,204,21,.5);border-left:3px solid #f59e0b;box-shadow:0 0 20px #facc1599,0 0 40px #facc1566,inset 0 0 20px #ffffff4d,0 2px 4px #0000001a;position:relative;z-index:2;animation:glow-yellow 2s ease-in-out infinite alternate}@keyframes glow-yellow{0%{box-shadow:0 0 20px #facc1599,0 0 40px #facc1566,inset 0 0 20px #ffffff4d,0 2px 4px #0000001a}to{box-shadow:0 0 30px #facc15cc,0 0 60px #facc1599,inset 0 0 25px #fff6,0 2px 6px #00000026}}.booking-count-badge{font-size:.7rem;font-weight:700;padding:.1rem .3rem;border-radius:.75rem;min-width:1.2rem;text-align:center;background:linear-gradient(135deg,#fff,#fef3c7);color:#713f12;border:1px solid rgba(250,204,21,.3);box-shadow:0 1px 3px #0000001a}.room-status.has-booking .booking-count-badge{background:#fff;color:#92400e;font-weight:800;box-shadow:0 0 10px #facc1580,0 1px 3px #0003}.room-status.has-booking:hover{transform:translateY(-1px) scale(1.02);filter:brightness(1.1);z-index:10}.room-name{font-weight:500;font-size:.6rem;white-space:nowrap;max-width:50%;letter-spacing:-.5px}.room-info .mobile-booking-indicator{display:flex;align-items:center;justify-content:center;margin:2px 0 0!important;padding:0 2px;background:#67e8f9e6;border:1px solid rgba(103,232,249,.3);border-radius:3px;line-height:.9;position:relative;z-index:5}.mobile-booking-indicator .booking-count{font-size:.45rem;color:#0e7490;font-weight:600}@media (max-width: 768px){.room-status.has-booking{animation:glow-yellow-mobile 3s ease-in-out infinite alternate}@keyframes glow-yellow-mobile{0%{box-shadow:0 0 15px #facc1580,inset 0 0 15px #fff3}to{box-shadow:0 0 20px #facc15b3,inset 0 0 20px #ffffff4d}}.room-status{font-size:10px!important;padding:2px 3px!important;line-height:1.2!important}.room-name{font-size:10px!important}.room-stock{font-size:9px!important}}.booking-detail-chip{margin-top:4px;padding:6px 8px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:11px;border:1px solid transparent;background:#fff;box-shadow:0 1px 3px #00000014}.booking-detail-chip:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026;border-color:#e5e7eb;z-index:10}.booking-detail-chip.status-예약확정{border-width:2px;border-style:solid}.booking-detail-chip.status-입금대기{border-width:2px;border-style:dashed;opacity:.9}.booking-main-info{display:flex;align-items:center;gap:4px;margin-bottom:4px;font-weight:600}.source-icon{font-size:12px;flex-shrink:0}.customer-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;font-weight:600}.status-indicator{color:#f59e0b;font-weight:700;font-size:12px;flex-shrink:0}.booking-sub-info{display:flex;flex-direction:column;gap:3px;font-size:10px;margin-left:16px}.booking-sub-info>span{display:inline-flex;align-items:center;gap:2px;white-space:nowrap}.guest-count{font-weight:500}.total-price{font-weight:600}.calendar-legend{display:flex;justify-content:center;gap:2rem;padding:1rem;background-color:#f8f9fa;border-top:1px solid #e0e0e0}.legend-color{width:1rem;height:1rem;border-radius:.25rem;border:1px solid #ddd}.legend-color.available{background-color:#e8f5e9}.legend-color.full{background-color:#ffebee}.legend-color.status-입금대기{background-color:var(--color-warning)}.legend-color.status-예약확정{background-color:var(--color-success)}@media (min-width: 1920px){.calendar-cell{min-height:140px;height:auto;padding:.75rem}.cell-day{font-size:1rem}.room-status{font-size:.75rem;padding:.25rem .5rem}.room-name{font-size:.75rem}.booking-detail-chip{padding:8px 10px;font-size:12px}.booking-main-info{margin-bottom:5px}.source-icon{font-size:14px}.customer-name{font-size:13px}.booking-sub-info{font-size:11px;gap:8px}.occupancy-badge{font-size:.75rem;padding:.25rem .5rem}}@media (min-width: 1366px) and (max-width: 1919px){.calendar-cell{min-height:120px;height:auto}}@media (max-width: 1024px){.calendar-cell{min-height:100px;height:auto;padding:.375rem}.month-display h2{font-size:1.25rem}.room-status{font-size:.65rem}.booking-detail-chip{padding:4px 6px;font-size:9px}.booking-main-info{margin-bottom:3px}.source-icon,.customer-name{font-size:10px}.booking-sub-info{font-size:8px;gap:4px;margin-left:12px}}@media (max-width: 768px){.custom-calendar{overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-grid,.weekdays{min-width:700px;width:700px}.calendar-grid{grid-auto-rows:1fr;min-height:350px}.calendar-header{padding:.5rem;position:sticky;left:0;z-index:10}.month-display h2{font-size:.9rem}.weekday{padding:.4rem .2rem;font-size:.65rem;font-weight:500}.calendar-cell{min-height:50px;padding:.15rem;min-width:100px}.cell-header{margin-bottom:.1rem}.cell-day{font-size:.9rem;font-weight:700;padding:.2rem .4rem;min-width:1.5rem}.occupancy-badge{font-size:.45rem;padding:.05rem .15rem}.room-info{gap:0;margin-bottom:0}.cell-content{gap:0!important}.room-status{font-size:10px;padding:1px 3px;line-height:1.1;display:flex;justify-content:space-between;align-items:center}.room-name{font-size:9px;white-space:nowrap;letter-spacing:-.5px;max-width:45%}.booking-count-badge{font-size:9px;padding:0 .2rem;min-width:.9rem}.mobile-booking-indicator{margin-top:1px!important;padding:1px 2px}.mobile-booking-indicator .booking-count{font-size:9px}.booking-detail-chip{padding:2px 3px;font-size:.45rem;margin-top:2px}.booking-main-info{margin-bottom:1px;gap:1px}.source-icon,.customer-name{font-size:.5rem}.booking-sub-info{font-size:.4rem;gap:1px;margin-left:8px}.calendar-legend{padding:.5rem;gap:.5rem;font-size:.65rem}.legend-color{width:.6rem;height:.6rem}}@media (max-width: 480px){.weekday{font-size:.6rem;padding:.3rem .15rem}.calendar-cell{min-height:45px;padding:.1rem}.calendar-grid{grid-auto-rows:1fr;min-height:315px}.cell-day{font-size:.8rem;padding:.15rem .3rem}.cell-header{margin-bottom:.05rem}.occupancy-badge{font-size:.4rem;padding:.05rem .1rem}.room-status{font-size:9px;padding:0 2px;line-height:1}.room-name{font-size:8px;letter-spacing:-.5px;max-width:40%}.booking-count-badge{font-size:8px;padding:0 .15rem;min-width:.8rem}.mobile-booking-indicator{margin-top:1px!important;padding:0}.mobile-booking-indicator .booking-count{font-size:8px}.cell-content{gap:0}.room-info{gap:0;margin-bottom:0}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:20px}.close-button{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.close-button:hover{opacity:.8}.modal-body{padding:20px}.info-section{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.info-section h3{margin:0 0 12px;font-size:16px;color:#495057;padding-bottom:8px;border-bottom:1px solid #dee2e6}.info-section p{margin:8px 0;font-size:14px;color:#212529;display:flex;align-items:baseline;gap:8px}.info-section p strong{display:inline-block;min-width:80px;color:#6c757d;font-weight:500}.form-group{margin-bottom:12px}.form-group label{display:block;margin-bottom:4px;font-size:13px;color:#6c757d;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.status-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;display:inline-block}.status-badge.status-예약확정{background:#d4edda;color:#155724}.status-badge.status-입금대기{background:#fff3cd;color:#856404}.status-badge.status-예약취소{background:#f8d7da;color:#721c24}.sms-status-section{background:#f0f8ff;border:1px solid #b8daff}.sms-status-grid{display:grid;gap:12px;margin-top:12px}.sms-status-item{padding:10px;background:#fff;border-radius:6px;border:1px solid #dee2e6;display:flex;flex-direction:column;gap:8px}.sms-status-header{display:flex;justify-content:space-between;align-items:center;min-height:28px}.sms-type{font-size:13px;font-weight:600;color:#495057;display:flex;align-items:center;gap:6px}.sms-date{font-size:11px;font-weight:400;color:#6c757d;opacity:.9}.sms-badge{font-size:12px;padding:3px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px}.sms-badge.success{background:#d4edda;color:#155724}.sms-badge.error{background:#f8d7da;color:#721c24}.sms-badge.pending{background:#fff3cd;color:#856404}.sms-time{font-size:11px;opacity:.8}.btn-resend{padding:6px 14px;font-size:13px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;min-width:85px;font-weight:500}.btn-resend:hover:not(:disabled){background:#0056b3}.btn-resend:disabled{background:#6c757d;cursor:not-allowed;opacity:.7}.sms-log-info{margin-top:12px;padding:8px;background:#e7f3ff;border-radius:4px;font-size:12px}.sms-log-title{font-weight:600;margin-bottom:4px;color:#0056b3}.sms-log-item{margin:2px 0;color:#495057;font-family:monospace;font-size:11px}.option-list-vertical{margin-top:8px;margin-left:15px;display:flex;flex-direction:column;gap:6px}.option-item{padding:5px 10px;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:13px;border-left:3px solid #1976d2;display:inline-block;width:fit-content}.options-selection{display:flex;flex-direction:column;gap:10px;padding:10px;background:#f8f9fa;border-radius:6px;border:1px solid #dee2e6;max-height:200px;overflow-y:auto}.option-checkbox{display:flex;align-items:center;padding:8px;background:#fff;border-radius:4px;cursor:pointer;transition:background-color .2s;border:1px solid #e9ecef}.option-checkbox:hover{background:#f0f8ff;border-color:#b8daff}.option-checkbox input[type=checkbox]{width:auto;margin-right:10px;cursor:pointer}.option-label{display:flex;align-items:center;flex:1;font-size:14px;color:#212529}.option-price{margin-left:8px;font-size:13px;color:#6c757d;font-weight:500}.price-calculation{background:#f0f8ff;padding:10px;border-radius:4px;margin-bottom:10px;font-size:13px;color:#495057;border:1px solid #b8daff}.price-calculation div{margin:4px 0;display:flex;justify-content:space-between}.price-calculation div:last-child{padding-top:6px;border-top:1px solid #b8daff;color:#0056b3;font-size:14px}.option-tag{display:inline-block;padding:2px 6px;background:#e3f2fd;color:#1976d2;border-radius:3px;font-size:12px;margin:0 2px}.modal-footer{padding:15px 20px;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;border-radius:0 0 12px 12px}.status-buttons,.action-buttons{display:flex;gap:8px}.btn-status,.btn-edit,.btn-save,.btn-delete,.btn-cancel{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-confirm:hover:not(:disabled){background:#218838}.btn-cancel:hover:not(:disabled){background:#c82333}.btn-edit{background:#17a2b8;color:#fff}.btn-edit:hover:not(:disabled){background:#138496}.btn-save{background:#28a745;color:#fff}.btn-save:hover:not(:disabled){background:#218838}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover:not(:disabled){background:#c82333}button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.modal-header{padding:15px}.modal-header h2{font-size:18px}.modal-body{padding:15px}.info-section{padding:12px;margin-bottom:15px}.info-section h3{font-size:14px}.info-section p{font-size:13px}.info-section p strong{min-width:70px}.modal-footer{flex-direction:column;gap:10px;padding:12px 15px}.status-buttons,.action-buttons{width:100%;justify-content:center}.sms-status-header{flex-direction:column;align-items:flex-start;gap:6px}}.booking-source-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.5rem}@media (max-width: 768px){.booking-source-grid{grid-template-columns:repeat(2,1fr)}}.booking-source-item{position:relative;cursor:pointer;display:block}.booking-source-item input[type=radio]{position:absolute;opacity:0;width:0;height:0}.source-content{display:flex;align-items:center;gap:.5rem;padding:.75rem;border:2px solid #e0e0e0;border-radius:var(--radius-md);background:#fff;transition:all .2s ease}.booking-source-item:hover .source-content{border-color:var(--color-primary);background:#f0f7ff}.booking-source-item.selected .source-content{border-color:var(--color-primary);background:#e3f2fd}.source-icon{font-size:1.5rem;line-height:1}.source-name{font-size:.875rem;font-weight:500;color:var(--color-dark)}.source-badge{font-size:1.2rem;display:inline-block;vertical-align:middle;cursor:help}.daily-prices{margin-top:.5rem;padding:.5rem;background-color:#f0f7ff;border-radius:var(--radius-sm);font-size:.85rem}.daily-price-item{display:flex;justify-content:space-between;padding:.25rem 0;color:#666}.daily-price-item:not(:last-child){border-bottom:1px solid #e0e0e0}.stock-info-section{margin-top:1rem;padding:1rem;background-color:#f8f9fa;border-radius:var(--radius-md)}.stock-info-section label{display:block;margin-bottom:.75rem;font-size:.95rem;color:#333;font-weight:500}.daily-stock-list{display:flex;flex-direction:column;gap:.5rem}.daily-stock-item{display:flex;justify-content:space-between;padding:.5rem .75rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:var(--radius-sm);font-size:.875rem}.daily-stock-item.unavailable{background-color:#fee;border-color:#fcc}.stock-date{color:#666;font-weight:500}.stock-count{color:#2e7d32;font-weight:600}.stock-count.no-stock{color:var(--color-danger)}.form-group select option:disabled{color:#999;background-color:#f5f5f5}.new-reservation-modal{background:#fff;border-radius:var(--radius-lg);width:90%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 30px #0003;animation:slideUp .3s ease}.new-reservation-modal.mobile{width:100%;height:100vh;max-height:100vh;border-radius:0}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e0e0e0}.form-section:last-of-type{margin-bottom:1rem;border-bottom:none}.form-section h3{font-size:1.125rem;color:var(--color-dark);margin:0 0 1rem;font-weight:600}.form-group label{display:block;margin-bottom:.5rem;font-size:.95rem;color:#333;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:.95rem;transition:border-color .2s ease;background-color:#fff}.form-group input.error,.form-group select.error{border-color:var(--color-danger)}.error-message{display:block;color:var(--color-danger);font-size:.875rem;margin-top:.25rem}.options-list{display:flex;flex-direction:column;gap:.75rem}.option-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid #e0e0e0;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;position:relative;font-size:.875rem}.option-item:hover{background-color:#f8f9fa;border-color:var(--color-primary)}.option-item input[type=checkbox]{width:auto;margin:0}.option-label{flex:1;font-size:.8rem;color:#333}.option-note{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.7rem;padding:.25rem .5rem;border-radius:1rem;background-color:#e3f2fd;color:#1565c0;font-weight:500}.option-note.onsite{background-color:#fff3e0;color:#e65100;font-weight:600}.price-section{background-color:#f8f9fa;padding:1.5rem;border-radius:var(--radius-md);margin-top:1rem}.price-section h3{margin:0 0 1rem;font-size:1.125rem;color:var(--color-dark)}.price-details{display:flex;flex-direction:column;gap:.75rem}.price-row{display:flex;justify-content:space-between;align-items:center;font-size:.95rem;color:#666}.price-row.total{padding-top:.75rem;border-top:1px solid #dee2e6;font-size:1.125rem;font-weight:600;color:var(--color-dark)}.price-row.onsite{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #dee2e6;color:#e65100}.total-price{color:var(--color-primary);font-size:1.25rem}.onsite-price{color:#e65100;font-weight:600}@media (max-width: 768px){.new-reservation-modal{margin:0}.modal-body{padding:1rem}.form-row{grid-template-columns:1fr}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem}.price-section{padding:1rem}.option-note{position:static;display:block;margin-top:.25rem;width:fit-content}}button:disabled{opacity:.6;cursor:not-allowed}textarea{resize:vertical;min-height:80px}.reservation-calendar-container{width:100%;height:100%;background:#f5f7fa;padding:20px}.calendar-layout{min-width:0;width:100%;display:flex;gap:20px;height:100%}.calendar-main{flex:1 1 0;min-width:0;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.calendar-header{padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.calendar-header h2{margin:0;font-size:24px;font-weight:600}.calendar-content{flex:1;padding:20px;overflow:auto;min-width:0}.reservation-panel{width:380px;flex-shrink:0;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:15px 20px;background:linear-gradient(135deg,#56ccf2,#2f80ed);color:#fff;display:flex;align-items:center;gap:10px}.panel-header h3{margin:0;font-size:18px;font-weight:600;flex:1}.selected-date{font-size:14px;opacity:.9}.close-panel{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.panel-actions{padding:10px;border-bottom:1px solid #eee}.btn-add-reservation{width:100%;padding:10px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-add-reservation:hover{background:#218838}.reservation-list{flex:1;overflow-y:auto;padding:10px}.no-reservations{text-align:center;padding:40px 20px;color:#999}.reservation-card{background:#f8f9fa;border-radius:8px;padding:12px;margin-bottom:10px;cursor:pointer;transition:all .2s ease;border:1px solid #e9ecef}.reservation-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#667eea}.room-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:10px;border-bottom:2px solid #e9ecef}.room-name-large{font-size:16px;font-weight:700;padding:4px 8px;border-radius:4px;display:inline-block}.room-section .room-name-large{color:#fff}.reservation-card[data-room=Forest] .room-name-large{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.reservation-card[data-room="Forest mini"] .room-name-large{background:linear-gradient(135deg,#ec4899,#db2777)}.reservation-card[data-room="Forest 패밀리"] .room-name-large{background:linear-gradient(135deg,#3b82f6,#2563eb)}.reservation-card[data-room="Forest mini 패밀리"] .room-name-large{background:linear-gradient(135deg,#06b6d4,#0891b2)}.reservation-card[data-room=호수뷰객실] .room-name-large{background:linear-gradient(135deg,#f59e0b,#d97706)}.reservation-card[data-room=단체예약] .room-name-large{background:linear-gradient(135deg,#6366f1,#4f46e5)}.reservation-card:not([data-room]) .room-name-large{background:linear-gradient(135deg,#6b7280,#4b5563)}.customer-section{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:6px;background:#f1f5f9;border-radius:4px}.customer-name{font-weight:600;font-size:14px;color:#1e293b}.divider{color:#94a3b8;font-size:12px}.customer-phone{font-size:13px;color:#64748b}.booking-info{margin-bottom:8px}.info-row{display:flex;margin-bottom:4px;font-size:13px}.info-row .label{width:70px;color:#666;flex-shrink:0}.info-row .value{color:#333;flex:1}.info-row .value.memo{color:#666;font-style:italic}.options-section{margin:8px 0;padding:8px 0;border-top:1px solid #e9ecef;border-bottom:1px solid #e9ecef}.options-section .label{font-size:13px;color:#666;margin-bottom:6px;display:block}.options-list{display:flex;flex-wrap:wrap;gap:4px}.option-tag{font-size:11px;padding:3px 8px;border-radius:4px;display:inline-block}.option-tag.included{background:#e3f2fd;color:#1976d2}.option-tag.onsite{background:#fff3cd;color:#856404}.price-section{margin-top:8px;padding-top:8px;border-top:1px solid #e9ecef}.price-breakdown{display:flex;flex-direction:column;gap:3px;margin-bottom:6px;padding:4px 6px;background:#fef3c7;border-radius:4px;border-left:3px solid #fbbf24}.price-item{display:flex;justify-content:space-between;font-size:11px;color:#78350f}.price-item .label{color:#92400e}.price-item .value{font-weight:500}.price-row{display:flex;justify-content:space-between;margin-bottom:4px;font-size:13px}.price-row.total{font-weight:700;font-size:14px;color:#1e293b;padding:6px;background:#e0e7ff;border-radius:4px;margin-bottom:6px}.price-row.total .value{color:#4338ca}.price-row.onsite{color:#dc2626;padding:4px 6px;background:#fee2e2;border-radius:4px}.price-row .label{color:inherit}.price-row .value{font-weight:600}.action-section{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid #e9ecef}.status-badge{font-size:11px;padding:4px 8px;border-radius:4px;font-weight:600}.status-badge.예약확정{background:#d4edda;color:#155724}.status-badge.입금대기{background:#fff3cd;color:#856404}.status-badge.예약취소{background:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:4px}.btn-confirm,.btn-cancel{padding:4px 8px;font-size:11px;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:opacity .2s}.btn-confirm{background:#28a745;color:#fff}.btn-cancel{background:#dc3545;color:#fff}.btn-confirm:hover,.btn-cancel:hover{opacity:.8}.sms-status-icons{display:flex;gap:4px}.sms-icon{font-size:14px;cursor:help}.sms-icon.success{color:#28a745}.sms-icon.pending{color:#ffc107}.sms-icon.error{color:#dc3545}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.reservation-calendar-container{padding:0;height:auto;overflow-x:hidden}.calendar-layout{min-width:0;width:100%;flex-direction:column;height:auto;gap:0}.calendar-main{flex:1 1 0;border-radius:0;flex:none;box-shadow:none}.calendar-header{padding:8px;background:#f8f9fa}.calendar-header h2{font-size:14px}.calendar-content{padding:0;overflow:visible;flex:none}.reservation-panel{width:100%;border-radius:0;box-shadow:none;margin-top:0;border-top:1px solid #e0e0e0;background:#fff;position:relative;max-height:none;overflow:visible}.panel-header{padding:6px 10px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.panel-header h3{font-size:13px;color:#333}.selected-date{font-size:11px;color:#666}.panel-actions{padding:5px;border-bottom:1px solid #eee}.btn-add-reservation{padding:6px;font-size:12px;background:#28a745}.reservation-list{overflow:visible;max-height:none;padding:5px}.reservation-card{padding:8px;margin-bottom:6px;background:#fafafa;border:1px solid #e0e0e0;border-radius:4px}.room-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid #e0e0e0}.room-name-large{font-size:13px;font-weight:700}.customer-section{display:flex;align-items:center;gap:6px;margin-bottom:4px;padding:4px;background:#f1f5f9;border-radius:3px;font-size:11px}.customer-name{font-size:11px;font-weight:600;color:#1e293b}.divider{color:#94a3b8;font-size:10px}.customer-phone{font-size:10px;color:#64748b}.booking-info{margin-bottom:4px}.booking-main-line{display:flex;gap:10px;align-items:center;margin-bottom:3px;font-size:11px}.room-name-text{font-weight:600;color:#2c3e50}.guest-count-text{color:#7f8c8d;padding:1px 4px;background:#ecf0f1;border-radius:3px;font-size:10px}.date-text{color:#27ae60;font-weight:500}.memo-line{font-size:10px;color:#795548;margin-top:3px;padding:4px 6px;background:#fff9c4;border-left:3px solid #ffc107;border-radius:2px}.options-section{margin:3px 0;padding:0;border:none}.options-section .label{display:none}.options-list{display:inline-flex;gap:3px}.option-tag{font-size:8px;padding:1px 3px;border-radius:2px}.memo-line{font-size:9px;color:#666;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.price-section{margin-top:4px;padding-top:4px;border-top:1px solid #e0e0e0}.price-breakdown{display:flex;flex-direction:column;gap:2px;margin-bottom:4px;padding:3px 4px;background:#fef3c7;border-radius:3px;border-left:2px solid #fbbf24}.price-item{display:flex;justify-content:space-between;font-size:9px;color:#78350f}.price-item .label{color:#92400e;font-size:9px}.price-item .value{font-weight:500;font-size:9px}.price-row{display:flex;justify-content:space-between;font-size:10px;margin-bottom:3px}.price-row.total{font-size:11px;font-weight:700;color:#1e293b;padding:4px;background:#e0e7ff;border-radius:3px;margin-bottom:3px}.price-row.total .value{color:#4338ca;font-size:11px}.price-row.onsite{font-size:10px;color:#dc2626;padding:3px 4px;background:#fee2e2;border-radius:3px}.action-section{display:flex;justify-content:space-between;align-items:center;margin-top:3px;padding-top:3px;border-top:1px solid #eee}.status-badge{font-size:8px;padding:2px 4px;border-radius:2px}.action-buttons{display:flex;gap:3px}.btn-confirm,.btn-cancel{padding:2px 5px;font-size:8px;border-radius:2px}.sms-status-icons{display:inline-flex;gap:2px}.sms-icon{font-size:10px}}.modal-backdrop{position:fixed;inset:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-out}.cancel-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;z-index:1001;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.cancel-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.cancel-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:4px 8px;transition:color .2s}.close-btn:hover{color:#333}.cancel-modal-body{flex:1;overflow-y:auto;padding:24px}.reservation-info-section,.refund-policy-section,.refund-calculation,.cancel-reason-section{margin-bottom:24px}.cancel-modal-body h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#333}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;background:#f8f9fa;padding:16px;border-radius:8px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item .label{font-size:.875rem;color:#666}.info-item .value{font-size:1rem;font-weight:500;color:#333}.policy-alert{display:flex;align-items:center;gap:8px;padding:12px;background:#e3f2fd;border:1px solid #2196f3;border-radius:8px;margin-bottom:16px}.alert-icon{font-size:1.2rem}.policy-table{overflow:hidden;border-radius:8px;border:1px solid #e0e0e0}.policy-table table{width:100%;border-collapse:collapse}.policy-table th{background:#f5f5f5;padding:12px;text-align:left;font-weight:600;font-size:.875rem;color:#333;border-bottom:1px solid #e0e0e0}.policy-table td{padding:10px 12px;font-size:.875rem;border-bottom:1px solid #f0f0f0}.policy-table tr:last-child td{border-bottom:none}.policy-table tr.current{background:#fff3e0;font-weight:600}.calculation-details{background:#f8f9fa;padding:16px;border-radius:8px}.calc-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:.95rem}.calc-row.cancellation-fee{color:#d32f2f}.calc-row.total{border-top:2px solid #e0e0e0;padding-top:12px;margin-top:8px;font-weight:600;font-size:1.1rem}.amount{font-weight:500}.amount.negative{color:#d32f2f}.amount.highlight{color:#2196f3;font-size:1.2rem}.rate{font-weight:600;color:#2196f3}.cancel-reason-section textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;resize:vertical;font-family:inherit;font-size:.95rem}.cancel-reason-section textarea:focus{outline:none;border-color:#2196f3}.warning-message{display:flex;align-items:center;gap:8px;padding:12px;background:#ffebee;border:1px solid #f44336;border-radius:8px;color:#c62828;font-size:.9rem;font-weight:500}.warning-icon{font-size:1.2rem}.cancel-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e0e0e0;background:#f8f9fa}.btn-secondary,.btn-danger{padding:10px 24px;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary{background:#fff;color:#333;border:1px solid #ddd}.btn-secondary:hover{background:#f5f5f5}.btn-danger{background:#d32f2f;color:#fff}.btn-danger:hover:not(:disabled){background:#c62828;transform:translateY(-1px);box-shadow:0 2px 8px #d32f2f4d}.btn-danger:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.cancel-modal{width:95%;max-height:95vh}.cancel-modal-header,.cancel-modal-body,.cancel-modal-footer{padding:16px}.info-grid{grid-template-columns:1fr}.policy-table{font-size:.85rem}.calc-row{font-size:.9rem}.btn-secondary,.btn-danger{padding:8px 20px;font-size:.95rem}}.modal-body span{background:transparent!important;background-color:transparent!important}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.options-detail{display:flex;flex-direction:column;gap:.375rem;margin-top:.25rem}.option-item{display:flex;align-items:center;gap:.5rem;padding:.375rem;background:#f0f7ff;border-radius:6px;font-size:.875rem}.option-icon{font-size:1.125rem;flex-shrink:0}.option-name{font-weight:500;color:#333;flex:1}.option-price{font-size:.8125rem;color:#666;white-space:nowrap}.options-edit-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto;padding:.5rem;background:#f8f9fa;border-radius:6px}.option-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;transition:background-color .2s;border-radius:4px}.option-checkbox:hover{background-color:#e3f2fd}.option-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.option-checkbox span{font-size:.875rem;color:#333}@media (max-width: 768px){.options-detail{gap:.25rem;margin-top:.125rem}.option-item{flex-direction:column;align-items:flex-start;padding:.375rem;font-size:.8125rem;gap:.125rem}.option-icon{display:none}.option-name{font-size:.8125rem;font-weight:600}.option-price{font-size:.75rem;margin-left:.5rem}}.modal-container{background:#fff;border-radius:var(--radius-lg);width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 30px #0003;animation:slideUp .3s ease}.modal-header h2{margin:0;font-size:1.5rem;color:var(--color-dark)}.modal-close{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:2rem;color:#999;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease}.modal-close:hover{background-color:#f0f0f0;color:#666}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.status-badge{display:inline-block;padding:4px 12px;border-radius:16px;font-size:.875rem;font-weight:600;background:#f3f4f6;color:#374151}.status-badge.large{font-size:1rem;padding:6px 16px}.status-badge.status-예약확정{background:#10b981;color:#fff}.status-badge.status-입금대기,.status-badge.status-이체대기{background:#f59e0b;color:#fff}.status-badge.status-예약취소{background:#ef4444;color:#fff}.booking-status-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #f0f0f0}.status-badge.large{font-size:1.125rem;padding:.5rem 1.5rem;border-radius:2rem}.booking-id{font-size:.875rem;color:#666}.status-info{display:flex;flex-direction:column;gap:.25rem}.source-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600}.info-section{margin-bottom:2rem}.info-section:last-child{margin-bottom:0}.info-section h3{font-size:1.125rem;color:var(--color-dark);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f8f9fa;background:transparent!important;background-color:transparent!important}.info-row:last-child{border-bottom:none}.info-row.small{padding:.5rem 0}.info-label{font-size:.95rem;color:#666!important;font-weight:500;background:transparent!important;background-color:transparent!important}.info-value{font-size:.95rem;color:#333!important;font-weight:600;background:transparent!important;background-color:transparent!important}.info-value.price{font-size:1.125rem;color:var(--color-primary)}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-size:.95rem;color:#666;font-weight:500}.form-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:.95rem;transition:border-color .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary)}textarea.form-input{resize:vertical;min-height:80px}.memo-text{margin:0;padding:1rem;background-color:#f8f9fa;border-radius:var(--radius-md);color:#666;font-size:.95rem;line-height:1.5}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-top:1px solid #e0e0e0;background-color:#f8f9fa}.footer-left,.footer-right{display:flex;gap:.75rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-primary:hover:not(:disabled){background-color:var(--color-secondary)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.customer-detail{background:#f5f5f5;border-left:4px solid var(--color-primary)}.customer-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.stat-item{text-align:center;padding:.75rem;background:#fff;border-radius:var(--radius-sm)}.stat-label{display:block;font-size:.75rem;color:#666!important;margin-bottom:.25rem;background:transparent!important;background-color:transparent!important}.stat-value{display:block;font-size:1.125rem;font-weight:600;color:#333!important;background:transparent!important;background-color:transparent!important}.customer-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}@media (max-width: 768px){.modal-container{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:0;display:flex;flex-direction:column}.modal-overlay{padding:0}.modal-header{padding:.375rem .625rem;position:sticky;top:0;background:#fff;z-index:10;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 2px #00000008}.modal-header h2{font-size:1rem;font-weight:600}.modal-close{width:1.75rem;height:1.75rem;font-size:1.25rem}.modal-body{padding:.25rem;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.booking-status-section{flex-direction:column;gap:.125rem;align-items:flex-start;margin-bottom:.25rem;padding:.25rem;background:#f8f9fa;border-radius:6px;border-bottom:none}.status-badge.large{font-size:.9375rem;padding:.375rem .75rem}.booking-id{font-size:.6875rem;color:#888}.info-section{margin-bottom:.1875rem;padding:.25rem;background:#fff;border:1px solid #e8e8e8;border-radius:6px;box-shadow:0 1px 2px #00000008}.info-section h3{font-size:.8125rem;margin-bottom:.125rem;padding-bottom:0;color:#1976d2;font-weight:600;border-bottom:none}.info-row{flex-direction:row;justify-content:space-between;align-items:center;padding:.125rem 0;gap:.25rem;border-bottom:none}.info-label{font-size:.8125rem;color:#666!important;font-weight:600;min-width:70px;flex-shrink:0;background:transparent!important;background-color:transparent!important}.info-value{font-size:.8125rem;font-weight:600;color:#333!important;text-align:right;flex:1;word-break:break-word;background:transparent!important;background-color:transparent!important}.info-value.price{font-size:1.125rem;color:#e74c3c;font-weight:700}.form-group{margin-bottom:.25rem}.form-group label{font-size:.8125rem;font-weight:600;color:#555;margin-bottom:.125rem}.form-input{padding:.625rem;font-size:.9375rem;border:1px solid #e0e0e0;background:#f8f9fa}.form-input:focus{border-color:#1976d2;background:#fff}.memo-text{padding:.5rem;font-size:.8125rem;line-height:1.4;background:#f8f9fa}.customer-detail{background:transparent;border:none;border-radius:0;padding:.25rem;margin-bottom:.25rem;box-shadow:none;border-left:2px solid #1565C0;margin-left:.25rem}.customer-detail h3{color:#1565c0;font-size:.8125rem;margin-bottom:.125rem;font-weight:600}.customer-stats{grid-template-columns:repeat(3,1fr);gap:.125rem;margin-bottom:0}.stat-item{padding:.25rem .125rem;background:transparent;border:none;border-radius:0;box-shadow:none;text-align:center}.stat-item:active{transform:scale(.98)}.stat-label{font-size:.625rem;color:#888!important;margin-bottom:0;font-weight:400;line-height:1;display:block;background:transparent!important;background-color:transparent!important}.stat-value{font-size:.875rem;font-weight:700;color:#1565c0!important;line-height:1.2;display:block;background:transparent!important;background-color:transparent!important}.customer-badge{display:inline-block;margin-left:4px;padding:1px 4px;border-radius:6px;font-size:.5625rem;font-weight:600;white-space:nowrap}.modal-footer{position:sticky;bottom:0;padding:.25rem;background:#fff;border-top:1px solid #e0e0e0;box-shadow:0 -1px 3px #0000000d;gap:.125rem;flex-direction:column}.footer-left,.footer-right{width:100%;justify-content:stretch;gap:.25rem}.footer-right{flex-wrap:wrap}.btn{flex:1;padding:.625rem .875rem;font-size:.8125rem;font-weight:600;border-radius:6px;min-width:0}.btn-danger{flex:0 0 auto;min-width:80px}.btn-secondary{background-color:#e0e0e0;color:#333}.btn-secondary:hover:not(:disabled){background-color:#d0d0d0}.info-section:last-child{background:#fafafa;border:1px dashed #ddd;margin-bottom:0;padding:.25rem}.info-section:last-child h3{font-size:.75rem;color:#666;margin-bottom:.125rem}.info-row.small{padding:.125rem 0}.info-row.small .info-label,.info-row.small .info-value{font-size:.6875rem}.customer-detail .info-row{padding:.125rem 0}.customer-detail .info-row .info-label{font-size:.625rem;color:#1565c0;font-weight:500;min-width:30px}.customer-detail .info-row .info-value{font-size:.625rem;color:#333}.form-group{margin-bottom:.1875rem}.memo-text{padding:.5rem;font-size:.8125rem;line-height:1.4}.customer-extra-info{margin-top:.125rem;padding-top:.125rem;border-top:1px dashed #e0e0e0}.info-row.compact{padding:.0625rem 0}.info-row.compact .info-label{font-size:.625rem;min-width:30px}.info-row.compact .info-value{font-size:.625rem}.info-section:nth-of-type(2),.info-section:nth-of-type(3){padding-top:.1875rem;padding-bottom:.1875rem;margin-bottom:.125rem}.info-section:nth-of-type(2) h3,.info-section:nth-of-type(3) h3{font-size:.8125rem;margin-bottom:.0625rem}.info-section:nth-of-type(2) .info-row,.info-section:nth-of-type(3) .info-row{padding:.0625rem 0}.customer-history-inline{margin-top:.125rem;padding-top:.125rem;border-top:1px solid #e0e0e0}.customer-stats-inline{display:flex;justify-content:space-between;gap:.25rem;margin-bottom:.125rem}.customer-stats-inline .stat-item{flex:1;display:flex;align-items:center;gap:.125rem;padding:0;background:transparent;border:none;min-width:0;overflow:hidden}.customer-stats-inline .stat-label{font-size:.625rem;color:#888;font-weight:400;margin:0}.customer-stats-inline .stat-value{font-size:.8125rem;font-weight:600;color:#333;margin:0;white-space:nowrap}}@media (max-width: 375px){.modal-header{padding:.375rem .5rem}.modal-header h2{font-size:1rem}.modal-body{padding:.25rem}.info-section{padding:.1875rem;margin-bottom:.125rem}.info-section h3{font-size:.75rem;margin-bottom:.1875rem}.info-row{padding:.0625rem 0}.info-label{font-size:.75rem;min-width:60px;color:#666!important;background:transparent!important;background-color:transparent!important}.info-value{font-size:.75rem;color:#333!important;background:transparent!important;background-color:transparent!important}.customer-detail{padding:.25rem}.stat-item{padding:.25rem .125rem}.stat-label{font-size:.5625rem;color:#888!important}.stat-value{font-size:.75rem;color:#333!important}.modal-footer{padding:.25rem}.btn{padding:.625rem .75rem;font-size:.8125rem}.form-input{padding:.5rem;font-size:.875rem}.customer-stats-inline .stat-label{font-size:.5625rem}.customer-stats-inline .stat-value{font-size:.75rem}}.date-detail-backdrop{position:fixed;inset:0;background:#0000004d;z-index:999;animation:fadeIn .3s ease-out}.date-detail-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -2px 10px #0000001a;transition:transform .3s ease;z-index:1000;display:flex;flex-direction:column;border-top-left-radius:20px;border-top-right-radius:20px;transform:translateY(0);max-height:80vh;overflow:hidden}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.date-detail-panel{animation:slideUp .3s ease-out}.date-detail-panel.mobile{max-height:80vh}.date-detail-panel.desktop{position:fixed;inset:60px 20px 20px;max-height:calc(100vh - 100px);width:calc(100% - 40px);transform:none;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.date-detail-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #e0e0e0;background:#fff;z-index:10;flex-shrink:0}.date-detail-panel.desktop .date-detail-header{padding:18px 24px;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;border-radius:12px 12px 0 0}.date-detail-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#2c3e50}.close-button{background:none;border:none;font-size:24px;cursor:pointer;padding:5px 10px;color:#666;transition:color .2s}.close-button:hover{color:#333}.date-detail-body{display:flex;flex:1;overflow:hidden;height:calc(100% - 80px);background:#fff;border-radius:0 0 12px 12px}.date-detail-panel.desktop .date-summary{width:350px;padding:32px;background:#f8f9fa;border-right:2px solid #e0e0e0;overflow-y:auto;flex-shrink:0}.date-summary h4{margin:0 0 24px;font-size:1.25rem;font-weight:600;color:#2c3e50}.summary-content{display:flex;flex-direction:column;gap:12px}.summary-item{display:flex;justify-content:space-between;align-items:center;font-size:1.05rem;padding:8px 0}.room-summary{padding-left:16px;color:#666}.summary-label{font-weight:500}.summary-value{font-weight:700;font-size:1.1rem;color:#2196f3}.summary-divider{height:1px;background:#e0e0e0;margin:8px 0}.room-details{flex:1;padding:24px;overflow-y:auto;min-width:0}.date-detail-panel.mobile .room-details{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:16px;align-content:start}.date-detail-panel.desktop .room-details{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px;align-content:start;padding:32px}.date-detail-panel.desktop .mobile-summary{display:none}.mobile-summary{display:flex;justify-content:space-around;padding:8px 12px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;font-size:.85rem}.summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-label{color:#666;font-weight:500;font-size:.7rem}.stat-value{color:#2196f3;font-weight:700;font-size:.9rem}.date-detail-panel.mobile .attachment-info{font-size:11px!important}.date-detail-panel.mobile .memo-text{font-size:11px!important;line-height:1.4}.room-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:12px;transition:box-shadow .2s;display:flex;flex-direction:column}.date-detail-panel.mobile .room-card{margin-bottom:0;padding:10px}.room-card:hover{box-shadow:0 2px 8px #00000014}.room-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #f0f0f0}.date-detail-panel.mobile .room-card-header{flex-direction:row;align-items:center;padding-bottom:4px;margin-bottom:6px}.room-title{display:flex;align-items:center;gap:8px}.room-icon{font-size:1.2rem}.room-title h4{margin:0;font-size:1.15rem;font-weight:600;color:#2c3e50}.date-detail-panel.mobile .room-title h4{font-size:.95rem;font-weight:700;color:#1976d2}.room-price{font-size:1.15rem;font-weight:700;color:#2196f3}.room-inventory{font-size:.85rem;color:#666;margin-bottom:8px;padding:6px 10px;background:#e3f2fd;border-radius:6px;display:inline-block;font-weight:600}.date-detail-panel.mobile .room-inventory{width:100%;text-align:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #90caf9;margin-bottom:4px;font-size:.7rem;padding:3px 6px}.reservations-list{margin:8px 0;border-top:1px solid #f0f0f0;padding-top:8px}.reservation-list-header{font-size:.75rem;color:#666;font-weight:600;margin-bottom:4px;padding:4px 4px 2px;border-bottom:1px solid #e8e8e8}.date-detail-panel.mobile .reservations-list{margin-top:6px;max-height:100px;overflow-y:auto;border:1px solid #e8e8e8;border-radius:6px;padding:3px;background:#fafafa}.date-detail-panel.mobile .reservations-list::-webkit-scrollbar{width:4px}.date-detail-panel.mobile .reservations-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.date-detail-panel.mobile .reservation-item{background:#fff;border:1px solid #e0e0e0;border-radius:4px;padding:4px;margin-bottom:3px}.date-detail-panel.mobile .reservation-item:last-child{margin-bottom:0}.date-detail-panel.mobile .reservation-header{padding:3px;margin-bottom:0;font-size:.75rem}.date-detail-panel.mobile .guest-name{font-size:.75rem;font-weight:600;color:#333;flex:1}.date-detail-panel.mobile .reservation-main-info{width:100%}.date-detail-panel.mobile .status-dot{width:6px;height:6px}.no-reservations{text-align:center;padding:8px;color:#999;font-size:.8rem;background:#f8f8f8;border-radius:6px;margin:6px 0}.date-detail-panel.mobile .no-reservations{padding:6px;font-size:.75rem}.reservation-item{border-left:3px solid #e0e0e0;padding-left:12px;margin-bottom:8px}.reservation-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:12px;transition:background .2s;border-radius:8px;margin-bottom:8px}.date-detail-panel.desktop .reservation-header:hover{background:#f0f7ff;transform:translate(4px)}.reservation-main-info{display:flex;align-items:center;gap:8px}.guest-name{font-weight:600;font-size:1rem;color:#2c3e50}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.expand-icon{font-size:.8rem;color:#666;margin-left:8px}.reservation-info-wrapper{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.reservation-quick-info{display:flex;align-items:center;gap:8px}.phone-info{font-size:.9rem;color:#666;margin-left:12px}.memo-preview{font-size:.85rem;color:#666;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;padding:4px 8px;background:#f8f9fa;border-radius:4px}.source-icon{font-size:1rem}.option-icons{display:flex;gap:4px}.option-icon{font-size:.9rem}.reservation-options{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.option-item{display:inline-flex;align-items:center;gap:2px;padding:2px 5px!important;border-radius:3px;font-size:.65rem!important;font-weight:500;line-height:1.2}.option-label{font-size:.6rem!important;font-weight:600}.option-note{font-size:.55rem!important;opacity:.8}.option-item.included,.option-included{background:linear-gradient(135deg,#e3f2fd,#bbdefb)!important;color:#0d47a1!important;border:1px solid #64b5f6;box-shadow:0 1px 2px #2196f333}.option-item.onsite,.option-onsite{background:linear-gradient(135deg,#fff3e0,#ffe0b2)!important;color:#bf360c!important;border:1px solid #ff9800;box-shadow:0 1px 2px #ff980033}.date-detail-panel.mobile .option-item{font-size:.6rem!important;padding:1px 4px!important}.date-detail-panel.mobile .option-label{font-size:.55rem!important}.date-detail-panel.mobile .option-note{font-size:.5rem!important}.guest-count{font-size:.9rem;color:#666;padding:2px 6px;background:#f0f0f0;border-radius:4px;margin-left:4px}.reservation-details{padding:12px;background:#f8f9fa;border-radius:8px;margin-top:8px;animation:slideDown .2s ease}.detail-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;padding:0 4px}.detail-row:last-child{margin-bottom:0}.detail-icon{font-size:1rem;min-width:20px}.memo-text{color:#666;font-size:.9rem;line-height:1.5;word-break:break-word}.mobile-actions{margin-top:12px;display:flex;justify-content:flex-end}.room-actions{display:flex;gap:4px;margin-top:auto;padding-top:6px}.fully-booked-message{width:100%;text-align:center;padding:8px 12px;background-color:#f5f5f5;color:#666;border-radius:4px;font-size:14px;font-weight:500}.action-btn{flex:1;padding:5px;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s;background:#f0f0f0;color:#333;display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px}.action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.reserve-btn{background:#4caf50;color:#fff}.reserve-btn:hover{background:#45a049}.block-btn{background:#ff9800;color:#fff}.block-btn:hover{background:#f57c00}.detail-btn{background:#2196f3;color:#fff;font-size:.85rem;padding:6px 16px;min-width:auto}.detail-btn:hover{background:#1976d2}.date-detail-body ::-webkit-scrollbar{width:6px}.date-detail-body ::-webkit-scrollbar-track{background:#f1f1f1}.date-detail-body ::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.date-detail-body ::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.date-detail-panel{height:auto;max-height:85vh}.date-detail-header{padding:16px 20px}.date-detail-header h3{font-size:1.25rem}.date-detail-body{max-height:calc(85vh - 120px);overflow-y:auto}@media (max-width: 380px){.date-detail-panel.mobile .room-details{grid-template-columns:1fr}}}.mobile-menu-overlay{display:none;position:fixed;inset:0;background-color:#0009;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.mobile-menu{position:fixed;top:0;left:-320px;width:280px;height:100vh;background:linear-gradient(180deg,#fff,#f8f9fa);box-shadow:4px 0 12px #00000026;transition:left .3s cubic-bezier(.4,0,.2,1);z-index:201;display:none;flex-direction:column}.mobile-menu.open{left:0}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 2px 8px #0000001a}.mobile-menu-header h2{margin:0;font-size:1.125rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:.5rem}.menu-header-icon{font-size:1.25rem}.mobile-menu-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;font-size:1.25rem;color:#fff;cursor:pointer;border-radius:50%;transition:all .2s ease}.mobile-menu-close:hover{background:#fff3;transform:rotate(90deg)}.mobile-menu-nav{flex:1;overflow-y:auto;padding:.75rem 0;background:#fff}.mobile-menu-item{width:100%;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:none;border:none;font-size:.95rem;color:#52525b;cursor:pointer;transition:all .2s ease;text-align:left;position:relative}.mobile-menu-item:hover{background:linear-gradient(90deg,rgba(74,144,226,.08) 0%,transparent 100%);color:#18181b}.mobile-menu-item.active{background:linear-gradient(90deg,#4a90e226,#4a90e20d);color:#4a90e2;font-weight:600}.mobile-menu-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:4px;background:#4a90e2;border-radius:0 2px 2px 0}.mobile-menu-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:inherit;opacity:.8}.mobile-menu-item:hover .mobile-menu-icon,.mobile-menu-item.active .mobile-menu-icon{opacity:1}.mobile-menu-label{flex:1;font-weight:500}.mobile-menu-badge{padding:2px 6px;background:#ef4444;color:#fff;font-size:.625rem;font-weight:600;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.mobile-menu-footer{padding:1rem 1.5rem;border-top:1px solid #E4E4E7;background:#fafafa}.mobile-menu-version{margin:0;font-size:.75rem;color:#a1a1aa;text-align:center}.mobile-menu-nav::-webkit-scrollbar{width:4px}.mobile-menu-nav::-webkit-scrollbar-track{background:transparent}.mobile-menu-nav::-webkit-scrollbar-thumb{background:#d4d4d8;border-radius:2px}.mobile-menu-nav::-webkit-scrollbar-thumb:hover{background:#a1a1aa}@media (max-width: 768px){.mobile-menu-overlay{display:block}.mobile-menu{display:flex}}@media (max-width: 360px){.mobile-menu{width:260px;left:-280px}.mobile-menu-item{padding:.875rem 1.25rem}.mobile-menu-header{padding:1rem 1.25rem}}.options-settings{max-width:1400px;margin:0 auto;background:#fff;padding:2rem;border-radius:12px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.settings-header h2{margin:0;color:#1f2937;font-size:1.75rem;font-weight:600;white-space:nowrap}.option-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0}.option-tabs button{padding:.75rem 1.5rem;border:none;background:none;color:#4b5563;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent;margin-bottom:-2px}.option-tabs button:hover{color:var(--color-primary)}.option-tabs button.active{color:#2d5016;border-bottom-color:#2d5016;font-weight:600}.btn-add{padding:.5rem 1rem;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.25rem;box-shadow:0 2px 4px #4a90e233}.btn-add:hover{background:linear-gradient(135deg,#357abd,#2563eb);transform:translateY(-1px);box-shadow:0 4px 8px #4a90e24d}.btn-add-text-short{display:none}.btn-add-text-full{display:inline}.options-section{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.options-section h3{margin:0 0 1.5rem;color:#1f2937;font-weight:600}.option-card{background:#fff;border-radius:var(--radius-md);padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1rem;transition:all .2s ease;border:1px solid #e0e0e0}.option-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.option-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.option-header h4{margin:0;color:var(--color-dark);font-size:1.125rem;flex:1}.option-badges{display:flex;gap:.5rem;align-items:center}.option-type{display:inline-block;padding:.375rem .75rem;border-radius:2rem;font-size:.813rem;font-weight:500}.option-type.included{background:#e8f5e9;color:#2e7d32}.option-type.onsite{background:#fff3e0;color:#f57c00}.option-type.late_checkout{background:#e3f2fd;color:#1565c0}.option-type.custom{background:#f3e5f5;color:#7b1fa2}.room-badge{display:inline-block;padding:.375rem .75rem;background:#f5f5f5;color:#666;border-radius:2rem;font-size:.813rem;font-weight:500}.option-actions{display:flex;gap:.5rem}.option-actions button,.btn-edit{padding:.375rem .75rem;border:none;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s ease}.option-actions button:first-child,.btn-edit{background:#e0e0e0;color:var(--color-dark)}.option-actions button:first-child:hover,.btn-edit:hover{background:#d0d0d0}.btn-delete{background:var(--color-danger);color:#fff}.btn-delete:hover{background:#d32f2f}.option-details{font-size:.875rem;color:#666}.option-details p{margin:.5rem 0}.description{margin:0 0 .5rem}.room-info{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.selected-rooms{font-size:.875rem;color:#666}.individual-info strong,.shared-info strong{font-weight:600;color:var(--color-dark)}.room-settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem;margin-top:.5rem}.room-setting-item{padding:.375rem .75rem;background:#f8f9fa;border-radius:var(--radius-sm);font-size:.813rem}.shared-info{font-size:.875rem;color:#666}.shared-info small{color:#999}.room-mapping-section{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.room-mapping-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.room-mapping-card{border:1px solid #e0e0e0;border-radius:var(--radius-md);padding:1.5rem;background:#fafafa}.room-mapping-card h4{margin:0 0 1rem;color:var(--color-dark);font-size:1.125rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-primary)}.applied-options{display:flex;flex-direction:column;gap:.5rem}.applied-option{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#fff;border-radius:var(--radius-sm);font-size:.875rem}.option-name{font-weight:500;color:var(--color-dark)}.option-value{color:var(--color-primary);font-weight:600}.modal-content{background:#fff;border-radius:var(--radius-lg);padding:2rem;max-width:700px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003}.option-form{max-height:70vh;overflow-y:auto;padding-right:.5rem}.form-group{margin-bottom:1.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:.95rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.room-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#f8f9fa;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.checkbox-label:hover{background:#e8f5e9}.checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer}.individual-settings{display:grid;gap:.75rem}.room-setting{display:grid;grid-template-columns:150px 1fr;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:var(--radius-sm)}.room-name{font-weight:500;color:var(--color-dark)}.room-setting input{max-width:150px}.mt-3{margin-top:1rem}.btn-save,.btn-cancel{padding:.5rem 1.5rem;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-save{background-color:var(--color-primary);color:#fff}.btn-cancel{background-color:#e0e0e0;color:var(--color-dark)}.btn-save:hover{background-color:var(--color-secondary)}.btn-cancel:hover{background-color:#d0d0d0}.info-section{background:#f8f9fa;padding:1.5rem;border-radius:var(--radius-md);margin-bottom:1.5rem}.info-section h3{margin:0 0 1rem;color:var(--color-dark);font-size:1.125rem}.extra-charges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.charge-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border-radius:var(--radius-sm)}.charge-item .room-name{font-weight:500;color:var(--color-dark)}.charge-item .price{color:var(--color-primary);font-weight:600}@media (max-width: 768px){.settings-header{flex-wrap:nowrap;margin-bottom:1.5rem}.settings-header h2{font-size:1.25rem;flex:1}.btn-add{padding:.5rem .875rem;font-size:.875rem;white-space:nowrap}.btn-add-text-full{display:none}.btn-add-text-short{display:inline}.options-section{padding:1rem}.option-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;margin-bottom:1rem}.option-tabs::-webkit-scrollbar{display:none}.option-tabs button{padding:.625rem 1rem;font-size:.875rem;white-space:nowrap}.room-mapping-grid,.room-checkboxes{grid-template-columns:1fr}.option-header{flex-direction:column}.option-badges{flex-wrap:wrap}.option-type,.room-badge{font-size:.75rem;padding:.25rem .5rem}.option-card{padding:1rem}.modal-content{padding:1.5rem;width:95%}}@media (max-width: 480px){.settings-header h2{font-size:1.125rem}.btn-add{padding:.375rem .75rem;font-size:.813rem}.option-tabs button{padding:.5rem .75rem;font-size:.813rem}.option-type,.room-badge{font-size:.688rem;padding:.188rem .375rem}}.pricing-settings{max-width:1400px;margin:0 auto;background:#fff;padding:2rem;border-radius:12px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.settings-header h2{margin:0;color:#1f2937;font-size:1.75rem;font-weight:600}.price-info{display:flex;gap:1rem}.info-badge{padding:.5rem 1rem;border-radius:2rem;font-size:.875rem;font-weight:500}.info-badge.weekday{background:#e3f2fd;color:#1565c0}.info-badge.weekend{background:#fce4ec;color:#c2185b}.pricing-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0}.pricing-tabs button{padding:.75rem 1.5rem;border:none;background:none;color:#4b5563;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent;margin-bottom:-2px}.pricing-tabs button:hover{color:var(--color-primary)}.pricing-tabs button.active{color:#2d5016;border-bottom-color:#2d5016;font-weight:600}.price-setting-section{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h3{margin:0;color:#1f2937;font-weight:600}.room-price-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.room-price-card{border:1px solid #e0e0e0;border-radius:var(--radius-md);padding:1.5rem;background:#f8f9fa}.room-price-card h4{margin:0 0 1rem;color:var(--color-dark);font-size:1.125rem}.price-inputs{display:grid;gap:1rem}.price-input-group{display:flex;flex-direction:column;gap:.5rem}.price-input-group label{font-size:.875rem;color:#666;font-weight:500}.price-input-group input{padding:.75rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:1rem;transition:border-color .2s ease}.price-input-group input:focus{outline:none;border-color:var(--color-primary)}.holidays-section{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.header-controls{display:flex;gap:1rem;align-items:center}.year-selector{padding:.5rem 1rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:1rem}.holidays-info{background:#f8f9fa;padding:1.5rem;border-radius:var(--radius-md);margin-bottom:2rem}.holidays-info p{margin:0 0 .5rem;font-weight:500;color:var(--color-dark)}.holidays-info ul{margin:0;padding-left:1.5rem;color:#666}.holidays-info li{margin:.25rem 0}.holidays-list h4{margin:1.5rem 0 1rem;color:var(--color-dark)}.holiday-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1.5rem}.holiday-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:var(--radius-sm);font-size:.875rem}.holiday-item.default{background:#e8f5e9;color:#2e7d32}.holiday-item.custom{background:#e3f2fd;color:#1565c0}.holiday-date{font-weight:600;font-family:monospace}.holiday-name{flex:1}.btn-remove{padding:.25rem .5rem;background:#0000001a;border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer}.price-calendar-section{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.price-calendar-section h3{margin:0 0 1.5rem;color:var(--color-dark)}.price-calendar{max-width:1000px;margin:0 auto}.room-selector{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:var(--radius-md)}.room-selector label{font-weight:500;color:var(--color-dark)}.room-select{padding:.5rem 1rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:1rem;background:#fff;cursor:pointer}.calendar-header{display:flex;justify-content:center;align-items:center;gap:2rem;margin-bottom:1.5rem}.nav-btn{width:44px;height:44px;border:none;background:var(--color-primary);color:#fff;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.nav-btn:hover{background:var(--color-secondary);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.nav-btn:active{transform:translateY(0)}.calendar-header h4{margin:0;color:var(--color-dark);font-size:1.5rem;font-weight:600;min-width:150px;text-align:center}.calendar-wrapper{background:#fff;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000001a;overflow:hidden;border:1px solid #e0e0e0}.weekday-headers{display:grid;grid-template-columns:repeat(7,1fr);background:#f8f9fa;border-bottom:2px solid #e0e0e0}.weekday-header{padding:1rem;text-align:center;font-weight:600;font-size:.875rem;color:#666;border-right:1px solid #e0e0e0}.weekday-header:last-child{border-right:none}.weekday-header.sunday{color:#d32f2f}.weekday-header.saturday{color:#1976d2}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);background:#fff}.calendar-day{min-height:120px;border-right:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;padding:.75rem;position:relative;transition:all .2s ease;cursor:pointer;display:flex;flex-direction:column}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover:not(.empty){background-color:#00000005;z-index:1;box-shadow:0 2px 8px #0000001a}.calendar-day.empty{background:#fafafa;cursor:default}.calendar-day.weekday{background:#fff}.calendar-day.weekend{background:#fef8e7}.calendar-day.today{box-shadow:inset 0 0 0 2px var(--color-primary)}.day-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.day-number{font-weight:600;font-size:1rem;line-height:1}.calendar-day.sunday .day-number{color:#d32f2f}.calendar-day.saturday .day-number{color:#1976d2}.holiday-marker{font-size:1rem;cursor:help}.day-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.price-display{font-weight:600;color:var(--color-dark);margin-bottom:.25rem}.price-amount{font-size:1.125rem}.price-unit{font-size:.75rem;color:#666;margin-left:.125rem}.holiday-name{font-size:.75rem;color:#e91e63;line-height:1.2;word-break:keep-all}.price-type-badge{position:absolute;bottom:.5rem;right:.5rem;padding:.25rem .5rem;border-radius:1rem;font-size:.625rem;font-weight:600;text-transform:uppercase}.calendar-day.weekday .price-type-badge{background:#e3f2fd;color:#1565c0}.calendar-day.weekend .price-type-badge{background:#fce4ec;color:#c2185b}.calendar-footer{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem}.calendar-legend{display:flex;gap:1.5rem;align-items:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666}.legend-color{width:24px;height:24px;border-radius:var(--radius-sm);border:1px solid #e0e0e0}.legend-color.weekday{background:#fff}.legend-color.weekend{background:#fef8e7}.legend-icon{font-size:1.25rem}.price-summary{display:flex;gap:2rem;align-items:center}.summary-item{display:flex;align-items:center;gap:.5rem}.summary-label{font-weight:500;color:#666}.summary-value{font-weight:600;font-size:1.125rem;color:var(--color-dark)}@media (max-width: 768px){.price-calendar{padding:0}.room-selector{flex-direction:column;align-items:stretch}.room-select{width:100%}.calendar-header{gap:1rem}.calendar-header h4{font-size:1.25rem}.calendar-day{min-height:90px;padding:.5rem}.price-amount{font-size:.875rem}.holiday-name{display:none}.calendar-footer{flex-direction:column}.calendar-legend{flex-wrap:wrap}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:var(--radius-lg);padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003}.modal-content.compact{max-width:400px}.modal-content h3{margin:0 0 1.5rem;color:var(--color-dark)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-dark);font-size:.95rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:var(--radius-md);font-size:.95rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:2rem}.btn-add,.btn-save,.btn-cancel,.btn-edit,.btn-delete{padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-add,.btn-save{background-color:var(--color-primary);color:#fff}.btn-cancel,.btn-edit{background-color:#e0e0e0;color:var(--color-dark)}.btn-delete{background-color:var(--color-danger);color:#fff}.btn-add:hover,.btn-save:hover{background-color:var(--color-secondary)}.rules-section{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.rules-list{display:grid;gap:1.5rem}.rule-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .3s ease}.rule-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.rule-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-bottom:1px solid #e5e7eb}.rule-info h4{margin:0;color:#1e40af;font-size:1.25rem;font-weight:600}.rule-period{display:inline-flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.375rem .75rem;background:#fff;border-radius:20px;font-size:.875rem;color:#64748b;font-weight:500}.rule-period:before{content:"📅";font-size:1rem}.rule-actions{display:flex;gap:.5rem}.rule-actions .btn-edit,.rule-actions .btn-delete{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.rule-actions .btn-edit{background:#fff;color:#3b82f6;border:1px solid #dbeafe}.rule-actions .btn-edit:hover{background:#dbeafe;transform:translateY(-1px)}.rule-actions .btn-delete{background:#fff;color:#ef4444;border:1px solid #fee2e2}.rule-actions .btn-delete:hover{background:#fee2e2;transform:translateY(-1px)}.rule-details{padding:1.5rem}.season-prices{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.room-season-price{background:#f8fafc;padding:1.25rem;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s}.room-season-price:hover{background:#f1f5f9;border-color:#cbd5e1}.room-season-price h5{margin:0 0 .75rem;color:#1e293b;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.room-season-price h5:before{content:"🏠";font-size:1.125rem}.season-price-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.9rem}.season-price-row:first-of-type{border-bottom:1px solid #e2e8f0}.price-label{color:#64748b;font-weight:500}.price-value{font-weight:700;color:#0f172a;font-size:1rem}.empty-rules{text-align:center;padding:4rem 2rem;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0}.empty-rules p{margin:.5rem 0;color:#64748b;font-size:1rem}.empty-description{font-size:.9rem;margin-bottom:2rem;color:#94a3b8}.btn-add-first{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:.875rem 1.75rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #3b82f64d}.btn-add-first:before{content:"✨";font-size:1.125rem}.btn-add-first:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.season-price-inputs{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.season-price-inputs h4{margin:0 0 1.5rem;color:#1e293b;font-size:1.125rem}.room-season-input{margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.room-season-input h5{margin:0 0 1rem;color:#334155;font-size:1rem;font-weight:600}.season-input-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.section-header .btn-add{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;box-shadow:0 2px 8px #10b9814d}.section-header .btn-add:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.input-with-currency{position:relative;display:flex;align-items:center}.input-with-currency input{padding-right:2.5rem;width:100%}.input-with-currency .currency{position:absolute;right:1rem;color:#64748b;font-weight:500;pointer-events:none}.price-preview{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0;display:grid;gap:.5rem}.preview-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0}.preview-label{color:#64748b;font-size:.875rem}.preview-price{font-weight:600;color:#0f172a;font-size:1rem}.preview-item.extra .preview-price{color:#f59e0b}.room-info{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #e2e8f0}.room-specs{display:flex;gap:1rem;margin-top:.5rem}.room-capacity,.room-inventory{font-size:.875rem;color:#64748b;display:flex;align-items:center;gap:.25rem}.room-capacity:before{content:"👥"}.room-inventory:before{content:"📦"}@media (max-width: 768px){.pricing-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.room-price-grid{grid-template-columns:1fr}.price-info{flex-direction:column;gap:.5rem}.header-controls{flex-direction:column;width:100%}.year-selector{width:100%}.calendar-day{font-size:.75rem}.day-info{flex-direction:column}.season-prices,.form-row,.season-input-row{grid-template-columns:1fr}}.data-initializer{display:flex;justify-content:center;align-items:center;min-height:400px;padding:20px}.initializer-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px;max-width:500px;width:100%}.initializer-card h2{margin:0 0 10px;color:#333;font-size:24px}.initializer-card>p{color:#666;margin-bottom:20px}.data-preview{background:#f8f9fa;border-radius:8px;padding:20px;margin-bottom:20px}.data-preview h3{margin:0 0 10px;font-size:16px;color:#555}.data-preview ul{margin:0;padding-left:20px}.data-preview li{margin:5px 0;color:#666}.error-message{background:#fee;color:#c33;padding:10px 15px;border-radius:6px;margin-bottom:20px;font-size:14px}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:20px}.progress-fill{height:100%;background:#4caf50;transition:width .3s ease}.btn-initialize{width:100%;padding:12px 24px;background:#2196f3;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.btn-initialize:hover{background:#1976d2}.btn-initialize:disabled{background:#ccc;cursor:not-allowed}.room-management{background-color:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md)}.management-header{margin-bottom:2rem;position:relative}.management-header h2{margin:0 0 .5rem;color:var(--color-primary)}.info-text{margin:0;color:#666;font-size:.95rem}.add-room-btn{position:absolute;top:0;right:0;padding:.75rem 1.5rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s ease}.add-room-btn:hover{background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.room-card{border:1px solid #e0e0e0;border-radius:var(--radius-md);padding:1.5rem;background-color:#f8f9fa;transition:all .2s ease}.room-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.add-room-card{background-color:#f0f8ff;border:2px dashed var(--color-primary)}.add-room-card:hover{background-color:#e8f4f8}.required{color:#dc3545;font-weight:700}.room-card h3{margin:0 0 1rem;color:var(--color-primary);font-size:1.2rem}.view-mode .info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item .label{font-size:.875rem;color:#666;font-weight:500}.info-item .value{font-size:1rem;color:var(--color-dark);font-weight:600}.room-description{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.room-description p{margin:0;color:#666;line-height:1.5}.edit-mode .form-section{margin-bottom:1.5rem}.form-section h4{margin:0 0 .75rem;font-size:1rem;color:#666;font-weight:600}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#666}.form-group input,.form-group textarea{padding:.5rem;border:1px solid #ddd;border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.form-group small{font-size:.8rem;color:#999}.form-group small.warning-text{color:#ff9800;font-weight:500}.form-group textarea{resize:vertical;min-height:60px}.card-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.btn{padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-edit{background-color:var(--color-primary);color:#fff}.btn-edit:hover{background-color:var(--color-primary-dark)}.btn-save{background-color:var(--color-success);color:#fff}.btn-save:hover:not(:disabled){background-color:#218838}.btn-cancel{background-color:#6c757d;color:#fff}.btn-cancel:hover{background-color:#5a6268}.btn-delete{background-color:#dc3545;color:#fff}.btn-delete:hover:not(:disabled){background-color:#c82333}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;color:#666;font-size:1.1rem}.room-card .drag-handle{cursor:move;color:#999;font-size:1.2rem;margin-right:.5rem}.room-card.dragging{opacity:.5}@media (max-width: 768px){.room-management{padding:1rem}.rooms-grid{grid-template-columns:1fr;gap:1rem}.view-mode .info-grid,.form-row{grid-template-columns:1fr}.card-actions{flex-direction:column}.btn{width:100%}.add-room-btn{position:static;width:100%;margin-top:1rem}}.reservation-list{width:100%;height:100%;background-color:#fff;color:var(--text-primary, #374151);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;display:block!important}.reservation-list .list-controls{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center}.reservation-list .search-input{flex:1 1 300px;max-width:400px;min-width:200px;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9rem;transition:all .2s}.reservation-list .search-input:focus{outline:none;border-color:#2d5016;box-shadow:0 0 0 3px #2d50161a}.reservation-list .filter-select{flex:0 0 auto;min-width:120px;max-width:160px;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer;transition:all .2s}.reservation-list .filter-select:focus{outline:none;border-color:#2d5016;box-shadow:0 0 0 3px #2d50161a}.reservation-list .date-input{padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer;transition:all .2s}.reservation-list .date-input:focus{outline:none;border-color:#2d5016;box-shadow:0 0 0 3px #2d50161a}.reservation-list .reservation-table-wrapper{width:100%;background:#fff;color:var(--text-primary, #374151);border-radius:8px;border:1px solid #e0e0e0;overflow:hidden;display:block!important;position:relative}.reservation-list .reservation-table{width:100%;overflow-x:auto;overflow-y:visible;display:block!important}.reservation-list table{width:100%;min-width:950px;border-collapse:collapse;border-spacing:0;table-layout:auto;display:table!important}.reservation-list thead{display:table-header-group!important;background:linear-gradient(to bottom,#f8f9fa,#f3f4f6);border-bottom:2px solid #dee2e6}.reservation-list tbody{display:table-row-group!important}.reservation-list tr{display:table-row!important}.reservation-list th,.reservation-list td{display:table-cell!important;vertical-align:middle}.reservation-list th{padding:1rem .75rem;text-align:left;font-weight:600;font-size:.85rem;color:#495057;white-space:nowrap;position:sticky;top:0;background:#f8f9fa;z-index:1;border-bottom:2px solid #dee2e6}.reservation-list th:nth-child(1){min-width:85px}.reservation-list th:nth-child(2){min-width:75px}.reservation-list th:nth-child(3){min-width:95px}.reservation-list th:nth-child(4){min-width:45px}.reservation-list th:nth-child(5){min-width:75px}.reservation-list th:nth-child(6){min-width:45px}.reservation-list th:nth-child(7){min-width:85px}.reservation-list th:nth-child(8){min-width:85px}.reservation-list th:nth-child(9){min-width:100px}.reservation-list th:nth-child(10){min-width:75px}.reservation-list th:nth-child(11){min-width:90px}.reservation-list th:nth-child(12){min-width:75px}.reservation-list tbody tr{background:#fff;color:var(--text-primary, #374151);border-bottom:1px solid #f0f0f0;transition:background-color .15s}.reservation-list tbody tr:hover{background-color:#f9fafb;cursor:pointer}.reservation-list tbody tr:last-child{border-bottom:none}.reservation-list td{padding:.875rem .5rem;font-size:.875rem;color:#374151;vertical-align:middle;border-bottom:1px solid #f0f0f0}.reservation-list td:nth-child(2),.reservation-list td:nth-child(3),.reservation-list td:nth-child(5){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reservation-list .status-badge{display:inline-block;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600;white-space:nowrap}.reservation-list .status-입금대기{background:#fef3c7;color:#92400e}.reservation-list .status-예약확정{background:#d1fae5;color:#065f46}.reservation-list .status-예약취소{background:#fee2e2;color:#991b1b}.reservation-list .source-badge{font-size:1.25rem;display:inline-block;vertical-align:middle}.reservation-list td:nth-child(4){text-align:center}.reservation-list td:nth-child(6){text-align:center}.reservation-list .action-buttons{display:flex;gap:.375rem;flex-wrap:wrap}.reservation-list .btn-confirm,.reservation-list .btn-cancel{padding:.375rem .625rem;border:none;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.reservation-list .btn-confirm{background:#10b981;color:var(--text-inverse)}.reservation-list .btn-confirm:hover{background:#059669;transform:translateY(-1px)}.reservation-list .btn-cancel{background:#ef4444;color:var(--text-inverse)}.reservation-list .btn-cancel:hover{background:#dc2626;transform:translateY(-1px)}.reservation-list .status-cell{display:flex;flex-direction:column;gap:.25rem}.reservation-list .refund-info{display:flex;align-items:center;gap:.25rem;font-size:.7rem;color:#6b7280}.reservation-list .refund-label{color:#9ca3af}.reservation-list .refund-amount{font-weight:600;color:#3b82f6}.reservation-list .refund-rate{color:#9ca3af}.reservation-list .price-cell{display:flex;flex-direction:column;gap:.125rem}.reservation-list .total-price{font-weight:600;color:#1f2937;white-space:nowrap}.reservation-list .cancellation-fee{font-size:.7rem;color:#ef4444;white-space:nowrap}.reservation-list .guests-info{white-space:nowrap;text-align:center}.reservation-list .options-info{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.reservation-list .options-list{font-size:.8125rem;color:#6b7280;line-height:1.4;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reservation-list td:nth-child(9){position:relative}.reservation-list td:nth-child(9):has(.options-list:not(:empty)){cursor:help}.reservation-list td:nth-child(9):hover .options-list:not(:empty){overflow:visible;white-space:normal;word-break:break-word;position:absolute;background:#fff;border:1px solid #e5e7eb;padding:.5rem;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:100;min-width:200px;max-width:300px;left:50%;transform:translate(-50%);top:calc(100% + 4px)}.reservation-list td:nth-child(9):hover .options-list:not(:empty):before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #e5e7eb}.reservation-list td:nth-child(9):hover .options-list:not(:empty):after{content:"";position:absolute;top:-7px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid white}.reservation-list .options-list:empty:before{content:"-";color:#9ca3af;display:block;text-align:center}.reservation-list .empty-reservations{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#9ca3af}.reservation-list .empty-icon{font-size:3.5rem;margin-bottom:1rem;opacity:.5}.reservation-list .empty-text{font-size:1.125rem;color:#6b7280;margin:0}.reservation-list .reservation-cards{display:none}@media (max-width: 1024px){.reservation-list .list-controls{flex-wrap:wrap}.reservation-list .search-input{flex:1 1 100%;max-width:none}.reservation-list .filter-select{flex:1 1 auto}}@media (max-width: 768px){.reservation-list{padding:1rem;border-radius:0;box-shadow:none}.reservation-list .list-controls{display:flex;flex-direction:column;gap:.75rem}.reservation-list .search-input{width:100%;padding:.75rem 1rem;font-size:.9rem}.reservation-list .filter-container{display:flex;gap:.5rem;width:100%}.reservation-list .filter-select{flex:1;padding:.625rem .75rem;font-size:.875rem;min-width:unset;max-width:none}.reservation-list .date-filter-container{display:flex;flex-direction:column;gap:.5rem;width:100%}.reservation-list .date-filter{width:100%}.reservation-list .custom-date-inputs{display:flex;gap:.5rem;align-items:center}.reservation-list .date-input{flex:1;padding:.625rem .75rem;font-size:.875rem}.reservation-list .date-separator{color:#6b7280;font-weight:500}.reservation-list .reservation-table-wrapper{display:none!important}.reservation-list .reservation-cards{display:flex;flex-direction:column;gap:.75rem}.reservation-list .reservation-card{background:#fff;color:var(--text-primary, #374151);border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.reservation-list .card-header{padding:.75rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:flex-start}.reservation-list .card-date-room{flex:1}.reservation-list .card-room{font-size:1rem;font-weight:700;color:#2d5016;display:block;margin-bottom:.25rem}.reservation-list .card-check-date{font-size:.8125rem;color:#6b7280}.reservation-list .card-body{padding:.75rem}.reservation-list .card-customer{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.reservation-list .customer-info{flex:1}.reservation-list .customer-name{font-weight:600;color:#1f2937;display:block}.reservation-list .customer-phone{font-size:.875rem;color:#6b7280}.reservation-list .source-badge-mobile{font-size:1.5rem}.reservation-list .card-details{display:flex;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.reservation-list .detail-item{display:flex;align-items:center;gap:.375rem}.reservation-list .detail-label{font-size:.8125rem;color:#6b7280}.reservation-list .detail-value{font-size:.875rem;font-weight:600;color:#1f2937}.reservation-list .options-item{flex:1 1 100%}.reservation-list .card-price{display:flex;justify-content:space-between;align-items:center;padding:.625rem;background:#f0f9ff;border-radius:6px;margin:.75rem 0}.reservation-list .price-label{font-size:.875rem;color:#6b7280}.reservation-list .price-value{font-size:1.125rem;font-weight:700;color:#2d5016}.reservation-list .card-footer{padding:.75rem;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#f9fafb}.reservation-list .card-meta{flex:1}.reservation-list .meta-label{font-size:.75rem;color:#9ca3af;display:block}.reservation-list .meta-value{font-size:.875rem;color:#4b5563;font-weight:500}.reservation-list .card-actions{display:flex;gap:.5rem}.reservation-list .cancellation-fee-mobile{font-size:.75rem;color:#ef4444;margin-top:.375rem}}@media (min-width: 1400px){.reservation-list .search-input{flex:0 1 450px}.reservation-list table{min-width:1200px}.reservation-list th,.reservation-list td{padding:1rem}.reservation-list th,.reservation-list td{font-size:.9rem}}.reservation-list .reservation-table::-webkit-scrollbar{height:8px}.reservation-list .reservation-table::-webkit-scrollbar-track{background:#f9fafb;border-radius:4px}.reservation-list .reservation-table::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.reservation-list .reservation-table::-webkit-scrollbar-thumb:hover{background:#9ca3af}.reservation-list *{grid-column:unset!important;grid-row:unset!important}.blocked-ip-manager{max-width:1400px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px}.manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.manager-header h2{margin:0;color:#1f2937;font-size:1.75rem;font-weight:600}.btn-refresh{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#2d5016;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-refresh:hover{background:#3a6620;transform:translateY(-1px);box-shadow:0 2px 4px #2d501633}.ip-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;gap:1rem;transition:all .3s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-icon{font-size:2.5rem;opacity:.8}.stat-content{flex:1}.stat-value{font-size:2rem;font-weight:700;color:#1f2937;line-height:1}.stat-label{font-size:.875rem;color:#666;margin-top:.25rem}.ip-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;margin-bottom:2rem}.ip-table{width:100%;border-collapse:collapse}.ip-table thead{background:#f8f9fa;border-bottom:2px solid #e9ecef}.ip-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:#495057;white-space:nowrap}.ip-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.ip-table tbody tr:hover{background:#f9fafb}.ip-table td{padding:1rem;font-size:.875rem;color:#374151}.ip-address{font-family:Courier New,monospace;font-weight:600;color:#1f2937}.reason-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff}.permanent-badge{color:#dc3545;font-weight:700;font-size:1.125rem}.temporary-badge{color:#6c757d;font-weight:700;font-size:1.125rem}.btn-unblock{padding:.5rem 1rem;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-unblock:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.btn-unblock:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.empty-message{text-align:center;padding:3rem;color:#6c757d;font-style:italic}.ip-info-panel{background:#f8f9fa;border-radius:12px;padding:2rem;border:1px solid #e9ecef}.ip-info-panel h3{margin:0 0 1rem;color:#1f2937;font-size:1.125rem;font-weight:600}.ip-info-panel ul{margin:0;padding-left:1.5rem;color:#495057;line-height:1.8}.ip-info-panel li{margin-bottom:.5rem}.error-message{background:#fee;color:#dc3545;padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media (max-width: 768px){.blocked-ip-manager{padding:1rem}.manager-header{flex-direction:column;gap:1rem;align-items:stretch}.btn-refresh{justify-content:center}.ip-stats{grid-template-columns:1fr}.ip-table-container{overflow-x:auto}.ip-table{min-width:700px}}.room-notification-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px;transition:all .3s ease}.room-notification-card.expanded{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.room-card-header{padding:16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f3f4f6}.room-info{display:flex;align-items:center;gap:20px}.room-info h4{margin:0;font-size:16px;font-weight:600;color:#111827}.room-enable-switch{position:relative;display:inline-flex;align-items:center;cursor:pointer}.room-enable-switch input{position:absolute;opacity:0;width:0;height:0}.switch-slider{position:relative;display:inline-block;width:44px;height:24px;background-color:#cbd5e1;border-radius:12px;transition:background-color .2s}.switch-slider:before{content:"";position:absolute;width:20px;height:20px;left:2px;top:2px;background-color:#fff;border-radius:50%;transition:transform .2s}.room-enable-switch input:checked+.switch-slider{background-color:#3b82f6}.room-enable-switch input:checked+.switch-slider:before{transform:translate(20px)}.switch-label{margin-left:8px;font-size:14px;color:#6b7280}.expand-button{padding:6px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s}.expand-button:hover{background:#f3f4f6;border-color:#d1d5db}.room-card-content{padding:20px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.template-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid #e5e7eb}.template-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;font-size:14px;color:#6b7280;cursor:pointer;transition:all .2s}.template-tab:hover{color:#374151;background:#f9fafb}.template-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab-icon{font-size:16px}.tab-label{font-weight:500}.template-editor-section{margin-bottom:24px}.editor-header{display:flex;gap:12px;margin-bottom:12px}.template-title{flex:1;padding:8px 12px;font-size:14px;font-weight:500;border:1px solid #d1d5db;border-radius:6px;background:#f9fafb}.template-title:focus{outline:none;border-color:#3b82f6;background:#fff}.reset-button{padding:8px 12px;background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;font-size:16px;cursor:pointer;transition:all .2s}.reset-button:hover{background:#fecaca;border-color:#f87171}.editor-content{display:grid;grid-template-columns:1fr 1fr;gap:20px}.editor-column,.preview-column{display:flex;flex-direction:column}.editor-column h5,.preview-column h5{margin:0 0 8px;font-size:13px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.template-editor{flex:1;padding:12px;font-family:Consolas,Monaco,monospace;font-size:13px;line-height:1.5;border:1px solid #d1d5db;border-radius:6px;resize:vertical;min-height:300px;background:#f9fafb}.template-editor:focus{outline:none;border-color:#3b82f6;background:#fff}.variable-helper{margin-top:12px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px}.helper-label{display:block;margin-bottom:8px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase}.variable-chips{display:flex;flex-wrap:wrap;gap:6px}.variable-chip{padding:4px 10px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;font-size:12px;color:#1e40af;cursor:pointer;transition:all .2s}.variable-chip:hover{background:#dbeafe;border-color:#93c5fd;transform:translateY(-1px)}.template-preview{flex:1;padding:12px;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;min-height:300px;overflow-y:auto}.preview-title{margin-bottom:12px;padding-bottom:8px;font-size:14px;font-weight:600;color:#111827;border-bottom:1px solid #e5e7eb}.preview-content{font-size:13px;line-height:1.6;color:#374151;white-space:pre-wrap;word-break:break-word}.auto-send-section{margin-top:24px;padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px}.auto-send-section h5{margin:0 0 16px;font-size:14px;font-weight:600;color:#111827}.auto-send-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.auto-send-item{display:flex;flex-direction:column;gap:8px}.auto-send-item label{display:flex;align-items:center;gap:8px;font-size:14px;color:#374151;cursor:pointer}.auto-send-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}.time-setting{display:flex;align-items:center;gap:8px;margin-left:24px;font-size:13px;color:#6b7280}.time-setting input[type=number]{width:50px;padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;text-align:center}.time-setting input[type=number]:focus{outline:none;border-color:#3b82f6}.time-setting input:disabled{background:#f3f4f6;cursor:not-allowed}.room-card-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.btn{padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s}.btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-primary{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}@media (max-width: 1024px){.editor-content,.auto-send-grid{grid-template-columns:1fr}}@media (max-width: 768px){.room-card-header{flex-direction:column;align-items:flex-start;gap:12px}.room-info{width:100%;justify-content:space-between}.expand-button{width:100%}.template-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.variable-chips{max-height:100px;overflow-y:auto}.room-card-actions{flex-direction:column}.btn{width:100%}}.notification-settings{padding:2rem;max-width:1200px;margin:0 auto;background:#fff;border-radius:12px}.notification-settings h2{font-size:1.75rem;font-weight:600;color:#1f2937;margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}.settings-section{margin-bottom:40px}.settings-section h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.settings-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.form-group input[type=password]{font-family:monospace}.checkbox-group{display:flex;gap:24px;margin-bottom:20px}.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.btn-primary{background:#2d5016;color:#fff}.btn-primary:hover:not(:disabled){background:#3a6620;transform:translateY(-1px);box-shadow:0 2px 4px #2d501633}.auto-send-item{padding:16px;background:#f9f9f9;border-radius:4px;margin-bottom:16px}.auto-send-item label{display:flex;align-items:center;gap:12px;font-weight:500;margin-bottom:12px}.time-setting{display:flex;align-items:center;gap:8px;margin-left:30px;font-size:14px}.time-setting input{width:60px;padding:6px 8px;border:1px solid #ddd;border-radius:4px;text-align:center}.time-setting input:disabled{background:#f0f0f0;color:#999}.time-info{margin-left:30px;font-size:13px;color:#666;font-style:italic}.settings-info{background:#f0f7ff;border:1px solid #b3d9ff;border-radius:8px;padding:20px;margin-top:40px}.settings-info h4{font-size:16px;margin-bottom:12px;color:#06c}.settings-info ul{margin:0;padding-left:20px}.settings-info li{margin-bottom:8px;color:#555;font-size:14px;line-height:1.6}@media (max-width: 768px){.notification-settings,.settings-card{padding:16px}.checkbox-group{flex-direction:column;gap:12px}.button-group{flex-direction:column}.btn{width:100%}.time-setting{margin-left:0;margin-top:8px}}.global-settings-section{margin-bottom:32px;padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.global-settings-section h3{margin-top:0;margin-bottom:20px;font-size:18px;color:#111827;display:flex;align-items:center;gap:8px}.global-settings-section h4{margin-top:20px;margin-bottom:12px;font-size:15px;color:#374151;font-weight:600}.room-settings-section{margin-top:32px}.room-settings-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.room-settings-section h3{margin:0;font-size:18px;color:#111827;display:flex;align-items:center;gap:8px}.room-cards-container{display:flex;flex-direction:column;gap:16px}.message-templates{padding:20px;max-width:1400px;margin:0 auto}.message-templates h2{font-size:24px;margin-bottom:30px;display:flex;align-items:center;gap:10px}.template-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e0e0e0}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .3s;margin-bottom:-2px}.tab-button:hover{color:#333}.tab-button.active{color:#4a90e2;border-bottom-color:#4a90e2}.template-editor{display:grid;grid-template-columns:1fr 1fr;gap:24px}.editor-section,.preview-section{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.editor-section h3,.preview-section h3{font-size:18px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e0e0e0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .3s}.form-group textarea{resize:vertical;min-height:200px;line-height:1.5}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.variable-info{background:#f9f9f9;border-radius:4px;padding:16px;margin-bottom:20px}.variable-info h4{font-size:14px;font-weight:500;margin-bottom:12px;color:#555}.variable-list{display:flex;flex-wrap:wrap;gap:8px}.variable{display:inline-block;padding:4px 8px;background:#fff;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:12px;color:#4a90e2}.button-group{display:flex;gap:12px;justify-content:flex-end}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-primary{background:#4a90e2;color:#fff}.btn-primary:hover:not(:disabled){background:#357abd}.btn-secondary{background:#f5f5f5;color:#333;border:1px solid #ddd}.btn-secondary:hover:not(:disabled){background:#e8e8e8}.preview-settings{margin-bottom:24px}.preview-settings h4{font-size:14px;font-weight:500;margin-bottom:12px;color:#555}.preview-form{display:grid;grid-template-columns:1fr 1fr;gap:8px}.preview-form input{padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:12px}.phone-mockup{background:#f5f5f5;border-radius:20px;padding:20px;box-shadow:0 4px 12px #0000001a;max-width:320px;margin:0 auto}.phone-screen{background:#fff;border-radius:12px;padding:16px;min-height:400px}.message-bubble{background:#e3f2fd;border-radius:12px;padding:12px 16px;margin-bottom:8px;position:relative}.message-bubble:before{content:"";position:absolute;top:0;left:-8px;width:0;height:0;border-style:solid;border-width:0 10px 10px 0;border-color:transparent #e3f2fd transparent transparent}.message-bubble pre{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;color:#333}.message-info{display:flex;justify-content:flex-end;padding:8px}.char-count{font-size:12px;color:#666;background:#f0f0f0;padding:4px 8px;border-radius:4px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #4A90E2;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 1024px){.template-editor{grid-template-columns:1fr}.preview-section{position:sticky;top:20px}}@media (max-width: 768px){.message-templates{padding:16px}.template-tabs{overflow-x:auto;white-space:nowrap}.tab-button{padding:10px 16px;font-size:13px}.editor-section,.preview-section{padding:16px}.preview-form{grid-template-columns:1fr}.button-group{flex-direction:column}.btn{width:100%}}.monthly-stats-input{padding:20px;background:#f8f9fa;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.business-selector{display:flex;gap:10px;margin-bottom:20px;padding:15px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.business-tab{flex:1;padding:12px 24px;border:2px solid #ecf0f1;background:#fff;border-radius:8px;font-size:16px;font-weight:600;color:#7f8c8d;cursor:pointer;transition:all .3s ease}.business-tab:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.business-tab.active{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border-color:#2980b9;box-shadow:0 2px 6px #3498db4d}.business-tab.integrated{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff;border-color:#8e44ad}.business-tab.integrated:hover{transform:translateY(-2px);box-shadow:0 4px 12px #9b59b64d}.stats-header{margin-bottom:30px;padding:20px 30px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;min-height:40px}.stats-header h2{margin:0;color:#2c3e50;font-size:24px;font-weight:700;flex:1}.period-selector{display:flex;align-items:center;gap:8px;background:#f8f9fa;padding:5px;border-radius:8px}.nav-btn{padding:8px 14px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;min-width:70px}.nav-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.year-select,.month-select{padding:8px 12px;border:2px solid #ecf0f1;border-radius:6px;font-size:14px;font-weight:600;background:#fff;cursor:pointer;transition:all .3s ease;min-width:80px}.year-select:hover,.month-select:hover{border-color:#3498db}.year-select:focus,.month-select:focus{outline:none;border-color:#2980b9;box-shadow:0 0 0 3px #3498db1a}.header-info{display:flex;align-items:center;gap:15px}.auto-indicator{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;box-shadow:0 2px 6px #27ae604d}.save-button{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px #3498db4d}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3498db66}.save-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.stats-grid{display:grid;grid-template-columns:1fr;gap:25px}.stats-section{background:#fff;border-radius:12px;padding:25px 30px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.stats-section:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.stats-section h3{margin:0 0 20px;font-size:20px;font-weight:700;color:#2c3e50;border-bottom:2px solid #ecf0f1;padding-bottom:10px}.auto-section{background:linear-gradient(135deg,#e8f8f5,#d5f4e6);border:2px solid #27ae60}.auto-section h3{color:#27ae60;border-bottom-color:#27ae60}.auto-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.auto-stat-item{background:#fff;padding:20px;border-radius:8px;text-align:center;box-shadow:0 2px 6px #27ae601a}.auto-stat-item label{display:block;font-size:14px;color:#7f8c8d;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.auto-value{font-size:24px;font-weight:700;color:#27ae60;margin:0}.manual-section{background:#fff}.input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.input-group{display:flex;flex-direction:column}.input-group label{font-size:14px;font-weight:600;color:#2c3e50;margin-bottom:8px;display:flex;flex-direction:column;gap:4px}.help-text{font-size:12px;color:#7f8c8d;font-weight:400;font-style:italic}.input-group input{padding:12px 16px;border:2px solid #ecf0f1;border-radius:8px;font-size:16px;transition:all .3s ease;background:#f8f9fa}.input-group input:focus{outline:none;border-color:#3498db;background:#fff;box-shadow:0 0 0 3px #3498db1a}.performance-tabs{display:grid;gap:25px}.performance-section h4{margin:0 0 15px;font-size:16px;font-weight:600;color:#34495e;padding:10px 15px;background:#f8f9fa;border-radius:6px;border-left:4px solid #3498db}.calculated-section{background:linear-gradient(135deg,#fff9e6,#fef5e7);border:2px solid #f39c12}.calculated-section h3{color:#f39c12;border-bottom-color:#f39c12}.calculated-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.calculated-item{background:#fff;padding:16px;border-radius:8px;text-align:center;box-shadow:0 2px 6px #f39c121a;transition:all .3s ease}.calculated-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f39c1233}.calculated-item label{display:block;font-size:12px;color:#7f8c8d;font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.calculated-value{font-size:18px;font-weight:700;color:#f39c12;margin:0}.roi-value{font-size:20px!important;color:#e67e22!important}.monthly-stats-loading{display:flex;justify-content:center;align-items:center;height:400px;font-size:18px;color:#7f8c8d;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}@media (max-width: 768px){.monthly-stats-input{padding:15px}.stats-header{padding:20px}.header-top{flex-direction:column;gap:15px;text-align:center}.stats-header h2{font-size:24px}.period-selector{width:100%;justify-content:center;flex-wrap:wrap}.nav-btn,.year-select,.month-select{padding:6px 10px;font-size:12px}.header-info{width:100%;justify-content:center}.stats-section{padding:20px}.input-grid,.auto-stats-grid{grid-template-columns:1fr}.calculated-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.stats-header h2{font-size:20px}.auto-indicator{font-size:12px;padding:6px 12px}.calculated-grid{grid-template-columns:1fr}.auto-value{font-size:20px}.calculated-value{font-size:16px}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.stats-section{animation:slideInUp .5s ease-out}.input-group input:focus,.save-button:focus{outline:none;box-shadow:0 0 0 3px #3498db33}@media (prefers-reduced-motion: reduce){.stats-section,.calculated-item,.save-button{transition:none;animation:none}.stats-section:hover,.calculated-item:hover,.save-button:hover{transform:none}}.integrated-stats-view{padding:20px;background:#f5f5f5;min-height:100vh}.integrated-stats-loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:18px;color:#666}.stats-header{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center}.stats-header h2{margin:0;font-size:24px;color:#333}.period-selector{display:flex;align-items:center;gap:10px}.nav-btn{background:#007bff;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer;transition:background-color .3s}.nav-btn:hover{background:#0056b3}.year-select,.month-select{padding:8px 12px;border:1px solid #ddd;border-radius:5px;font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.stats-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.stats-card h3{margin:0 0 20px;font-size:18px;color:#333;padding-bottom:10px;border-bottom:2px solid #f0f0f0}.stats-row{display:flex;gap:20px;flex-wrap:wrap}.stat-item{flex:1;min-width:120px}.stat-item label{display:block;font-size:12px;color:#666;margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:20px;font-weight:700;color:#333}.stat-value.primary{color:#007bff;font-size:24px}.stat-value.roi-value{color:#28a745}.pension-breakdown{margin-top:20px;padding-top:15px;border-top:1px solid #f0f0f0}.breakdown-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.pension-label{font-size:14px;color:#666;flex:1}.pension-value{font-size:16px;font-weight:700;color:#333;margin:0 10px}.pension-count{font-size:12px;color:#999}.ad-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px;margin-top:15px}.ad-item{display:flex;flex-direction:column;padding:10px;background:#f8f9fa;border-radius:8px}.ad-platform{font-size:12px;color:#666;margin-bottom:5px}.ad-value{font-size:14px;font-weight:700;color:#333}.status-row{display:flex;flex-direction:column;gap:15px}.status-item{display:flex;align-items:center;gap:10px;padding:10px;background:#f8f9fa;border-radius:8px}.status-label{font-size:14px;color:#666;flex:1}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}.status-badge.complete{background:#d4edda;color:#155724}.status-badge.incomplete{background:#f8d7da;color:#721c24}.status-date{font-size:12px;color:#999}.revenue-card{border-left:4px solid #28a745}.visitor-card{border-left:4px solid #007bff}.ad-cost-card{border-left:4px solid #dc3545}.performance-card{border-left:4px solid #ffc107}.kpi-card{border-left:4px solid #6f42c1}.status-card{border-left:4px solid #6c757d}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.stats-header{flex-direction:column;gap:15px}.period-selector{width:100%;justify-content:center}.stats-row{flex-direction:column}.stat-item{width:100%}}.comparison-card.total .comparison-item span,.comparison-card.total .comparison-item strong{text-shadow:none!important}.comparison-card.total .comparison-stats strong{color:#fff!important;font-weight:600;text-shadow:none!important}.airtable-dashboard{padding:20px;max-width:1800px;margin:0 auto;background:#f5f6fa;min-height:auto;position:static;z-index:auto;display:flex;flex-direction:column;gap:16px}.airtable-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;position:static;z-index:auto;margin:0;flex-shrink:0}.header-left h2{margin:0;font-size:1.75rem;color:#2c3e50;display:flex;align-items:center;gap:12px}.header-icon{color:#667eea}.header-controls{display:flex;gap:24px;align-items:center}.view-mode-toggle{display:flex;gap:4px;background:#f0f2f5;padding:4px;border-radius:8px}.mode-btn{padding:8px 16px;border:none;background:transparent;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .3s ease}.mode-btn:hover{background:#667eea1a;color:#667eea}.mode-btn.active{background:#667eea;color:#fff}.date-selector{display:flex;gap:8px}.year-select,.month-select{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer;transition:border-color .3s ease}.year-select:hover,.month-select:hover{border-color:#667eea}.year-select:focus,.month-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.sub-navigation{display:flex;gap:12px;padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;position:static;margin:0;flex-shrink:0}.sub-nav-btn{padding:10px 24px;border:2px solid #e0e0e0;background:#fff;color:#666;font-size:.95rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .3s ease}.sub-nav-btn:hover{border-color:#667eea;color:#667eea;background:#667eea0d}.sub-nav-btn.active{background:#667eea;color:#fff;border-color:#667eea}.airtable-content{animation:fadeIn .5s ease;position:static;z-index:auto;background:transparent;display:flex;flex-direction:column;min-height:400px;flex:1;margin:0}.airtable-content .loading-gauge-container{flex:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:inherit}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-gauge-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;min-height:300px;width:100%;margin:0 auto}@media (max-width: 768px){.loading-gauge-container{padding:40px 16px;min-height:200px;border-radius:8px;margin:0}.loading-gauge{width:240px}.gauge-background{height:20px}.gauge-text{font-size:1.25rem}.loading-message{font-size:.85rem}}.loading-gauge{width:300px;text-align:center}.gauge-background{width:100%;height:24px;background:#e0e0e0;border-radius:12px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.gauge-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:12px;transition:width .3s ease;box-shadow:0 2px 4px #667eea4d;position:relative;overflow:hidden}.gauge-fill:after{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.gauge-text{margin-top:12px;font-size:1.5rem;font-weight:700;color:#667eea}.loading-message{margin-top:16px;color:#666;font-size:.95rem}.gradient-primary,.bg-primary,[class*=gradient-],.gradient-primary *,.bg-primary *,[class*=gradient-] *,.yearly-table thead th,.yearly-table thead th *{color:#fff!important;text-shadow:none!important}.yearly-table .category-row.integrated-row{background:linear-gradient(90deg,#667eea26,#764ba21a)}.yearly-table .integrated-total{font-weight:800;color:#667eea;background:#667eea0d}.yearly-view{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;position:static;display:block;width:100%}.yearly-table-container{overflow-x:auto;margin-top:20px;border-radius:8px;box-shadow:0 2px 6px #0000000f}.yearly-table{width:100%;border-collapse:collapse;font-size:.875rem;background:#fff}.yearly-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.yearly-table th{padding:12px 8px;text-align:center;font-weight:600;border-right:1px solid rgba(255,255,255,.1);white-space:nowrap}.yearly-table th:last-child{border-right:none}.yearly-table th.sticky-col{position:sticky;left:0;z-index:10;background:linear-gradient(135deg,#667eea,#764ba2);min-width:150px;text-align:left;padding-left:16px}.yearly-table th.total-col{background:#0000001a;font-weight:700}.yearly-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s ease}.yearly-table tbody tr:hover{background:#f8f9fa}.yearly-table td{padding:10px 8px;text-align:center;white-space:nowrap}.yearly-table td.sticky-col{position:sticky;left:0;background:#fff;font-weight:500;color:#2c3e50;border-right:2px solid #e0e0e0;text-align:left;padding-left:16px;z-index:5}.yearly-table tbody tr:hover td.sticky-col{background:#f8f9fa}.yearly-table td.total-col{background:#f0f2f5;font-weight:700;color:#667eea;border-left:2px solid #e0e0e0}.yearly-table .category-row{background:#f8f9fa}.yearly-table .category-row.choho-row{background:linear-gradient(90deg,#4caf501a,#4caf500d)}.yearly-table .category-row.shelter-row{background:linear-gradient(90deg,#2196f31a,#2196f30d)}.yearly-table .category-row.meta-row{background:linear-gradient(90deg,#1877f21a,#1877f20d)}.yearly-table .category-header{font-weight:700;font-size:.95rem;padding:12px 16px;color:#2c3e50}.pension-stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.pension-stat-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000014;transition:all .3s ease}.pension-stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0000001f}.pension-stat-card .card-header{display:flex;align-items:center;gap:12px;padding:16px 20px;color:#fff;font-weight:600}.pension-stat-card .card-header.naver{background:linear-gradient(135deg,#03c75a,#00a651)}.pension-stat-card .card-header.homepage{background:linear-gradient(135deg,#667eea,#764ba2)}.pension-stat-card .card-header.place{background:linear-gradient(135deg,#ff6b6b,#ff5252)}.pension-stat-card .card-header .card-icon{font-size:1.5rem}.pension-stat-card .card-header h4{margin:0;font-size:1.125rem}.pension-stat-card .card-body{padding:20px}.pension-stat-card .stat-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.pension-stat-card .stat-row:last-child{margin-bottom:0}.pension-stat-card .stat-item{display:flex;flex-direction:column;gap:6px}.pension-stat-card .stat-item label{font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.pension-stat-card .stat-item value{font-size:1.25rem;font-weight:700;color:#2c3e50}.pension-stat-card .stat-item value.cost{color:#667eea}.pension-stat-card .stat-footer{padding:12px 20px;background:#f8f9fa;border-top:1px solid #e0e0e0;text-align:center;font-size:.875rem;font-weight:600;color:#666}.comparison-container{padding:20px 0}.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.comparison-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.comparison-card.choho{border-top:4px solid #4CAF50}.comparison-card.shelter{border-top:4px solid #2196F3}.comparison-card.integrated-total,.comparison-card.integrated-summary{border-top:4px solid #9CA3AF;background:#fff}.comparison-card.integrated-total h4,.comparison-card.integrated-summary h4{color:#374151}.comparison-card h4{margin:0 0 20px;font-size:1.125rem;font-weight:600}.comparison-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.comparison-item span{color:#666;font-size:.875rem}.comparison-item strong{font-size:1rem;color:#2c3e50;font-weight:700}.comparison-item.highlight{background:#f8f9fa;padding:8px;border-radius:6px;margin:4px 0;border-bottom:none}.comparison-item.highlight strong{color:#667eea}.meta-container{padding:20px 0}.meta-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card.meta{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border-left:4px solid #1877F2;transition:all .3s ease}.stat-card.meta:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-card .stat-label{font-size:.875rem;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.stat-card .stat-value{font-size:2rem;font-weight:700;color:#2c3e50;margin-bottom:8px}.stat-card .stat-sub{font-size:.875rem;color:#1877f2;font-weight:600}.integrated-view{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.integrated-summary{margin-top:24px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.summary-section{background:#f8f9fa;border-radius:12px;padding:20px;border:1px solid #e0e0e0}.summary-section h4{margin:0 0 16px;font-size:1.125rem;font-weight:600;color:#2c3e50}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border-radius:8px;border:1px solid #e0e0e0}.summary-item span{color:#666;font-size:.875rem;font-weight:500}.summary-item strong{font-size:1.125rem;color:#667eea;font-weight:700}@media (max-width: 1200px){.yearly-table{font-size:.75rem}.yearly-table th,.yearly-table td{padding:8px 4px}.yearly-table th.sticky-col,.yearly-table td.sticky-col{min-width:120px;padding-left:12px}}@media (max-width: 768px){.pension-stats-container{grid-template-columns:1fr}.yearly-table-container{border-radius:0}}.section-title{margin:0 0 24px;font-size:1.5rem;color:#2c3e50;font-weight:600;padding:16px 20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea;box-shadow:none;position:static;display:block}.section-subtitle{margin:0 0 16px;font-size:1.125rem;color:#34495e;font-weight:600;padding-left:12px;border-left:3px solid #667eea}.date-label{font-size:.875rem;color:#7f8c8d;font-weight:400}.pension-view{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;position:static;display:block;width:100%}.stats-container{display:flex;flex-direction:column;gap:32px}.stats-section{padding:20px;background:#f8f9fa;border-radius:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.stat-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 6px #0000000f;border:1px solid #e8e8e8;transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.meta{border-top:3px solid #1877F2}.stat-label{font-size:.875rem;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.stat-value{font-size:1.75rem;font-weight:700;color:#2c3e50;margin-bottom:8px}.stat-sub{font-size:.875rem;color:#7f8c8d;padding-top:8px;border-top:1px solid #ecf0f1}.platform-view{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;position:static;display:block;width:100%}.comparison-container{margin-top:24px}.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.comparison-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border:2px solid #e0e0e0;transition:all .3s ease}.comparison-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.comparison-card.choho{border-color:#4caf50}.comparison-card.choho h4{color:#4caf50}.comparison-card.shelter{border-color:#2196f3}.comparison-card.shelter h4{color:#2196f3}.comparison-card.total{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;text-shadow:none!important}.comparison-card.total *{color:#fff!important;text-shadow:none!important}.comparison-card h4{margin:0 0 20px;font-size:1.125rem;font-weight:600;padding-bottom:12px;border-bottom:2px solid rgba(0,0,0,.05)}.comparison-card.total h4{border-bottom-color:#fff3}.comparison-stats{display:flex;flex-direction:column;gap:12px}.comparison-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed #e0e0e0}.comparison-card.total .comparison-item{border-bottom-color:#ffffff1a}.comparison-item:last-child{border-bottom:none}.comparison-item span{font-size:.875rem;color:#666;font-weight:500}.comparison-card.total .comparison-item span{color:#ffffffe6}.comparison-item strong{font-size:1rem;font-weight:600;color:#2c3e50}.comparison-card.total .comparison-item strong{color:#fff}.comparison-item.highlight strong{font-size:1.125rem;font-weight:700;color:#667eea}.comparison-card.total .comparison-item.highlight strong{color:#fff}.meta-container{margin-top:24px}.meta-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.integrated-view{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;position:static;display:block;width:100%}.integrated-summary{padding:20px;background:#f8f9fa;border-radius:12px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.summary-section{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 6px #0000000f}.summary-section h4{margin:0 0 16px;font-size:1.125rem;color:#2c3e50;font-weight:600;padding-bottom:12px;border-bottom:2px solid #e0e0e0}.summary-stats{display:flex;flex-direction:column;gap:12px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.summary-item span{font-size:.875rem;color:#666;font-weight:500}.summary-item strong{font-size:1.125rem;font-weight:700;color:#2c3e50}@media (max-width: 1024px){.dashboard-header{flex-direction:column;gap:12px;padding:16px}.header-controls{width:100%;justify-content:space-between;flex-wrap:wrap;gap:12px}.comparison-grid,.stats-grid,.summary-grid{grid-template-columns:1fr}}@media (max-width: 768px){.airtable-dashboard{padding:8px;min-height:auto;background:#f5f6fa;margin-top:0;overflow:visible;gap:12px}.airtable-content{min-height:calc(100vh - 250px);padding:0}.airtable-content>*{margin-bottom:12px}.airtable-content>*:first-child{margin-top:0}.airtable-header{padding:12px;margin:0;border-radius:8px;position:static}.header-left h2{font-size:1.25rem;gap:8px}.header-icon{width:20px;height:20px}.view-mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:4px;width:100%;padding:4px;background:#f0f2f5;border-radius:6px}.mode-btn{padding:6px 8px;font-size:.8rem;border-radius:4px}.date-selector{display:flex;gap:6px;width:100%}.year-select,.month-select{flex:1;padding:6px 8px;font-size:.85rem}.sub-navigation{display:flex;gap:8px;padding:12px;margin:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:static}.sub-navigation::-webkit-scrollbar{display:none}.sub-nav-btn{flex:0 0 auto;padding:8px 16px;font-size:.85rem;white-space:nowrap;border-radius:6px}.dashboard-content{padding:0}.section-title{font-size:1.1rem;padding:12px;margin-bottom:12px;border-radius:8px}.date-label{font-size:.75rem}.yearly-view{padding:12px;border-radius:8px}.yearly-table-container{margin-top:12px;border-radius:6px;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.yearly-table{font-size:.7rem;min-width:800px}.yearly-table th,.yearly-table td{padding:6px 4px;font-size:.65rem}.yearly-table th.sticky-col,.yearly-table td.sticky-col{position:sticky;left:0;z-index:5;background:#fff;min-width:100px;max-width:100px;padding-left:8px;font-size:.65rem}.yearly-table thead th.sticky-col{background:linear-gradient(135deg,#667eea,#764ba2)}.pension-view{padding:12px;border-radius:8px}.pension-stats-container{gap:12px}.pension-stat-card{border-radius:8px}.pension-stat-card .card-header{padding:12px 16px;font-size:.95rem}.pension-stat-card .card-header .card-icon{font-size:1.2rem}.pension-stat-card .card-header h4{font-size:.95rem}.pension-stat-card .card-body{padding:16px}.pension-stat-card .stat-item label{font-size:.7rem}.pension-stat-card .stat-item value{font-size:1rem}.pension-stat-card .stat-footer{padding:10px 16px;font-size:.8rem}.platform-view{padding:12px;border-radius:8px}.comparison-grid{gap:12px}.comparison-card{padding:16px;border-radius:8px}.comparison-card h4{font-size:.95rem;margin-bottom:12px}.comparison-item span{font-size:.8rem}.comparison-item strong{font-size:.9rem}.meta-stats-grid{grid-template-columns:1fr 1fr;gap:12px}.stat-card.meta{padding:16px;border-radius:8px}.stat-card .stat-label{font-size:.75rem;margin-bottom:6px}.stat-card .stat-value{font-size:1.25rem;margin-bottom:6px}.stat-card .stat-sub{font-size:.75rem}.integrated-view,.integrated-summary{padding:12px;border-radius:8px}.summary-grid{gap:12px}.summary-section{padding:12px;border-radius:8px}.summary-section h4{font-size:.95rem;margin-bottom:12px;padding-bottom:8px}.summary-item{padding:8px;border-radius:6px}.summary-item span{font-size:.75rem}.summary-item strong{font-size:.95rem}}@media (max-width: 360px){.airtable-dashboard{padding:6px}.dashboard-header{padding:10px}.header-left h2{font-size:1rem}.view-mode-toggle{grid-template-columns:1fr;gap:2px}.mode-btn{padding:5px 8px;font-size:.75rem}.year-select,.month-select{padding:5px 6px;font-size:.8rem}.section-title{font-size:.95rem;padding:10px}.yearly-table{font-size:.65rem}.yearly-table th,.yearly-table td{padding:4px 2px;font-size:.6rem}.yearly-table th.sticky-col,.yearly-table td.sticky-col{min-width:80px;max-width:80px;font-size:.6rem;padding-left:6px}.meta-stats-grid{grid-template-columns:1fr}.summary-item span{font-size:.7rem}.summary-item strong{font-size:.85rem}}@media (max-width: 768px){.yearly-table-container:after{content:"→ 좌우로 스크롤 →";position:absolute;bottom:5px;right:10px;background:#667eeae6;color:#fff;padding:2px 8px;border-radius:4px;font-size:.65rem;pointer-events:none;animation:fadeInOut 3s infinite}@keyframes fadeInOut{0%,to{opacity:0}50%{opacity:1}}.yearly-table-container{position:relative}}.stat-card,.comparison-card{animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stat-value{transition:color .3s ease}.stat-card:hover .stat-value{color:#667eea}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#5a6fe8}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}.text-primary{color:#667eea}.text-success{color:#4caf50}.text-warning{color:#ffc107}.text-danger{color:#f44336}.text-info{color:#2196f3}.bg-primary{background-color:#667eea}.bg-success{background-color:#4caf50}.bg-warning{background-color:#ffc107}.bg-danger{background-color:#f44336}.bg-info{background-color:#2196f3}.gradient-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.gradient-success{background:linear-gradient(135deg,#4caf50,#45a049)}.gradient-info{background:linear-gradient(135deg,#2196f3,#1976d2)}.shadow-sm{box-shadow:0 2px 4px #0000000f}.shadow{box-shadow:0 2px 8px #00000014}.shadow-lg{box-shadow:0 4px 12px #0000001a}.shadow-xl{box-shadow:0 6px 16px #0000001f}.border{border:1px solid #e0e0e0}.border-2{border:2px solid #e0e0e0}.border-primary{border-color:#667eea}.border-success{border-color:#4caf50}.border-info{border-color:#2196f3}.rounded{border-radius:4px}.rounded-lg{border-radius:8px}.rounded-xl{border-radius:12px}.rounded-full{border-radius:9999px}.transition-all{transition:all .3s ease}.transition-transform{transition:transform .3s ease}.transition-opacity{transition:opacity .3s ease}.hover-scale:hover{transform:scale(1.05)}.hover-lift:hover{transform:translateY(-2px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(0);animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}*{box-sizing:border-box;margin:0;padding:0}.dashboard{display:flex;flex-direction:column;width:100%;height:100vh;background:#f9fafb;overflow:hidden}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem;height:52px;min-height:52px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600;color:#111827}.logo-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d5016,#3a6620);color:#fff;border-radius:8px;box-shadow:0 2px 4px #2d501633}.header-right{display:flex;align-items:center;gap:1rem}.header-user{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#f3f4f6;border-radius:20px;font-size:.875rem;color:#111827;border:1px solid #e5e7eb}.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#2d5016,#3a6620);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.btn-logout{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;color:#6b7280;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626}.dashboard-nav{display:flex;align-items:center;padding:0 1.5rem;height:48px;min-height:48px;background:#fff;border-bottom:1px solid #e5e7eb;overflow-x:auto;flex-shrink:0}.dashboard-nav::-webkit-scrollbar{display:none}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:0 1.25rem;height:100%;background:transparent;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;position:relative}.nav-tab:hover{color:#374151;background:#2d50160d}.nav-tab.active{color:#2d5016;border-bottom-color:#2d5016;background:#2d501614;font-weight:600}.nav-tab-icon{width:20px;height:20px;opacity:.7;color:inherit;flex-shrink:0}.nav-tab.active .nav-tab-icon{opacity:1;color:#2d5016}.nav-tab-label{display:inline-block}.nav-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#dc2626;color:#fff;border-radius:10px;font-size:11px;font-weight:600;margin-left:.5rem}.dashboard-content{flex:1;width:100%;padding:1.5rem;overflow-y:auto;overflow-x:hidden;background:#f9fafb;min-height:0}.content-wrapper{max-width:1400px;margin:0 auto;width:100%}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0000000d;transition:all .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{font-size:2rem;opacity:.8;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-content h3{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:#111827;line-height:1.2}.stat-trend{display:inline-flex;align-items:center;gap:.25rem;margin-top:.5rem;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600}.stat-trend.positive{background:#10b9811a;color:#10b981}.stat-trend.negative{background:#ef44441a;color:#ef4444}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#2d5016;border-radius:50%;animation:spin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6b7280}.mobile-menu-trigger{display:none;width:40px;height:40px;align-items:center;justify-content:center;background:transparent;border:none;color:#111827;cursor:pointer}.mobile-page-title{display:none}.dashboard-content::-webkit-scrollbar{width:8px}.dashboard-content::-webkit-scrollbar-track{background:#f1f1f1}.dashboard-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.dashboard-content::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.mobile-menu-trigger{display:flex}.mobile-page-title{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff;border-radius:8px;margin-bottom:1rem;border:1px solid #e5e7eb}.mobile-page-title h2{font-size:1.125rem;font-weight:600;color:#111827;margin:0;display:flex;align-items:center;gap:.5rem}.logo-text{font-size:1.1rem}.header-user span{display:none}.dashboard-header{padding:0 1rem;height:48px;min-height:48px}.dashboard-nav{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,1fr);gap:0;padding:0;height:auto;min-height:104px;background:#fff;overflow:visible}.nav-tab{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:.75rem .25rem;gap:.25rem;height:auto;min-height:52px;background:#fff;border:1px solid #e5e7eb;border-bottom:3px solid transparent}.nav-tab-label{display:block;font-size:.7rem;line-height:1.2;text-align:center;word-break:keep-all}.nav-tab-icon{width:20px;height:20px}.nav-tab:hover{background:#f9fafb}.nav-tab.active{background:#fff;border-bottom-color:#2d5016;color:#2d5016}.nav-tab-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;font-size:10px;padding:0 4px}.dashboard-content{padding:1rem}.stat-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem;min-height:80px}.stat-icon{font-size:1.5rem}.stat-content h3{font-size:.75rem}.stat-value{font-size:1.5rem}}@media (max-width: 480px){.dashboard-header{height:44px;min-height:44px;padding:0 .75rem}.logo-icon{width:28px;height:28px}.logo-text{font-size:1rem}.btn-logout span{display:none}.nav-tab{padding:.5rem .2rem;min-height:48px}.nav-tab-icon{width:18px;height:18px}.nav-tab-label{font-size:.65rem}.dashboard-content{padding:.75rem}.stat-cards{grid-template-columns:1fr;gap:.625rem}.stat-card{padding:.875rem;min-height:70px}.stat-value{font-size:1.25rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-content.airtable-tab{overflow-y:visible;padding:0;background:transparent}#debug-panel{position:fixed;right:10px;top:10px;width:400px;max-height:80vh;background:#fff;border:2px solid #333;border-radius:8px;box-shadow:0 4px 20px #0000004d;z-index:99999;font-family:Consolas,Monaco,monospace;font-size:12px;overflow:hidden;display:flex;flex-direction:column}.debug-panel-header{background:#333;color:#fff;padding:10px;display:flex;justify-content:space-between;align-items:center;cursor:move}.debug-panel-header h3{margin:0;font-size:14px}.debug-panel-header button{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0;width:25px;height:25px;display:flex;align-items:center;justify-content:center}.debug-panel-header button:hover{background:#ffffff1a;border-radius:4px}.debug-panel-content{flex:1;overflow-y:auto;padding:10px;background:#f5f5f5}.debug-section{margin-bottom:15px;background:#fff;border-radius:4px;padding:10px;border:1px solid #ddd}.debug-section h4{margin:0 0 10px;color:#333;font-size:12px;font-weight:700;border-bottom:1px solid #eee;padding-bottom:5px}.debug-log-entry{margin-bottom:4px;padding:4px;background:#fafafa;border-left:3px solid #ddd;font-size:11px;word-wrap:break-word}.debug-log-entry.level-0{border-left-color:#f44;background:#fff5f5}.debug-log-entry.level-1{border-left-color:#fa0;background:#fffaf0}.debug-log-entry.level-2{border-left-color:#44f;background:#f0f0ff}.debug-log-entry.level-3{border-left-color:#4f4;background:#f0fff0}.debug-log-entry.level-4{border-left-color:#888;background:#f8f8f8}.debug-log-entry .time{color:#666;margin-right:5px}.debug-log-entry .component{color:#06c;font-weight:700;margin-right:5px}.debug-log-entry .message{color:#333}.debug-error-entry{margin-bottom:4px;padding:6px;background:#fff5f5;border-left:3px solid #ff4444;font-size:11px}.debug-error-entry .time{color:#666;margin-right:5px}.debug-error-entry .component{color:#c00;font-weight:700;margin-right:5px}.debug-error-entry .message{color:#900}.debug-query-entry{margin-bottom:4px;padding:4px;background:#f0f8ff;border-left:3px solid #0088cc;font-size:11px;display:flex;justify-content:space-between;align-items:center}.debug-query-entry .key{color:#06c;font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:5px}.debug-query-entry .count{color:#666;margin-right:10px}.debug-query-entry .status{color:#333}.debug-perf-entry{margin-bottom:4px;padding:4px;background:#f0fff0;border-left:3px solid #44ff44;font-size:11px;display:flex;justify-content:space-between}.debug-perf-entry .key{color:#080;font-weight:700}.debug-perf-entry .elapsed{color:#666}.debug-error-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#f44;color:#fff;padding:15px 20px;border-radius:4px;box-shadow:0 2px 10px #0000004d;z-index:100000;max-width:400px;animation:slideDown .3s ease}.debug-error-notification strong{display:block;margin-bottom:5px}.debug-error-notification p{margin:0;font-size:12px}.debug-error-notification button{position:absolute;top:5px;right:10px;background:none;border:none;color:#fff;font-size:20px;cursor:pointer}@keyframes slideDown{0%{transform:translate(-50%,-100%);opacity:0}to{transform:translate(-50%);opacity:1}}@media (max-width: 768px){#debug-panel{width:90%;right:5%;left:5%}}@media (prefers-color-scheme: dark){#debug-panel{background:#1a1a1a;border-color:#444}.debug-panel-header{background:#2a2a2a}.debug-panel-content{background:#1a1a1a}.debug-section{background:#2a2a2a;border-color:#444}.debug-section h4{color:#ccc;border-bottom-color:#444}.debug-log-entry{background:#222}.debug-log-entry .message,.debug-error-entry .message{color:#ddd}}:root{--color-primary: #1a1a1a;--color-primary-light: #404040;--color-primary-dark: #000000;--color-accent: #4A90E2;--color-accent-light: #6BA3E5;--color-accent-dark: #357ABD;--color-success: #10B981;--color-success-light: #34D399;--color-success-dark: #059669;--color-warning: #F59E0B;--color-warning-light: #FCD34D;--color-warning-dark: #D97706;--color-danger: #EF4444;--color-danger-light: #F87171;--color-danger-dark: #DC2626;--color-info: #3B82F6;--color-info-light: #60A5FA;--color-info-dark: #2563EB;--color-white: #FFFFFF;--color-gray-50: #FAFAFA;--color-gray-100: #F4F4F5;--color-gray-200: #E4E4E7;--color-gray-300: #D4D4D8;--color-gray-400: #A1A1AA;--color-gray-500: #71717A;--color-gray-600: #52525B;--color-gray-700: #3F3F46;--color-gray-800: #27272A;--color-gray-900: #18181B;--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F4F4F5;--bg-elevated: #FFFFFF;--bg-overlay: rgba(0, 0, 0, .5);--bg-hover: rgba(0, 0, 0, .04);--bg-active: rgba(0, 0, 0, .08);--text-primary: #18181B;--text-secondary: #52525B;--text-tertiary: #71717A;--text-disabled: #A1A1AA;--text-inverse: #FFFFFF;--text-link: #4A90E2;--text-on-dark: #FFFFFF;--text-on-light: #18181B;--border-light: #E4E4E7;--border-default: #D4D4D8;--border-dark: #A1A1AA;--border-focus: #4A90E2;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Code", "Fira Mono", "Roboto Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-slower: .5s ease;--z-base: 0;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-modal-backdrop: 40;--z-modal: 50;--z-popover: 60;--z-tooltip: 70;--z-notification: 80}@media (prefers-color-scheme: dark){:root{--bg-primary: #18181B;--bg-secondary: #27272A;--bg-tertiary: #3F3F46;--bg-elevated: #27272A;--text-primary: #FAFAFA;--text-secondary: #A1A1AA;--text-tertiary: #71717A;--border-light: #3F3F46;--border-default: #52525B;--border-dark: #71717A}}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-secondary);line-height:var(--leading-normal)}p,span,div,li,td,th,h1,h2,h3,h4,h5,h6,label,input,select,textarea{color:var(--text-primary)}*{color:inherit}html{color:var(--text-primary)}.bg-white,.card,.modal-content,[style*="background: white"],[style*="background-color: white"],[style*="background:#fff"],[style*="background-color:#fff"],[style*="background: #fff"],[style*="background-color: #fff"],[style*="background:#ffffff"],[style*="background-color:#ffffff"],[style*="background: #ffffff"],[style*="background-color: #ffffff"]{color:var(--text-primary)!important}.bg-white *:not(button):not(.btn),.card *:not(button):not(.btn),.modal-content *:not(button):not(.btn){color:inherit}button[style*="background: #"],.btn-primary,.btn-success,.btn-danger,.btn-warning{color:var(--text-inverse)!important}button[style*="background: white"],button[style*="background: #fff"],button[style*="background: #ffffff"],.btn-secondary,.btn-light,.btn-outline{color:var(--text-primary)!important}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--leading-tight);border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;outline:none}.btn:focus-visible{box-shadow:0 0 0 3px #4a90e226}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary-light)}.btn-secondary{background-color:var(--bg-primary);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-tertiary)}.btn-ghost{background-color:transparent;color:var(--text-primary);border-color:transparent}.btn-ghost:hover:not(:disabled){background-color:var(--bg-hover)}.card{background-color:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-light)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-light);background-color:var(--bg-tertiary)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-base);outline:none}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #4a90e21a}.input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.125rem .625rem;font-size:var(--text-xs);font-weight:var(--font-medium);line-height:var(--leading-tight);border-radius:var(--radius-full);white-space:nowrap}.badge-default{background-color:var(--bg-tertiary);color:var(--text-secondary)}.badge-primary{background-color:#1a1a1a1a;color:var(--color-primary)}.badge-success{background-color:#10b9811a;color:var(--color-success-dark)}.badge-warning{background-color:#f59e0b1a;color:var(--color-warning-dark)}.badge-danger{background-color:#ef44441a;color:var(--color-danger-dark)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html,body{height:100%}body{line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root{isolation:isolate;min-height:100vh}:root{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--color-primary: #2d5016;--color-secondary: #558b2f;--color-success: #28a745;--color-danger: #dc3545;--color-warning: #ffc107;--color-info: #17a2b8;--color-dark: #343a40;--color-light: #f8f9fa;--text-primary: #374151;--text-inverse: #ffffff;--shadow-sm: 0 2px 4px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}button{cursor:pointer;background:none;border:none;padding:0;font:inherit;color:inherit}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}@media (max-width: 768px){.hide-mobile{display:none}}@media (min-width: 769px){.hide-desktop{display:none}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;overflow-y:auto}.modal-overlay>*{background:#fff;color:var(--text-primary, #374151)}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;z-index:999}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:var(--color-dark);font-weight:600}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#666;background:transparent;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.modal-close:hover{background-color:#f0f0f0;color:var(--color-dark)}.modal-body{padding:1.5rem;overflow-y:auto;max-height:calc(90vh - 140px)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e0e0e0}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--text-inverse, white)}.btn-primary:hover:not(:disabled){background-color:#3a6a1d}.btn-secondary{background-color:#e9ecef;color:var(--color-dark)}.btn-secondary:hover:not(:disabled){background-color:#dee2e6}.btn-danger{background-color:var(--color-danger);color:var(--text-inverse, white)}.btn-danger:hover:not(:disabled){background-color:#c82333}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px;color:#666}.loading-spinner{width:40px;height:40px;border:3px solid #e8f5e9;border-top:3px solid var(--color-primary);border-right:3px solid var(--color-secondary);border-radius:50%;animation:spin .8s ease-in-out infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0);opacity:1}50%{opacity:.7}to{transform:rotate(360deg);opacity:1}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:#666;text-align:center}.empty-state p{font-size:1.125rem;margin-bottom:1rem}input:focus,select:focus,textarea:focus{outline:none;box-shadow:0 0 0 3px #2d50161a}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btnSpin .8s linear infinite;margin-right:8px;flex-shrink:0}@keyframes btnSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
