@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";:root{--primary: #5B5FC7;--primary-hover: #4B4FB7;--primary-light: #6366F1;--text-primary: #1A1A1A;--text-secondary: #666666;--text-tertiary: #999999;--text-disabled: #CCCCCC;--bg-primary: #FFFFFF;--bg-secondary: #F7F8FA;--bg-tertiary: #FAFBFC;--bg-hover: #F5F6F8;--border-primary: #E5E7EB;--border-secondary: #F0F0F0;--border-focus: #5B5FC7;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{line-height:1.1}button{font-family:inherit;cursor:pointer}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-transition{animation:fadeIn .25s ease-out}.subnav{position:sticky;top:0;z-index:100;background-color:var(--bg-primary);border-bottom:1px solid var(--border-primary);box-shadow:var(--shadow-sm);animation:subnavFadeIn .2s ease-out}@keyframes subnavFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.subnav-container{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;gap:8px}.subnav-item{padding:12px 16px;font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;border-bottom:2px solid transparent;transition:all .15s ease;position:relative}.subnav-item:hover{color:var(--text-primary);background-color:var(--bg-hover)}.subnav-item.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.layout{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-secondary)}.layout-header{background-color:var(--bg-primary);border-bottom:1px solid var(--border-primary);padding:0 24px;display:flex;justify-content:space-between;align-items:center;height:60px;box-shadow:var(--shadow-sm)}.header-left{display:flex;flex-direction:row;align-items:center;gap:50px;flex-wrap:nowrap}.header-logo-link{text-decoration:none;cursor:pointer;transition:opacity .15s ease}.header-logo-link:hover{opacity:.7}.header-logo{font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0;color:var(--text-primary)}.branch-selector{position:relative}.branch-selector-button{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:14px;font-weight:500;color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.branch-selector-button:hover{border-color:var(--primary);background-color:var(--bg-hover)}.branch-name{font-size:14px;font-weight:600;color:var(--primary)}.dropdown-arrow{font-size:10px;color:var(--text-tertiary)}.branch-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:150px;background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:200;overflow:hidden}.branch-option{width:100%;padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-primary);background-color:transparent;border:none;text-align:left;cursor:pointer;transition:all .15s ease}.branch-option:hover{background-color:var(--bg-hover)}.branch-option.active{background-color:#5b5fc714;color:var(--primary);font-weight:600}.header-nav{display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex:1;gap:24px}.nav-left,.nav-right{display:flex;flex-direction:row;align-items:center;gap:24px}.nav-tab{padding:8px 16px;font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all .15s ease;position:relative;background:transparent;border:none;cursor:pointer}.nav-tab:hover{color:var(--text-primary);background-color:var(--bg-hover)}.nav-tab.active{color:var(--primary);font-weight:600;background-color:#5b5fc714}.header-right{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:10px}.user-info.clickable{cursor:pointer;padding:4px 8px;margin:-4px -8px;border-radius:var(--radius-md);transition:all .15s ease}.user-info.clickable:hover{background-color:var(--bg-hover)}.user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border-secondary)}.user-avatar-placeholder{width:40px;height:40px;border-radius:50%;background-color:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;border:2px solid var(--border-secondary)}.user-name{font-size:13px;color:var(--text-primary);font-weight:500}.logout-button{padding:6px 14px;font-size:13px;color:var(--text-secondary);background-color:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;font-weight:500}.logout-button:hover{color:var(--text-primary);border-color:var(--border-focus);background-color:var(--bg-hover)}.layout-content{flex:1;overflow-y:auto;padding:0}.version-toast{position:fixed;bottom:24px;right:24px;background-color:var(--bg-primary);border:1px solid var(--primary);border-radius:var(--radius-lg);box-shadow:0 8px 32px #5b5fc740;padding:16px 20px;z-index:9999;display:flex;flex-direction:column;gap:12px;min-width:280px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.version-toast-content{display:flex;align-items:center;gap:10px}.version-toast-icon{font-size:20px}.version-toast-message{font-size:14px;font-weight:600;color:var(--text-primary)}.version-toast-actions{display:flex;gap:8px;justify-content:flex-end}.version-toast-btn{padding:8px 16px;font-size:13px;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.version-toast-btn.reload{background-color:var(--primary);color:#fff;border:none}.version-toast-btn.reload:hover{background-color:#4a4eb3}.version-toast-btn.dismiss{background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-primary)}.version-toast-btn.dismiss:hover{background-color:var(--bg-hover);color:var(--text-primary)}@media(max-width:768px){body.mobile-my-page .layout-header{display:none}body.mobile-my-page .layout-content{height:100vh}body.mobile-my-page .layout{height:auto;min-height:100vh}}.login-container{display:flex;height:100vh;width:100%;overflow:hidden}.emoji-slot-container{display:inline-flex;position:relative;width:64px;height:64px;overflow:hidden;vertical-align:middle;margin-left:8px;background:transparent;transform:translateY(-4px)}.emoji-slot-track{display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1)}.emoji-slot-item{display:flex;align-items:center;justify-content:center;width:64px;height:64px;font-size:56px;line-height:1;flex-shrink:0}.login-container.exiting .login-left{animation:slideOutLeft .6s cubic-bezier(.4,0,.2,1) forwards}.login-container.exiting .login-right{animation:slideOutRight .6s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideOutLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.login-left{width:50%;flex-shrink:0;background-color:#1a1a1a;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:60px;color:#fff;text-align:center}.login-logo h1{font-family:Arial Black,sans-serif;font-size:64px;font-weight:900;letter-spacing:-2px;margin:0;color:#fff}.login-subtitle{font-size:16px;margin-top:12px;letter-spacing:1px;color:#fffc}.login-logo{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.login-footer{font-size:13px;color:#fff9;width:100%}.login-right{width:50%;flex-shrink:0;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center;padding:40px}.login-form-wrapper{width:100%;max-width:400px}.login-title{font-size:24px;font-weight:700;margin-bottom:40px;color:#1a1a1a;text-align:left}.login-form{display:flex;flex-direction:column;gap:16px}.input-group{display:flex;flex-direction:column}.login-input{width:100%;padding:16px 20px;font-size:15px;border:1px solid #ddd;border-radius:4px;background-color:#fff;transition:all .2s;box-sizing:border-box}.login-input:focus{outline:none;border-color:#1a1a1a;background-color:#fafafa}.login-input:disabled{background-color:#f0f0f0;cursor:not-allowed}.login-input::placeholder{color:#999}.error-message{color:#e53935;font-size:14px;padding:12px 16px;background-color:#ffebee;border-radius:8px;text-align:center;white-space:pre-line;line-height:1.5}.remember-me-wrapper{margin-top:12px;margin-bottom:4px}.remember-me-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#666;-webkit-user-select:none;user-select:none}.remember-me-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#1a1a1a}.login-button{width:100%;padding:16px;font-size:16px;font-weight:600;color:#fff;background-color:#1a1a1a;border:none;border-radius:4px;cursor:pointer;transition:all .2s;margin-top:8px}.login-button:hover:not(:disabled){background-color:#2d2d2d}.login-button:active:not(:disabled){background-color:#000}.login-button:disabled{background-color:#999;cursor:not-allowed}.login-help{margin-top:24px;font-size:13px;color:#666;text-align:center;line-height:1.6}@media(max-width:768px){.login-container{flex-direction:column}.login-left{width:100%;padding:40px 24px;flex:0 0 auto}.login-logo h1{font-size:36px}.emoji-slot-container{width:36px;height:36px;margin-left:4px;transform:translateY(-2px)}.emoji-slot-item{width:36px;height:36px;font-size:32px}.login-subtitle{font-size:14px}.login-right{width:100%;padding:24px;flex:1}.login-form-wrapper{max-width:100%}.login-title{font-size:20px;margin-bottom:24px}.login-input{font-size:16px;min-height:48px;padding:14px 16px}.login-button{min-height:48px;font-size:16px}.remember-me-label{font-size:15px}.remember-me-checkbox{width:20px;height:20px}.login-help{font-size:12px}}.home-container{padding:40px 24px;max-width:1400px;margin:0 auto}.home-content{display:flex;flex-direction:column;gap:48px}.welcome-section{text-align:center;padding:60px 24px;background:linear-gradient(135deg,#5b5fc70d,#5b5fc705);border-radius:var(--radius-xl);border:1px solid var(--border-primary)}.welcome-title{font-size:36px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.welcome-subtitle{font-size:18px;color:var(--text-secondary);margin:0}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.info-card{display:flex;align-items:center;gap:20px;padding:24px;background-color:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.info-card-icon{font-size:40px;flex-shrink:0}.info-card-content{flex:1}.info-card-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.info-card-value{font-size:20px;font-weight:600;color:var(--text-primary)}.nav-section{padding:0 24px}.nav-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 24px}.nav-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.nav-card{display:flex;align-items:flex-start;gap:20px;padding:32px;background-color:var(--bg-primary);border-radius:var(--radius-lg);border:2px solid var(--border-primary);box-shadow:var(--shadow-sm);text-decoration:none;transition:all .2s ease}.nav-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.nav-card-icon{font-size:48px;flex-shrink:0}.nav-card-content{flex:1}.nav-card-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.nav-card-description{font-size:14px;color:var(--text-secondary);line-height:1.5}.info-section{text-align:center;padding:24px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.info-text{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.6}@media(max-width:768px){.home-container{padding:24px 16px}.welcome-section{padding:40px 20px}.welcome-title{font-size:28px}.welcome-subtitle{font-size:16px}.info-cards,.nav-cards{grid-template-columns:1fr}.nav-section{padding:0}}.filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:16px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.filter-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.filter-actions{display:flex;gap:8px}.btn-reset-filter{padding:8px 16px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s ease}.btn-reset-filter:hover{background:var(--bg-hover);color:var(--text-primary)}.filter-chip-group{display:flex;gap:4px}.filter-chip{padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;transition:all .15s ease}.filter-chip:hover{background:var(--bg-hover);border-color:var(--primary)}.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.chart-filter-container{display:flex;gap:12px;align-items:center}.chart-dropdown-group{display:flex;gap:8px;align-items:center}.chart-dropdown-group select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--bg-secondary)}.recharts-tooltip-wrapper{z-index:1000!important}.recharts-default-tooltip{background-color:#fffffffa!important;border:1px solid var(--border-primary)!important;border-radius:6px!important;box-shadow:0 4px 12px #00000026!important;padding:8px 10px!important;font-size:11px!important;max-width:200px!important}.recharts-tooltip-label{font-weight:600!important;font-size:11px!important;margin-bottom:4px!important;color:var(--text-primary)!important}.recharts-tooltip-item-list{padding:0!important;margin:0!important}.recharts-tooltip-item{padding:2px 0!important;font-size:11px!important;line-height:1.3!important}.recharts-tooltip-item-name{font-weight:500!important}.recharts-tooltip-item-value{font-weight:600!important}.filter-grid-main{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative}.filter-grid-detail{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;position:relative}.filter-item{position:relative;display:flex;flex-direction:column;gap:4px}.filter-item-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.filter-input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-family:inherit;transition:all .15s ease;background-color:var(--bg-primary);color:var(--text-primary)}.filter-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #5b5fc71a}.filter-input.active{border-color:var(--primary);background-color:#5b5fc70d;font-weight:500}.csv-download-btn{padding:8px 16px;font-size:13px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.csv-download-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 2px 4px #5b5fc733}.metric-table-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:hidden;padding:0}.metric-table{min-width:100%;width:max-content;border-collapse:collapse;font-size:13px}.view-mode-tabs{display:flex;gap:8px;background-color:var(--bg-secondary);padding:4px;border-radius:var(--radius-md);width:fit-content}.view-mode-tab{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.view-mode-tab:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.view-mode-tab.active{background-color:var(--bg-primary);color:var(--primary);font-weight:600;box-shadow:0 1px 3px #0000001a}.pivot-table th,.pivot-table td{text-align:center;min-width:80px}.pivot-table th:first-child,.pivot-table th:nth-child(2),.pivot-table th:nth-child(3),.pivot-table td:first-child,.pivot-table td:nth-child(2),.pivot-table td:nth-child(3){text-align:left}.pivot-table .numeric{text-align:right;font-family:Roboto Mono,monospace}.pivot-table .total{font-weight:600;background-color:var(--bg-secondary)}.pivot-table .metric-name{font-weight:500;padding-left:16px}.pivot-table .highlight-row{background-color:rgba(var(--primary-rgb),.05)}.pivot-table .highlight-row td{font-weight:600}.coupon-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.coupon-modal{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:900px;width:100%;max-height:80vh;display:flex;flex-direction:column}.coupon-modal-header{padding:20px 24px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.coupon-modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.coupon-add-section{padding:16px 24px;background:var(--bg-secondary);display:flex;gap:8px;border-bottom:1px solid var(--border-primary)}.coupon-tags-input-container{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 12px;min-height:42px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);cursor:text}.coupon-tags-input-container:focus-within{border-color:var(--primary)}.coupon-id-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background-color:var(--primary);color:#fff;border-radius:4px;font-size:13px;font-weight:500;font-family:monospace}.coupon-tag-remove{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;margin-left:2px;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:14px;line-height:1;cursor:pointer;transition:background .15s ease}.coupon-tag-remove:hover{background:#fff6}.coupon-tags-input{flex:1;min-width:180px;padding:4px 0;border:none;background:transparent;font-size:14px;color:var(--text-primary);outline:none}.coupon-tags-input::placeholder{color:var(--text-tertiary)}.coupon-add-input{flex:1;padding:10px 14px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary)}.coupon-add-input:focus{outline:none;border-color:var(--primary)}.coupon-add-btn{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.coupon-add-btn:hover:not(:disabled){background-color:var(--primary-hover)}.coupon-add-btn:disabled{opacity:.5;cursor:not-allowed}.coupon-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.coupon-modal .modal-loading,.coupon-modal .modal-empty{text-align:center;padding:40px;color:var(--text-tertiary);font-size:14px}.coupon-modal .coupon-table{width:100%;border-collapse:collapse;font-size:13px}.coupon-modal .coupon-table th,.coupon-modal .coupon-table td{padding:12px 14px;text-align:center;border-bottom:1px solid var(--border-secondary)}.coupon-modal .coupon-table th{background:var(--bg-secondary);font-size:13px;font-weight:600;color:var(--text-secondary)}.coupon-modal .coupon-table td{font-size:13px;color:var(--text-primary)}.coupon-modal .coupon-table tbody tr:hover{background:var(--bg-hover)}.coupon-modal .row-inactive{opacity:.5}.coupon-modal .status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.coupon-modal .status-active{background-color:#d4edda;color:#155724}.coupon-modal .status-expired{background-color:#f8d7da;color:#721c24}.coupon-modal .status-used{background-color:#e2e3e5;color:#383d41}.coupon-modal .code-cell{font-family:monospace;font-size:11px;color:#666}.coupon-delete-btn{padding:4px 10px;font-size:12px;color:#dc3545;background:transparent;border:1px solid #dc3545;border-radius:4px;cursor:pointer;transition:all .15s ease}.coupon-delete-btn:hover{background:#dc3545;color:#fff}.coupon-modal .modal-close{background:none;border:none;font-size:28px;color:var(--text-tertiary);cursor:pointer;padding:0;line-height:1}.coupon-modal .modal-close:hover{color:var(--text-primary)}.active-member-container{padding:24px;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{font-size:28px;font-weight:700;color:#1a1a1a;margin:0}.btn-info{padding:10px 20px;background:#fff;color:#5b5fc7;border:1px solid #5B5FC7;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.btn-info:hover{background:#5b5fc7;color:#fff}.filter-row{display:grid;grid-template-columns:1fr 1fr 300px;gap:24px;margin-bottom:20px}.filter-row-category{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.filter-group{display:flex;flex-direction:column;gap:12px}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.filter-header label{font-size:14px;font-weight:600;color:#1a1a1a}.btn-toggle-all{padding:4px 12px;background:#fff;color:#5b5fc7;border:1px solid #5B5FC7;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-toggle-all:hover{background:#5b5fc7;color:#fff}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;max-height:200px;overflow-y:auto;padding:12px;background:#f7f8fa;border:1px solid #E5E7EB;border-radius:6px}.checkbox-grid-horizontal{display:flex;flex-wrap:wrap;gap:8px;max-height:none;overflow-y:visible;padding:12px;background:#f7f8fa;border:1px solid #E5E7EB;border-radius:6px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 8px;border-radius:4px;transition:background .2s;font-size:13px;color:#1a1a1a}.checkbox-label:hover{background:#e5e7eb}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#5B5FC7}.checkbox-label span{flex:1;-webkit-user-select:none;user-select:none}.filter-group-dates{grid-column:3}.filter-group-dates label{font-size:14px;font-weight:600;color:#1a1a1a;margin-bottom:8px}.date-inputs{display:flex;align-items:center;gap:12px}.date-separator{color:#666;font-weight:500}.filter-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid #E5E7EB}.filter-actions-row{display:flex;align-items:center;gap:16px;padding-top:16px;flex-wrap:wrap}.filter-group-inline{display:flex;align-items:center;gap:12px}.filter-group-inline label{font-size:14px;font-weight:600;color:#1a1a1a;white-space:nowrap}.filter-buttons{display:flex;gap:12px;margin-left:auto}.filter-group-compact{display:flex;flex-direction:column;gap:12px;flex:1}.btn-primary{padding:10px 24px;background:#5b5fc7;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#4a4eb0}.btn-primary.inactive{background:#d1d5db;color:#fff;cursor:not-allowed}.btn-primary.changed{background:#5b5fc7;animation:pulse 1.5s ease-in-out infinite;box-shadow:0 0 #5b5fc7b3}.btn-primary.changed:hover{background:#4a4eb0;animation:none}@keyframes pulse{0%{box-shadow:0 0 #5b5fc7b3}50%{box-shadow:0 0 0 8px #5b5fc700}to{box-shadow:0 0 #5b5fc700}}.btn-secondary{padding:10px 24px;background:#fff;color:#666;border:1px solid #E5E7EB;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f7f8fa;border-color:#d1d5db}.chart-section{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:24px;margin-bottom:24px}.chart-section h2{font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:20px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:16px}.spinner{width:40px;height:40px;border:4px solid #E5E7EB;border-top-color:#5b5fc7;border-radius:50%;animation:spin .8s linear infinite}.loading-state p{font-size:14px;color:#666}.error-banner{background:#fef2f2;border:1px solid #FCA5A5;border-radius:6px;padding:12px 16px;margin-bottom:24px;display:flex;align-items:center;gap:8px;color:#991b1b;font-size:14px}.checkbox-grid::-webkit-scrollbar{width:8px}.checkbox-grid::-webkit-scrollbar-track{background:#f7f8fa;border-radius:4px}.checkbox-grid::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.checkbox-grid::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media(max-width:1200px){.filter-row{grid-template-columns:1fr}.filter-group-dates{grid-column:1}.checkbox-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.filter-actions-row{flex-direction:column;align-items:stretch}.filter-buttons{margin-left:0;justify-content:flex-end}.page-header{flex-direction:column;align-items:flex-start;gap:16px}}@media(max-width:768px){.active-member-container{padding:16px}.checkbox-grid{grid-template-columns:repeat(2,1fr)}.date-inputs{flex-direction:column;gap:8px}.date-separator{display:none}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:1100px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #E5E7EB}.modal-title{font-size:24px;font-weight:700;color:#1a1a1a;margin:0}.modal-close{background:none;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#1a1a1a}.modal-body{padding:32px}.modal-description-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.modal-description-card{background:#f7f8fa;border:1px solid #E5E7EB;border-radius:8px;padding:20px}.modal-description-card h3{font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:16px}.modal-description-card ul{list-style:none;padding:0;margin:0}.modal-description-card li{font-size:13px;color:#666;line-height:1.7;padding-left:0;margin-bottom:6px}@media(max-width:768px){.modal-description-grid{grid-template-columns:1fr}.modal-header,.modal-body{padding:20px}}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chart-header h2{font-size:18px;font-weight:600;color:#1a1a1a;margin:0}.btn-criteria{padding:10px 20px;background:#e53935;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #e5393559}.btn-criteria:hover{background:#c62828;box-shadow:0 4px 10px #e5393573}.active-member-container .filter-section{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.active-member-container .filter-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 14px}.active-member-container .filter-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:nowrap}.active-member-container .filter-item{display:flex;flex-direction:column;gap:4px;flex:1}.active-member-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.active-member-container .filter-input{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);min-width:80px;height:36px;box-sizing:border-box}.active-member-container .filter-input:focus{outline:none;border-color:var(--primary)}.active-member-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;min-width:80px;height:36px}.active-member-container .filter-select:focus{outline:none;border-color:var(--primary)}.active-member-container .filter-select-btn{padding:8px 12px;background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all .2s;text-align:left;width:100%;display:flex;justify-content:space-between;align-items:center;height:36px;box-sizing:border-box}.active-member-container .filter-select-btn:hover{border-color:var(--primary)}.active-member-container .filter-select-btn:after{content:"▼";font-size:10px;color:var(--text-secondary)}.filter-modal-overlay{position:fixed;inset:0;background:#0000004d;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.filter-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.filter-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.filter-modal-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.filter-modal-close{background:none;border:none;font-size:24px;color:var(--text-tertiary);cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.filter-modal-close:hover{color:var(--text-primary)}.filter-modal-body{padding:20px}.filter-modal-actions{display:flex;gap:8px;margin-bottom:16px}.filter-modal-actions button{padding:6px 12px;background-color:var(--bg-primary);color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius-md);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.filter-modal-actions button:hover{background-color:var(--primary);color:#fff}.filter-checkbox-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.filter-checkbox-grid label{display:flex;align-items:center;gap:8px;padding:8px 10px;background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-size:13px;color:var(--text-primary)}.filter-checkbox-grid label:hover{background-color:var(--bg-hover)}.filter-checkbox-grid label.selected{background-color:#5b5fc71a;border-color:var(--primary)}.filter-checkbox-grid input[type=checkbox]{width:16px;height:16px;accent-color:#5B5FC7;cursor:pointer}@media(max-width:768px){.filter-row{flex-direction:column;align-items:stretch}.filter-item{width:100%}.filter-checkbox-grid{grid-template-columns:repeat(2,1fr)}.chart-header{flex-direction:column;align-items:flex-start;gap:12px}}.reference-editor-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.reference-editor-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.reference-editor-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-primary)}.reference-editor-header h2{margin:0;font-size:20px;font-weight:700;color:var(--text-primary)}.close-button{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .15s ease}.close-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.reference-editor-tabs{display:flex;border-bottom:1px solid var(--border-primary);padding:0 24px}.tab-button{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;margin-bottom:-1px}.tab-button:hover{color:var(--text-primary);background-color:var(--bg-hover)}.tab-button.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.reference-editor-content{flex:1;overflow-y:auto;padding:24px}.reference-table-header{display:grid;grid-template-columns:1fr 1fr 60px;gap:12px;padding:12px;background-color:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:12px;font-weight:600;font-size:13px;color:var(--text-primary)}.reference-col{text-align:left}.reference-col-action{text-align:center}.reference-table-body{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;max-height:400px;overflow-y:auto}.reference-row{display:grid;grid-template-columns:1fr 1fr 60px;gap:12px;align-items:center}.reference-input{padding:10px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-family:inherit;transition:all .15s ease;background-color:var(--bg-primary);color:var(--text-primary)}.reference-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #5b5fc71a}.remove-button{width:36px;height:36px;background-color:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .15s ease}.remove-button:hover{background-color:#fee;border-color:#fcc}.add-button{width:100%;padding:10px 16px;font-size:14px;font-weight:500;color:var(--primary);background-color:#5b5fc714;border:1px dashed var(--primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.add-button:hover{background-color:#5b5fc726}.reference-editor-footer{display:flex;justify-content:space-between;align-items:center;padding:24px;border-top:1px solid var(--border-primary)}.footer-actions{display:flex;gap:12px}.reset-button{padding:10px 16px;font-size:14px;font-weight:500;color:#666;background-color:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.reset-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.cancel-button{padding:10px 20px;font-size:14px;font-weight:500;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.cancel-button:hover{background-color:var(--bg-hover)}.save-button{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.save-button:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 3px 6px #5b5fc74d}.category-header,.category-row{grid-template-columns:1fr 1fr 1fr 1fr 60px!important}.original-entry{background-color:#5b5fc70a;border-radius:var(--radius-md);padding:4px;position:relative}.original-entry:before{content:"기본";position:absolute;left:-45px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;color:var(--primary);background-color:#5b5fc71a;padding:2px 6px;border-radius:4px}.metric-container{padding:24px;max-width:1400px;margin:0 auto}.metric-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.metric-title h1{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.metric-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.metric-source-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding:6px 12px;background-color:var(--bg-secondary);border-radius:var(--radius-md);min-width:150px;font-size:12px;color:var(--text-secondary);line-height:1.4}.metric-source-info div:first-child{font-weight:700;color:var(--text-primary)}.metric-source-info div:nth-child(2){color:var(--primary);font-weight:600}.last-updated{display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding:8px 16px;background-color:var(--bg-secondary);border-radius:var(--radius-md);min-width:220px}.update-time{font-size:13px;font-weight:600;color:var(--text-primary)}.time-ago{font-size:12px;font-weight:500;color:var(--primary)}.metric-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.metric-container .filter-section h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.metric-container .filter-grid-main{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;position:relative}.metric-container .filter-grid-detail{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;position:relative}.filter-item{position:relative;display:flex;flex-direction:column;gap:8px}.filter-item-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.filter-mode-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.filter-mode-text{font-size:13px;font-weight:600;color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:all .15s ease;padding:0}.filter-mode-text:first-child{text-align:left}.filter-mode-text:last-child{text-align:right}.filter-mode-text.active{color:var(--primary);font-weight:700}.filter-mode-text:hover{color:var(--primary)}.date-range-inputs{display:flex;align-items:center;gap:4px}.date-input{flex:1;font-size:14px!important;padding:10px 12px!important;min-width:0;box-sizing:border-box}.date-separator{font-size:14px;color:var(--text-secondary);flex-shrink:0}.filter-dropdown-button{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;font-size:14px;font-weight:500;color:var(--text-primary);background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.filter-dropdown-button:hover{border-color:var(--primary);background-color:var(--bg-hover)}.filter-dropdown-button.active{border-color:var(--primary);background-color:#5b5fc714;color:var(--primary);font-weight:600}.filter-value{flex:1;text-align:left}.dropdown-arrow{font-size:10px;color:var(--text-tertiary);margin-left:8px}.filter-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:100;max-height:300px;overflow-y:auto;padding:8px}.filter-all-btn{width:100%;padding:8px 12px;margin-bottom:8px;font-size:13px;font-weight:500;color:var(--primary);background-color:#5b5fc714;border:1px solid var(--primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.filter-all-btn:hover{background-color:#5b5fc726}.filter-option-list{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.filter-option{display:flex;align-items:center;gap:8px;padding:6px 8px;font-size:13px;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-md);transition:background-color .15s ease}.filter-option:hover{background-color:var(--bg-hover)}.filter-option input[type=checkbox]{cursor:pointer}.filter-option-btn{width:100%;padding:10px 12px;font-size:14px;font-weight:500;color:var(--text-primary);background-color:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background-color .15s ease}.filter-option-btn:hover{background-color:var(--bg-hover)}.metric-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.stat-card{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-primary)}.stat-label{font-size:13px;color:var(--text-secondary);font-weight:500;margin-bottom:8px}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.stat-breakdown{display:flex;flex-direction:column;gap:1px;font-size:11px;font-weight:500;margin-left:auto;align-self:flex-end;text-align:right;line-height:1.3}.stat-positive{color:#3b82f6}.stat-negative{color:#ef4444}.csv-download-section{display:flex;justify-content:flex-end;margin-bottom:24px}.download-csv-button{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.download-csv-button:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.download-csv-button:disabled{opacity:.6;cursor:not-allowed}.csv-download-inline{padding:6px 12px;font-size:12px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;margin-left:auto}.csv-download-inline:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 2px 4px #5b5fc733}.csv-download-inline:disabled{opacity:.5;cursor:not-allowed}.btn-apply-filter{padding:8px 16px;font-size:13px;font-weight:600;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;opacity:.5}.btn-apply-filter:disabled{cursor:not-allowed;opacity:.3}.btn-apply-filter.active{color:#fff;background-color:var(--primary);border-color:var(--primary);opacity:1;box-shadow:0 2px 4px #5b5fc733}.btn-apply-filter.active:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 3px 6px #5b5fc74d}.metric-table-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:visible;padding:0;width:100%}.table-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.table-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.pagination{display:flex;align-items:center;gap:12px}.pagination-button{padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.pagination-button:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background-color:#5b5fc70d}.pagination-button:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:13px;font-weight:500;color:var(--text-secondary);min-width:100px;text-align:center}.table-wrapper{overflow-x:auto;width:100%}.metric-table{min-width:100%;width:max-content!important;border-collapse:collapse;font-size:13px;display:table}.metric-table thead{position:sticky;top:0;z-index:10}.metric-table thead tr{background-color:var(--bg-secondary)}.metric-table th{padding:8px 12px;text-align:center;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-primary);white-space:nowrap;background-color:var(--bg-secondary);min-width:100px;max-width:250px;overflow:hidden;text-overflow:ellipsis}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.sortable-header:hover{background-color:var(--bg-hover)}.sortable-header.filtered{background-color:var(--bg-secondary);color:var(--primary);font-weight:700;position:relative}.sortable-header.filtered:after{content:"";position:absolute;inset:0;background-color:#5b5fc70f;pointer-events:none}.filter-badge{color:var(--primary);font-size:8px;margin-left:4px;vertical-align:super}.sort-indicator{font-size:10px;color:var(--primary)}.metric-table td{padding:8px 12px;color:var(--text-secondary);border-bottom:1px solid var(--border-secondary);white-space:nowrap;min-width:100px;max-width:250px;overflow:hidden;text-overflow:ellipsis;transition:background-color .15s ease;text-align:center}.metric-table td.filtered-cell{background-color:#5b5fc714;font-weight:500}.metric-table tbody tr:hover{background-color:var(--bg-hover)}.table-footer{padding:16px 24px;border-top:1px solid var(--border-primary);background-color:var(--bg-secondary)}.table-footer .info-text{margin:0;text-align:center}.metric-content{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-sm);min-height:400px;display:flex;align-items:center;justify-content:center}.metric-info{text-align:center}.metric-info p{font-size:16px;color:var(--text-primary);margin:0 0 8px}.info-text{font-size:14px;color:var(--text-secondary)}.metric-error{color:var(--error)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-stat-card{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-primary)}.skeleton-stat-label{height:16px;width:60%;margin-bottom:12px}.skeleton-stat-value{height:32px;width:80%}.skeleton-table-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:hidden}.skeleton-table-header{padding:20px 24px;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center}.skeleton-table-title{height:24px;width:120px}.skeleton-pagination{display:flex;gap:12px;align-items:center}.skeleton-pagination-btn{height:32px;width:60px}.skeleton-pagination-info{height:18px;width:100px}.skeleton-table-wrapper{padding:24px}.skeleton-table-row{display:grid;grid-template-columns:repeat(8,1fr);gap:16px;padding:12px 0;border-bottom:1px solid var(--border-secondary)}.skeleton-table-row:first-child{padding-top:0}.skeleton-table-cell{height:20px}.skeleton-filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.skeleton-filter-title{height:22px;width:100px;margin-bottom:20px}.skeleton-filter-grid-main{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.skeleton-filter-grid-detail{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.skeleton-filter-item{display:flex;flex-direction:column;gap:8px}.skeleton-filter-label{height:18px;width:70%}.skeleton-filter-input{height:42px;width:100%}@media(max-width:1400px){.filter-grid-new{grid-template-columns:repeat(4,1fr)}}@media(max-width:1024px){.filter-grid-new{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.metric-container{padding:16px}.metric-header{flex-direction:column;gap:12px}.last-updated{align-items:flex-start;width:100%}.filter-grid-new{grid-template-columns:repeat(2,1fr)}.metric-stats{grid-template-columns:1fr}}@media(max-width:480px){.filter-grid-new{grid-template-columns:1fr}}.metric-table td[data-column=지점명_분류]{background-color:#f0f8ff!important}.metric-table td[data-column=카테고리_소분류],.metric-table td[data-column=카테고리_중분류],.metric-table td[data-column=카테고리_대분류]{background-color:#fff4e6!important}.cardio-container{padding:24px;max-width:1400px;margin:0 auto}.cardio-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.cardio-header-left{display:flex;flex-direction:column;gap:4px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.last-update{font-size:13px;font-weight:500;color:var(--text-secondary)}.btn-refresh{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:6px}.btn-refresh:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.refresh-icon{font-size:16px;display:inline-block;animation:rotate 1s linear infinite}.btn-refresh:not(:disabled) .refresh-icon{animation:none}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-banner{display:flex;align-items:center;gap:12px;padding:16px 20px;margin-bottom:24px;background-color:#fef2f2;border:1px solid #FCA5A5;border-radius:var(--radius-md);color:#dc2626;font-size:14px;font-weight:500}.cardio-content{display:grid;grid-template-columns:320px 1fr;gap:24px;min-height:600px}.place-sidebar{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-primary);background-color:var(--bg-secondary)}.sidebar-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.place-count{font-size:13px;font-weight:600;color:var(--primary);background-color:#5b5fc71a;padding:4px 10px;border-radius:var(--radius-sm)}.place-list{overflow-y:auto;max-height:calc(100vh - 250px)}.place-item{width:100%;padding:12px 16px;background:none;border:none;border-bottom:1px solid var(--border-secondary);text-align:left;cursor:pointer;transition:all .15s ease;display:flex;justify-content:space-between;align-items:center;gap:12px}.place-item:hover{background-color:var(--bg-hover)}.place-item.active{background-color:#5b5fc714;border-left:3px solid var(--primary);padding-left:13px}.place-item-left{display:flex;align-items:center;gap:8px}.place-item-right{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.place-name{font-size:15px;font-weight:600;color:var(--text-primary)}.status-badge{padding:4px 10px;font-size:12px;font-weight:600;border-radius:var(--radius-sm)}.status-badge.error{background-color:#fee2e2;color:#dc2626}.status-badge.warning{background-color:#fef3c7;color:#d97706}.stat-compact{font-size:12px;font-weight:500;color:var(--text-secondary)}.place-detail{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;overflow-y:auto;max-height:calc(100vh - 200px)}.detail-header{display:flex;flex-direction:column;gap:4px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.detail-header h2{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.center-name{font-size:13px;font-weight:500;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px}.stat-card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border-primary)}.stat-card-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.stat-card-icon{font-size:20px}.stat-card-title{font-size:14px;font-weight:600;color:var(--text-secondary)}.stat-card-body{display:flex;flex-direction:column;gap:12px}.stat-card-main{display:flex;align-items:baseline;gap:4px}.stat-card-value{font-size:32px;font-weight:700;color:var(--text-primary)}.stat-card-unit{font-size:14px;font-weight:500;color:var(--text-secondary)}.stat-card-breakdown{display:flex;gap:12px;flex-wrap:wrap}.stat-item-inline{font-size:13px;font-weight:500}.section{margin-bottom:32px}.section:last-child{margin-bottom:0}.section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.pc-list{display:flex;flex-direction:column;gap:12px}.pc-card{border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden;background-color:var(--bg-primary);transition:all .15s ease}.pc-card:hover{box-shadow:var(--shadow-sm)}.pc-card-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px;background:none;border:none;cursor:pointer;text-align:left;transition:background-color .15s ease}.pc-card-header:hover{background-color:var(--bg-hover)}.pc-card-left{display:flex;align-items:center;gap:12px}.status-dot{font-size:12px;font-weight:700}.pc-id{font-size:14px;font-weight:600;color:var(--text-primary)}.pc-card-right{display:flex;align-items:center;gap:16px}.pc-connections{display:flex;gap:8px}.connection-badge{padding:4px 10px;font-size:12px;font-weight:600;color:var(--text-secondary);background-color:var(--bg-secondary);border-radius:var(--radius-sm)}.expand-icon{font-size:10px;color:var(--text-tertiary);transition:transform .15s ease}.pc-card-body{padding:0 16px 16px;border-top:1px solid var(--border-secondary);background-color:var(--bg-secondary)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-secondary)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.detail-value{font-size:13px;font-weight:600;color:var(--text-primary)}.detail-value.warning{color:#d97706}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:12px}.device-card{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:10px 12px;transition:all .2s ease}.device-card:hover{border-color:var(--border-focus);box-shadow:var(--shadow-sm)}.device-card.status-normal{border-left:3px solid #10B981}.device-card.status-error{border-left:3px solid #EF4444;background-color:#fef2f2}.device-card.status-warning{border-left:3px solid #F59E0B;background-color:#fffbeb}.device-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border-secondary)}.device-card-title{font-size:13px;font-weight:700;color:var(--text-primary)}.device-card-status{font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}.device-card-body{display:flex;flex-direction:column;gap:4px}.device-card-row{display:flex;justify-content:space-between;align-items:center;font-size:12px}.device-card-label{color:var(--text-secondary);font-weight:500;font-size:12px}.device-card-value{color:var(--text-primary);font-weight:600;font-size:12px}.device-card-timestamp{color:var(--text-tertiary);font-size:11px}.device-card-error{margin-top:8px;padding:6px 8px;background-color:#fee2e2;border-radius:var(--radius-sm);font-size:11px;color:#dc2626;font-weight:500}.empty-state{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);font-size:14px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.spinner{width:40px;height:40px;border:4px solid var(--border-primary);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-state p{font-size:14px;color:var(--text-secondary);margin:0}@media(max-width:1200px){.cardio-content{grid-template-columns:280px 1fr}}@media(max-width:1024px){.stats-grid{grid-template-columns:1fr}}@media(max-width:768px){.cardio-container{padding:16px}.cardio-content{grid-template-columns:1fr}.place-sidebar{max-height:300px}.place-list{max-height:220px}.cardio-header{flex-direction:column;gap:12px}.header-left{width:100%}.btn-refresh{width:100%;justify-content:center}}.fun-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:24px}.loader-emoji-container{display:flex;align-items:center;justify-content:center;width:48px;height:48px;overflow:hidden}.loader-emoji-track{display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1)}.loader-emoji-item{display:flex;align-items:center;justify-content:center;width:48px;height:48px;font-size:40px;line-height:1;flex-shrink:0}.loader-text-container{min-height:28px;display:flex;align-items:center;justify-content:center}.typing-text{font-size:16px;color:#666;font-weight:500}.typing-cursor{display:inline-block;margin-left:2px;animation:blink .8s infinite;color:#999}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.ground-member-container{padding:16px 24px;max-width:1400px;margin:0 auto}.ground-member-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:12px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.ground-member-container .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:0;border:none!important;border-bottom:none!important}.ground-member-container .filter-section h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.ground-member-container .filter-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:nowrap}.ground-member-container .filter-item{display:flex;flex-direction:column;gap:4px;flex:1}.ground-member-container .filter-item.compact{min-width:0;flex-shrink:1}.ground-member-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.ground-member-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;min-width:80px;height:36px}.ground-member-container .filter-select:focus{outline:none;border-color:var(--primary)}.ground-member-container .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.ground-member-container .filter-input{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);min-width:80px;height:36px;box-sizing:border-box}.ground-member-container .filter-input:focus{outline:none;border-color:var(--primary)}.ground-member-container .filter-input::placeholder{color:var(--text-tertiary)}.ground-member-container .filter-chip-group{display:flex;gap:6px;flex-wrap:nowrap}.ground-member-container .filter-chip{display:flex;align-items:center;justify-content:center;padding:0 14px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:18px;cursor:pointer;transition:all .15s ease;white-space:nowrap;height:36px}.ground-member-container .filter-chip:hover{border-color:var(--primary);color:var(--primary)}.ground-member-container .filter-chip.active{background-color:var(--primary);border-color:var(--primary);color:#fff}.ground-member-container .filter-actions{display:flex;gap:8px;border:none!important;padding:0!important;margin:0!important}.ground-member-container .btn-search{padding:0 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;height:36px}.ground-member-container .btn-search:hover{background-color:var(--primary-hover)}.ground-member-container .btn-search.pulse{animation:pulse 1.5s infinite}.ground-member-container .btn-reset{padding:0 16px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;height:36px}.ground-member-container .btn-reset:hover{background-color:var(--bg-hover);border-color:var(--text-tertiary)}.ground-member-container .metric-table-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:hidden}.ground-member-container .table-header{display:flex;justify-content:space-between;align-items:center;padding:16px 12px;border-bottom:1px solid var(--border-primary)}.ground-member-container .table-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.ground-member-container .btn-export{padding:8px 16px;font-size:14px;font-weight:500;color:var(--primary);background-color:#5b5fc714;border:1px solid rgba(91,95,199,.2);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.ground-member-container .btn-export:hover:not(:disabled){background-color:#5b5fc726;border-color:var(--primary)}.ground-member-container .btn-export:disabled{opacity:.5;cursor:not-allowed}.ground-member-container .table-wrapper{overflow-x:auto;width:100%}.ground-member-table{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}.ground-member-table thead{position:sticky;top:0;z-index:10}.ground-member-table thead tr{background-color:var(--bg-secondary)}.ground-member-table th{padding:12px 8px;text-align:center;font-weight:600;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-primary);white-space:nowrap;background-color:var(--bg-secondary)}.ground-member-table td{padding:10px 8px;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border-secondary);text-align:center;vertical-align:middle;height:44px;box-sizing:border-box}.ground-member-table td.no-border{border-bottom:none}.ground-member-table th.col-member{text-align:center}.ground-member-table td.col-member{width:80px;text-align:left!important;padding-left:12px!important;white-space:nowrap}.ground-member-table .col-phone{width:110px;white-space:nowrap}.ground-member-table .col-gender,.ground-member-table .col-age{width:45px;white-space:nowrap}.ground-member-table .col-branch{width:60px;white-space:nowrap}.ground-member-table .col-category{width:80px;white-space:nowrap}.ground-member-table .col-type{width:70px;white-space:nowrap}.ground-member-table .col-refund{width:50px;white-space:nowrap}.ground-member-table th.col-product{text-align:center}.ground-member-table td.col-product{width:180px;text-align:left!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ground-member-table .col-price{width:100px;text-align:center!important;white-space:nowrap}.ground-member-table .col-date{width:80px;white-space:nowrap}.ground-member-table .col-count{width:50px;white-space:nowrap}.ground-member-container .member-info{display:flex;align-items:center;gap:6px}.ground-member-container .member-name{font-weight:600;color:var(--text-primary);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ground-member-container .expand-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:9px;color:var(--primary);transition:transform .2s;flex-shrink:0}.ground-member-container .expand-icon.expanded{transform:rotate(90deg)}.ground-member-container .expand-icon.hidden{visibility:hidden}.ground-member-container .membership-row.expandable{cursor:pointer}.ground-member-container .membership-row.expandable:hover td{background-color:var(--bg-hover)}.ground-member-container .membership-row.active td{background-color:var(--bg-primary)}.ground-member-container .membership-row.inactive td{background-color:#f5f5f5;color:#999}.ground-member-container .membership-row.inactive .member-name{color:#999}.ground-member-container .refunded{color:var(--text-tertiary);text-decoration:line-through}.ground-member-container .badge-refund-inline{display:inline-block;margin-left:6px;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;background:#ffebee;color:#c62828;text-decoration:none}.ground-member-container .purchase-count{font-weight:600;color:#ff9800}.ground-member-container .loading-container{display:flex;justify-content:center;align-items:center;padding:60px;color:var(--text-secondary);font-size:14px}.ground-member-container .empty-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-tertiary)}.ground-member-container .empty-results-icon{font-size:40px;margin-bottom:12px;opacity:.5}@media(max-width:1200px){.ground-member-container .filter-row{flex-wrap:wrap}}@media(max-width:768px){.ground-member-container{padding:12px}.ground-member-container .filter-header{flex-direction:column;align-items:flex-start;gap:8px}.ground-member-container .filter-row{flex-direction:column;align-items:stretch}.ground-member-container .filter-item.compact,.ground-member-container .filter-input,.ground-member-container .filter-select{width:100%}.ground-member-container .filter-actions{align-self:flex-end}}.ground-member-table .col-checkin{width:60px;white-space:nowrap}.ground-member-container .btn-checkin{padding:4px 10px;font-size:12px;font-weight:500;color:var(--primary);background-color:#5b5fc714;border:1px solid rgba(91,95,199,.2);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.ground-member-container .btn-checkin:hover{background-color:#5b5fc726;border-color:var(--primary)}.attendance-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.attendance-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;width:100%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.attendance-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary);background-color:var(--bg-secondary)}.attendance-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.attendance-modal-body{flex:1;overflow-y:auto;padding:16px 20px}.attendance-loading{display:flex;justify-content:center;align-items:center;padding:40px}.attendance-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--text-tertiary)}.attendance-empty .empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}.attendance-summary{margin-bottom:12px;padding:10px 14px;background-color:var(--bg-secondary);border-radius:var(--radius-md);font-size:14px;color:var(--text-secondary)}.attendance-summary strong{color:var(--primary);font-weight:600}.attendance-table-wrapper{overflow-x:auto;max-height:400px;overflow-y:auto;border:1px solid var(--border-primary);border-radius:var(--radius-md)}.attendance-table{width:100%;border-collapse:collapse;font-size:14px}.attendance-table thead{position:sticky;top:0;z-index:5}.attendance-table thead tr{background-color:var(--bg-secondary)}.attendance-table th{padding:10px 12px;text-align:center;font-weight:600;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-primary);white-space:nowrap;background-color:var(--bg-secondary)}.attendance-table td{padding:10px 12px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-secondary);text-align:center;vertical-align:middle}.attendance-table tbody tr:hover td{background-color:var(--bg-hover)}.attendance-table td.mbs-title{text-align:left;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checkin-container{padding:16px 24px;max-width:1400px;margin:0 auto}.checkin-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:16px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.checkin-container .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.checkin-container .filter-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.checkin-container .period-info{font-size:13px;color:var(--text-secondary)}.checkin-container .filter-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;align-items:end}.checkin-container .filter-item{display:flex;flex-direction:column;gap:4px}.checkin-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.checkin-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;min-width:100px;height:36px}.checkin-container .filter-select:focus{outline:none;border-color:var(--primary)}.checkin-container .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.checkin-container .filter-input{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);height:36px;box-sizing:border-box;width:100%}.checkin-container .filter-input:focus{outline:none;border-color:var(--primary)}.checkin-container .filter-input::placeholder{color:var(--text-tertiary)}.checkin-container .filter-chip-group{display:flex;gap:6px;flex-wrap:nowrap}.checkin-container .filter-chip{display:flex;align-items:center;justify-content:center;padding:0 14px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:18px;cursor:pointer;transition:all .15s ease;white-space:nowrap;height:36px}.checkin-container .filter-chip:hover{border-color:var(--primary);color:var(--primary)}.checkin-container .filter-chip.active{background-color:var(--primary);border-color:var(--primary);color:#fff}.checkin-container .stats-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:16px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.checkin-container .stats-header{margin-bottom:14px}.checkin-container .stats-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.checkin-container .stats-cards{display:flex;gap:16px}.checkin-container .stats-card{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:12px 20px;min-width:120px;position:relative}.checkin-container .stats-help{position:absolute;top:8px;right:8px;width:16px;height:16px;border-radius:50%;background-color:var(--border-primary);color:var(--text-secondary);font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:help}.checkin-container .stats-help:after{content:attr(data-tooltip);position:absolute;bottom:100%;right:0;transform:none;background-color:var(--text-primary);color:var(--bg-primary);padding:8px 12px;border-radius:var(--radius-md);font-size:12px;font-weight:400;width:180px;white-space:normal;word-break:keep-all;text-align:left;line-height:1.4;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:100;margin-bottom:8px;box-shadow:var(--shadow-md)}.checkin-container .stats-help:hover:after{opacity:1;visibility:visible}.checkin-container .stats-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.checkin-container .stats-value{font-size:24px;font-weight:700;color:var(--text-primary)}.checkin-container .chart-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.checkin-container .chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.checkin-container .chart-header h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.checkin-container .chart-legend{display:flex;gap:16px;align-items:center}.checkin-container .legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.checkin-container .legend-line{width:20px;height:3px;border-radius:2px}.checkin-container .legend-line.hourly{background-color:var(--primary)}.checkin-container .legend-bar{width:12px;height:12px;border-radius:2px}.checkin-container .legend-bar.daily{background-color:#10b981;opacity:.5}.checkin-container .chart-container{width:100%}.checkin-container .chart-loading,.checkin-container .empty-chart{display:flex;justify-content:center;align-items:center;min-height:300px;color:var(--text-secondary)}.checkin-tooltip{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:8px 12px;box-shadow:var(--shadow-md)}.checkin-tooltip .tooltip-date{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.checkin-tooltip .tooltip-count{font-size:14px;font-weight:600;color:var(--primary)}.checkin-tooltip .tooltip-daily{font-size:14px;font-weight:600;color:#10b981;margin-top:2px}.checkin-container .list-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.checkin-container .list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px}.checkin-container .list-header-left{display:flex;align-items:center;gap:16px}.checkin-container .list-header-right{display:flex;align-items:center;gap:12px}.checkin-container .list-header h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap}.checkin-container .list-search{display:flex;align-items:center}.checkin-container .search-input{padding:6px 12px;font-size:13px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);width:180px;height:32px;box-sizing:border-box}.checkin-container .search-input:focus{outline:none;border-color:var(--primary)}.checkin-container .search-input::placeholder{color:var(--text-tertiary)}.checkin-container .btn-download{padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;white-space:nowrap;height:32px}.checkin-container .btn-download:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.checkin-container .btn-download:disabled{opacity:.5;cursor:not-allowed}.checkin-container .pagination{display:flex;align-items:center;gap:8px}.checkin-container .pagination-button{padding:6px 12px;font-size:13px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.checkin-container .pagination-button:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.checkin-container .pagination-button:disabled{opacity:.5;cursor:not-allowed}.checkin-container .pagination-info{font-size:13px;color:var(--text-secondary);min-width:60px;text-align:center}.checkin-container .loading-container{display:flex;justify-content:center;align-items:center;min-height:200px}.checkin-container .empty-results{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px;color:var(--text-secondary);gap:8px}.checkin-container .empty-results-icon{font-size:32px}.checkin-container .table-wrapper{overflow-x:auto}.checkin-container .metric-table{width:100%;border-collapse:collapse;font-size:14px}.checkin-container .metric-table thead{background-color:var(--bg-secondary)}.checkin-container .metric-table th{padding:10px 12px;font-weight:600;color:var(--text-secondary);text-align:center;border-bottom:1px solid var(--border-primary);white-space:nowrap}.checkin-container .metric-table td{padding:10px 12px;color:var(--text-primary);text-align:center;border-bottom:1px solid var(--border-secondary)}.checkin-container .metric-table tbody tr:hover{background-color:var(--bg-secondary)}.checkin-container .col-date{width:100px}.checkin-container .col-time{width:70px}.checkin-container .col-place,.checkin-container .col-name{width:80px}.checkin-container .col-phone{width:120px}.checkin-container .col-product{min-width:150px}.locker-container{padding:16px 24px;max-width:1400px;margin:0 auto}.locker-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:12px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.locker-container .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:0;border:none!important;border-bottom:none!important}.locker-container .filter-section h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.locker-container .filter-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:nowrap}.locker-container .filter-item{display:flex;flex-direction:column;gap:4px;flex:1}.locker-container .filter-item.compact{min-width:0;flex-shrink:1}.locker-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.locker-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;min-width:80px;height:36px}.locker-container .filter-select:focus{outline:none;border-color:var(--primary)}.locker-container .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.locker-container .filter-input{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);min-width:80px;height:36px;box-sizing:border-box}.locker-container .filter-input:focus{outline:none;border-color:var(--primary)}.locker-container .filter-input::placeholder{color:var(--text-tertiary)}.locker-container .filter-chip-group{display:flex;gap:6px;flex-wrap:nowrap}.locker-container .filter-chip{display:flex;align-items:center;justify-content:center;padding:0 14px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:18px;cursor:pointer;transition:all .15s ease;white-space:nowrap;height:36px}.locker-container .filter-chip:hover{border-color:var(--primary);color:var(--primary)}.locker-container .filter-chip.active{background-color:var(--primary);border-color:var(--primary);color:#fff}.locker-container .filter-actions{display:flex;gap:8px;border:none!important;padding:0!important;margin:0!important}.locker-container .btn-search{padding:0 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;height:36px}.locker-container .btn-search:hover{background-color:var(--primary-hover)}.locker-container .btn-search.pulse{animation:pulse 1.5s infinite}.locker-container .btn-reset{padding:0 16px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;height:36px}.locker-container .btn-reset:hover{background-color:var(--bg-hover);border-color:var(--text-tertiary)}.locker-container .metric-table-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:hidden}.locker-container .table-header{display:flex;justify-content:space-between;align-items:center;padding:16px 12px;border-bottom:1px solid var(--border-primary)}.locker-container .table-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.locker-container .btn-export{padding:8px 16px;font-size:14px;font-weight:500;color:var(--primary);background-color:#5b5fc714;border:1px solid rgba(91,95,199,.2);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.locker-container .btn-export:hover:not(:disabled){background-color:#5b5fc726;border-color:var(--primary)}.locker-container .btn-export:disabled{opacity:.5;cursor:not-allowed}.locker-container .table-wrapper{overflow-x:auto;width:100%}.locker-table{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}.locker-table thead{position:sticky;top:0;z-index:10}.locker-table thead tr{background-color:var(--bg-secondary)}.locker-table th{padding:12px 8px;text-align:center;font-weight:600;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-primary);white-space:nowrap;background-color:var(--bg-secondary)}.locker-table td{padding:10px 8px;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border-secondary);text-align:center;vertical-align:middle;height:44px;box-sizing:border-box}.locker-table tbody tr.active td{background-color:var(--bg-primary)}.locker-table tbody tr.inactive td{background-color:#f5f5f5;color:#999}.locker-table tbody tr:hover td{background-color:var(--bg-hover)}.zone-badge{display:inline-block;padding:4px 10px;font-size:12px;font-weight:600;border-radius:12px;white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.zone-badge.zone-color-0{background-color:#5b5fc726;color:#4a4dc4}.zone-badge.zone-color-1{background-color:#2e7d3226;color:#2e7d32}.zone-badge.zone-color-2{background-color:#f57c0026;color:#e65100}.zone-badge.zone-color-3{background-color:#0288d126;color:#0277bd}.zone-badge.zone-color-4{background-color:#c2185b26;color:#c2185b}.zone-badge.zone-color-5{background-color:#7b1fa226;color:#7b1fa2}.locker-table .col-branch{width:70px;white-space:nowrap}.locker-table .col-zone{width:180px;text-align:left!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.locker-table .col-num,.locker-table .col-name{width:80px;white-space:nowrap}.locker-table .col-phone{width:120px;white-space:nowrap}.locker-table .col-date{width:85px;white-space:nowrap}.locker-table .col-duration,.locker-table .col-status{width:70px;white-space:nowrap}.locker-table .col-memo{width:150px;text-align:left!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.locker-num-btn{padding:4px 10px;font-size:14px;font-weight:600;color:var(--primary);background-color:#5b5fc714;border:1px solid rgba(91,95,199,.2);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.locker-num-btn:hover{background-color:#5b5fc726;border-color:var(--primary)}.status-badge{display:inline-block;padding:4px 10px;font-size:12px;font-weight:600;border-radius:12px}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.inactive{background-color:#f5f5f5;color:#9e9e9e}.locker-container .empty-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-tertiary)}.locker-container .empty-results-icon{font-size:40px;margin-bottom:12px;opacity:.5}.history-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.history-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;width:100%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.history-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary);background-color:var(--bg-secondary)}.history-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.modal-close-btn{width:32px;height:32px;border:none;background:none;font-size:24px;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.modal-close-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.history-modal-body{flex:1;overflow-y:auto;padding:16px 20px}.history-loading{display:flex;justify-content:center;align-items:center;padding:40px}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--text-tertiary)}.history-empty .empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}.history-summary{margin-bottom:12px;padding:10px 14px;background-color:var(--bg-secondary);border-radius:var(--radius-md);font-size:14px;color:var(--text-secondary)}.history-summary strong{color:var(--primary);font-weight:600}.history-table-wrapper{overflow-x:auto;max-height:400px;overflow-y:auto;border:1px solid var(--border-primary);border-radius:var(--radius-md)}.history-table{width:100%;border-collapse:collapse;font-size:14px}.history-table thead{position:sticky;top:0;z-index:5}.history-table thead tr{background-color:var(--bg-secondary)}.history-table th{padding:10px 12px;text-align:center;font-weight:600;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-primary);white-space:nowrap;background-color:var(--bg-secondary)}.history-table td{padding:10px 12px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-secondary);text-align:center;vertical-align:middle}.history-table tbody tr:hover td{background-color:var(--bg-hover)}.history-table tbody tr.active td{background-color:#2e7d320d}.history-table td.memo-cell{text-align:left;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:1200px){.locker-container .filter-row{flex-wrap:wrap}.locker-container .filter-header{flex-wrap:wrap;gap:12px}.locker-container .view-mode-tabs{order:3;width:100%;justify-content:center}}@media(max-width:768px){.locker-container{padding:12px}.locker-container .filter-header{flex-direction:column;align-items:flex-start;gap:8px}.locker-container .filter-row{flex-direction:column;align-items:stretch}.locker-container .filter-item.compact,.locker-container .filter-input,.locker-container .filter-select{width:100%}.locker-container .filter-actions{align-self:flex-end}.locker-container .date-range{flex-wrap:wrap;width:100%}.locker-container .filter-input.date{flex:1;min-width:100px}}.pt-metrics-container{padding:12px 24px;max-width:1400px;margin:0 auto}.pt-metrics-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:10px 16px;margin-bottom:12px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.pt-metrics-container .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.pt-metrics-container .filter-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.pt-metrics-container .filter-row{display:flex;align-items:flex-end;gap:12px}.pt-metrics-container .filter-row.six-col{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.pt-metrics-container .filter-item{display:flex;flex-direction:column;gap:4px}.pt-metrics-container .filter-item.empty{visibility:hidden}.pt-metrics-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.pt-metrics-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;width:100%;height:36px}.pt-metrics-container .filter-select:focus{outline:none;border-color:var(--primary)}.pt-metrics-container .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.loading-spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.error-container{color:#d32f2f}.error-detail{font-size:13px;color:#999;margin-top:8px}.top-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}.filter-card .filter-inputs{display:flex;gap:12px}.filter-card .filter-item{flex:1;display:flex;flex-direction:column;gap:4px}.filter-card .filter-label{font-size:11px;color:#888}.filter-card .filter-select{padding:6px 10px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;height:32px}.filter-card .filter-select:focus{outline:none;border-color:var(--primary)}.filter-card .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.stats-card{background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #00000014}.stats-card h3{font-size:16px;font-weight:600;color:#333;margin:0 0 12px}.stats-grid{display:grid;gap:6px}.stats-grid.three-col{grid-template-columns:repeat(3,1fr)}.stats-grid.four-col{grid-template-columns:repeat(4,1fr)}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:14px;color:#888}.stat-value{font-size:22px;font-weight:700;color:#222}.main-row{display:grid;grid-template-columns:2fr 1fr;gap:16px}.chart-card{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.chart-header h3{font-size:16px;font-weight:600;color:#333;margin:0}.chart-legend{display:flex;gap:16px}.legend-item{font-size:14px;color:#666;display:flex;align-items:center;gap:6px}.legend-item:before{content:"";width:12px;height:3px;border-radius:2px}.legend-item{cursor:pointer;transition:opacity .2s}.legend-item:hover{opacity:.8}.legend-item.inactive{opacity:.4;text-decoration:line-through}.legend-item.current:before{background:#5b5fc7}.legend-item.prev:before{background:#8b8fcf}.legend-item.last-year:before{background:#a5d6a7}.legend-item.year-avg:before{background:#ffb74d}.chart-total{font-size:28px;font-weight:700;color:#222;margin-bottom:12px}.chart-container{height:320px;min-height:320px}.chart-tooltip{background:#000000d9;border-radius:8px;padding:12px 16px;color:#fff;font-size:13px;min-width:160px}.tooltip-title{font-weight:600;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.2)}.tooltip-row{display:flex;justify-content:space-between;padding:3px 0}.tooltip-row.refund{color:#ff6b6b}.tooltip-row.total{font-weight:600}.tooltip-row.cumulative{color:#4caf50;font-weight:600}.tooltip-divider{height:1px;background:#fff3;margin:8px 0}.category-column{display:flex;flex-direction:column;gap:16px}.category-card{background:linear-gradient(135deg,#fafbfc,#f5f7fa);border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #00000014;flex:1;display:flex;flex-direction:column;justify-content:center;min-height:80px;transition:transform .15s ease,box-shadow .15s ease}.category-card.clickable{cursor:pointer}.category-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.category-card h4{font-size:16px;font-weight:600;color:#333;margin:0 0 12px}.category-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.category-stat{display:flex;flex-direction:column;gap:2px}.category-stat .label{font-size:14px;color:#888}.category-stat .value,.category-stat .value.highlight{font-size:22px;font-weight:700;color:#222}@media(max-width:1100px){.top-row{grid-template-columns:1fr 1fr}.top-row .filter-card{grid-column:1 / -1}}@media(max-width:900px){.top-row,.main-row{grid-template-columns:1fr}.category-column{flex-direction:row;gap:12px}.category-card{flex:1}}@media(max-width:600px){.pt-metrics-container{padding:12px}.pt-metrics-filters{flex-direction:column;gap:10px}.stats-grid.three-col,.stats-grid.four-col{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:16px}.chart-total{font-size:18px}.category-column{flex-direction:column}}.stat-value.clickable{cursor:pointer;transition:color .2s,text-decoration .2s}.stat-value.clickable:hover{color:#5b5fc7;text-decoration:underline}.detail-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.detail-modal{background:#fff;border-radius:12px;width:100%;max-width:1100px;height:80vh;display:flex;flex-direction:column;align-items:stretch;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;line-height:1;padding:0}.modal-close:hover{color:#333}.modal-search{display:flex;gap:8px;padding:16px 24px;border-bottom:1px solid #eee}.modal-search input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:14px}.modal-search input:focus{outline:none;border-color:#5b5fc7}.modal-search button{padding:10px 20px;background:#5b5fc7;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer}.modal-search button:hover{background:#4b4fb7}.pt-modal-content{flex:1 1 auto;min-height:0;overflow:auto}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#666}.detail-table-wrapper{padding:16px 0 24px}.detail-table{width:100%;min-width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.detail-table th,.detail-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #eee;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-table th:first-child,.detail-table td:first-child{padding-left:24px}.detail-table th:last-child,.detail-table td:last-child{padding-right:24px}.detail-table th{background:#f8f9fa;font-weight:600;color:#555;position:sticky;top:0}.detail-table tbody tr:hover{background:#f8f9fa}.detail-table .no-data{text-align:center;padding:40px;color:#999}.table-count{margin-top:16px;padding-right:24px;text-align:right;font-size:13px;color:#666}@media(max-width:800px){.detail-modal{max-width:100%;height:90vh}.detail-table-wrapper{overflow-x:auto}}.detail-table.accordion-table .member-row{cursor:pointer;transition:background-color .15s ease}.detail-table.accordion-table .member-row:hover{background-color:#f8f9fa}.detail-table .expand-cell{width:30px;text-align:center}.detail-table .expand-icon{display:inline-block;font-size:10px;color:#999;transition:transform .2s ease}.detail-table .expand-icon.expanded{transform:rotate(90deg)}.detail-table .expand-icon.has-more{color:#5b5fc7}.detail-table .membership-detail-row{background:#f8f9fa}.detail-table .membership-detail-row>td{padding:0!important}.membership-detail-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0}.membership-detail-table th{padding:10px 12px;text-align:center;font-weight:600;font-size:11px;color:#333;background:linear-gradient(to bottom,#f8f9fa,#e9ecef);border-bottom:2px solid #ddd}.membership-detail-table td{padding:10px 12px;text-align:center;font-size:12px;color:#333;border-bottom:1px solid #eee;background:#fff}.membership-detail-table tbody tr:hover td{background:#f8f9fa}.detail-table .clickable-row{cursor:pointer}.detail-table .clickable-row:hover{background-color:#f8f9fa}.pt-metrics-container .skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pt-metrics-container .skeleton-title{height:18px;width:80px;margin-bottom:12px}.pt-metrics-container .skeleton-filter-label{height:14px;width:30px;margin-bottom:6px}.pt-metrics-container .skeleton-filter-select{height:36px;width:100%}.pt-metrics-container .skeleton-stat-label{height:14px;width:30px}.pt-metrics-container .skeleton-stat-value{height:26px;width:90px;margin-top:2px}.pt-metrics-container .skeleton-legend-row{display:flex;gap:16px}.pt-metrics-container .skeleton-legend-item{height:18px;width:60px}.pt-metrics-container .skeleton-chart-total{height:34px;width:100px;margin-bottom:12px}.pt-metrics-container .skeleton-chart-area{height:320px;width:100%}.pt-metrics-container .skeleton-category-title{height:18px;width:40px;margin-bottom:12px}.pt-metrics-container .skeleton-category-label{height:14px;width:60px}.pt-metrics-container .skeleton-category-value{height:26px;width:80px;margin-top:2px}.pt-member-container{padding:16px 24px;max-width:1400px;margin:0 auto}.pt-member-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:12px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:0;border:none!important;border-bottom:none!important}.filter-section h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.filter-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:nowrap;justify-content:space-between}.filter-item{display:flex;flex-direction:column;gap:4px;flex:1}.filter-item.compact{min-width:0;flex-shrink:1}.filter-item.empty{visibility:hidden}.filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;width:100%;min-width:70px;height:36px}.filter-select:focus{outline:none;border-color:var(--primary)}.filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.pt-member-container .filter-input{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);width:100%;min-width:80px;height:36px}.pt-member-container .filter-input:focus{outline:none;border-color:var(--primary)}.pt-member-container .filter-input::placeholder{color:var(--text-tertiary)}.filter-chip-group{display:flex;gap:6px;flex-wrap:nowrap;flex:1;justify-content:flex-start}.filter-chip{display:flex;align-items:center;justify-content:center;padding:0 14px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:18px;cursor:pointer;transition:all .15s ease;white-space:nowrap;height:36px;flex:1}.filter-chip input{display:none}.filter-chip:hover{border-color:var(--primary);color:var(--primary)}.filter-chip.active{background-color:var(--primary);border-color:var(--primary);color:#fff}.filter-actions{display:flex;gap:8px;border:none!important;padding:0!important;margin:0!important}.btn-search{padding:0 20px;font-size:14px;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;height:36px}.btn-search:hover{background-color:var(--primary-hover)}@keyframes pulse{0%,to{box-shadow:0 0 #5b5fc780}50%{box-shadow:0 0 0 8px #5b5fc700}}.btn-search.pulse{animation:pulse 1.5s infinite}.btn-reset{padding:0 16px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;height:36px}.btn-reset:hover{background-color:var(--bg-hover);border-color:var(--text-tertiary)}.metric-table-container{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:hidden}.table-header{display:flex;justify-content:space-between;align-items:center;padding:16px 12px;border-bottom:1px solid var(--border-primary)}.table-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.btn-export{padding:8px 16px;font-size:14px;font-weight:500;color:var(--primary);background-color:#5b5fc714;border:1px solid rgba(91,95,199,.2);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.btn-export:hover:not(:disabled){background-color:#5b5fc726;border-color:var(--primary)}.btn-export:disabled{opacity:.5;cursor:not-allowed}.pt-member-container .table-wrapper{overflow-x:auto;width:100%}.pt-member-table{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}.pt-member-table thead{position:sticky;top:0;z-index:10}.pt-member-table thead tr{background-color:var(--bg-secondary)}.pt-member-table th{padding:12px 8px;text-align:center;font-weight:600;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-primary);white-space:nowrap;background-color:var(--bg-secondary)}.pt-member-table td{padding:10px 8px;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border-secondary);text-align:center;vertical-align:middle}.col-member{width:110px;text-align:left!important;padding-left:12px!important;white-space:nowrap}.col-type{width:50px;white-space:nowrap}.col-trainer{width:60px;white-space:nowrap}.col-product{width:140px;text-align:left!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-price{width:90px;text-align:center!important;white-space:nowrap}.col-date{width:70px;white-space:nowrap}.col-count{width:40px;white-space:nowrap}.col-re{width:70px;white-space:nowrap}.col-lesson{width:50px;white-space:nowrap}.member-info{display:flex;align-items:center;gap:6px}.member-name-wrap{display:flex;flex-direction:column;gap:2px;overflow:hidden}.member-name{font-weight:600;color:var(--text-primary);font-size:14px;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-phone{font-size:12px;color:var(--text-tertiary)}.expand-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:9px;color:var(--text-tertiary);transition:transform .2s;flex-shrink:0}.expand-icon.expanded{transform:rotate(90deg)}.expand-icon.has-content{color:var(--text-primary)}.expand-icon.no-content{color:var(--text-tertiary);cursor:default}.membership-row.expandable{cursor:pointer}.membership-row.expandable:hover td{background-color:var(--bg-hover)}.membership-row.active td{background-color:var(--bg-primary)}.membership-row.inactive td{background-color:#fafafa;color:var(--text-tertiary)}.inactive-badge{opacity:.7}.no-more-text{text-align:left!important;color:var(--text-tertiary);font-style:italic;padding-left:24px!important}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge-regular{background:#f3e5f5;color:#7b1fa2}.badge-refund{background:#ffebee;color:#c62828}.re-status{display:inline-block;padding:3px 8px;border-radius:10px;font-size:12px;font-weight:600;white-space:nowrap}.re-status-convert{background:#e8f5e9;color:#2e7d32}.re-status-renew{background:#e3f2fd;color:#1565c0}.re-status-none{background:#fff3e0;color:#e65100}.purchase-count{font-weight:600;color:#ff9800}.btn-lesson{padding:5px 12px;font-size:14px;font-weight:500;color:var(--primary);background-color:transparent;border:1px solid var(--primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.btn-lesson:hover{background-color:var(--primary);color:#fff}.loading-container{display:flex;justify-content:center;align-items:center;padding:60px;color:var(--text-secondary);font-size:14px}.empty-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-tertiary)}.empty-results-icon{font-size:40px;margin-bottom:12px;opacity:.5}.lesson-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.lesson-modal{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:850px;width:100%;max-height:80vh;display:flex;flex-direction:column}.lesson-modal-header{padding:20px 24px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.lesson-modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:28px;color:var(--text-tertiary);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--text-primary)}.lesson-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-loading,.modal-empty{text-align:center;padding:40px;color:var(--text-tertiary);font-size:14px}.lesson-count{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.lesson-table{width:100%;border-collapse:collapse;font-size:14px}.lesson-table th{background:var(--bg-secondary);padding:12px 14px;text-align:center;font-size:14px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary)}.lesson-table td{padding:12px 14px;text-align:center;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-secondary)}.lesson-table tbody tr:hover{background:var(--bg-hover)}.status-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-badge.confirmed{background:#e8f5e9;color:#2e7d32}.status-badge.attended{background:#e3f2fd;color:#1565c0}.status-badge.absent{background:#fff3e0;color:#e65100}.status-badge.cancelled{background:#ffebee;color:#c62828}@media(max-width:1200px){.filter-row{flex-wrap:wrap}}@media(max-width:768px){.pt-member-container{padding:12px}.filter-header{flex-direction:column;align-items:flex-start;gap:8px}.filter-row{flex-direction:column;align-items:stretch}.filter-item.compact,.filter-input,.filter-select{width:100%}.filter-actions{align-self:flex-end}.lesson-modal{max-width:100%;max-height:90vh}}.has-tooltip{position:relative;cursor:help}.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;font-size:10px;font-weight:700;color:var(--text-tertiary);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:50%;margin-left:4px;cursor:help}.tooltip-content{display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;padding:12px 14px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;z-index:100;white-space:nowrap;text-align:left;font-weight:400;font-size:12px}.has-tooltip:hover .tooltip-content{display:block}.tooltip-content strong{display:block;margin-bottom:8px;font-size:12px;color:var(--text-primary)}.tooltip-content ul{margin:0;padding:0;list-style:none}.tooltip-content li{padding:3px 0;color:var(--text-secondary);font-size:11px}.tooltip-content li b{color:var(--text-primary);font-weight:600}.pt-trainer-container{padding:16px 24px;max-width:1400px;margin:0 auto}.pt-trainer-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:16px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.pt-trainer-container .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.pt-trainer-container .filter-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.pt-trainer-container .filter-row{display:flex;align-items:flex-end;gap:12px}.pt-trainer-container .filter-row.six-col{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.pt-trainer-container .filter-item{display:flex;flex-direction:column;gap:4px}.pt-trainer-container .filter-item.empty{visibility:hidden}.pt-trainer-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.pt-trainer-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;width:100%;height:36px}.pt-trainer-container .filter-select:focus{outline:none;border-color:var(--primary)}.pt-trainer-container .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.pt-trainer-container .period-buttons{display:flex;gap:0;height:36px}.pt-trainer-container .period-buttons.four-col{width:100%}.pt-trainer-container .period-buttons.four-col .period-btn{flex:1}.pt-trainer-container .period-btn{padding:0 10px;font-size:13px;font-weight:500;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.pt-trainer-container .period-btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.pt-trainer-container .period-btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.pt-trainer-container .period-btn:not(:first-child){border-left:none}.pt-trainer-container .period-btn:hover{background:var(--bg-hover)}.pt-trainer-container .period-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.pt-trainer-container .loading-container,.pt-trainer-container .error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-tertiary)}.pt-trainer-container .loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.pt-trainer-container .error-container{color:#d32f2f}.pt-trainer-container .stats-container{background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);padding:20px}.pt-trainer-container .stats-grid{display:grid;grid-template-columns:3fr 3fr 5fr 5fr;gap:24px}.pt-trainer-container .stats-section{display:flex;flex-direction:column}.pt-trainer-container .stats-title{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--primary)}.pt-trainer-container .header-metrics{display:flex;gap:8px}.pt-trainer-container .metric-value{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:26px;padding:0 10px;font-size:14px;font-weight:700;color:var(--primary);background:#2196f31a;border-radius:13px;cursor:default}.pt-trainer-container .metric-value.highlight{color:#388e3c;background:#388e3c26}.pt-trainer-container .metric-value:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;padding:6px 10px;font-size:11px;font-weight:500;color:#fff;background:#000000d9;border-radius:6px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:100;pointer-events:none}.pt-trainer-container .metric-value:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:2px;border:5px solid transparent;border-top-color:#000000d9;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:100}.pt-trainer-container .metric-value:hover:after,.pt-trainer-container .metric-value:hover:before{opacity:1;visibility:visible}.pt-trainer-container .stats-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.pt-trainer-container .stats-table.three-col th:nth-child(1),.pt-trainer-container .stats-table.three-col td:nth-child(1){width:40%}.pt-trainer-container .stats-table.three-col th:nth-child(2),.pt-trainer-container .stats-table.three-col td:nth-child(2){width:35%}.pt-trainer-container .stats-table.three-col th:nth-child(3),.pt-trainer-container .stats-table.three-col td:nth-child(3){width:25%}.pt-trainer-container .stats-table.five-col th,.pt-trainer-container .stats-table.five-col td{width:20%}.pt-trainer-container .stats-table th{padding:10px 8px;text-align:center;font-weight:600;font-size:12px;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.pt-trainer-container .stats-table td{padding:10px 8px;text-align:center;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-secondary)}.pt-trainer-container .stats-table .no-data{padding:24px;text-align:center;color:var(--text-tertiary)}.pt-trainer-container .clickable-row{cursor:pointer;transition:background-color .15s ease}.pt-trainer-container .clickable-row:hover{background-color:var(--bg-hover)}body.modal-open{overflow:hidden}.trainer-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:40px;overflow:hidden}.trainer-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:900px;height:70vh;min-height:400px;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.trainer-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.trainer-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.trainer-modal-close{background:none;border:none;font-size:24px;color:var(--text-tertiary);cursor:pointer;line-height:1;padding:0}.trainer-modal-close:hover{color:var(--text-primary)}.trainer-modal-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px}.trainer-modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-tertiary)}.trainer-modal-empty{text-align:center;padding:60px;color:var(--text-tertiary);font-size:14px}.trainer-modal-table-wrapper{width:100%;box-sizing:border-box;border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.trainer-modal-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}.trainer-modal-table th,.trainer-modal-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trainer-modal-table th{padding:10px 12px;text-align:center;font-weight:600;font-size:12px;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);position:sticky;top:0}.trainer-modal-table td{padding:10px 12px;text-align:center;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-secondary)}.trainer-modal-table tbody tr:last-child td{border-bottom:none}.trainer-modal-table tbody tr:hover{background:var(--bg-hover)}.trainer-modal-count{padding:12px 16px;text-align:right;font-size:12px;color:var(--text-tertiary);margin-top:12px}.trainer-modal-table.accordion-table .member-row{cursor:pointer;transition:background-color .15s ease}.trainer-modal-table.accordion-table .member-row:hover{background-color:var(--bg-hover)}.trainer-modal-table .expand-cell{width:30px;text-align:center}.trainer-modal-table .expand-icon{display:inline-block;font-size:10px;color:var(--text-tertiary);transition:transform .2s ease}.trainer-modal-table .expand-icon.expanded{transform:rotate(90deg)}.trainer-modal-table .membership-detail-row{background:var(--bg-secondary)}.trainer-modal-table .membership-detail-row>td{padding:0!important}.membership-detail-container{padding:16px 20px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:500px;transform:translateY(0)}}.trainer-modal-table .expand-icon.has-more{color:var(--primary)}.membership-detail-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;background:var(--bg-primary);border-radius:8px;overflow:hidden;border:1px solid var(--border-primary)}.membership-detail-table th{padding:10px 12px;text-align:center;font-weight:600;font-size:11px;color:var(--text-primary);background:linear-gradient(to bottom,#f8f9fa,#e9ecef);border-bottom:2px solid var(--border-primary)}.membership-detail-table td{padding:10px 12px;text-align:center;font-size:12px;color:var(--text-primary);border-bottom:1px solid var(--border-secondary);background:var(--bg-primary)}.membership-detail-table tbody tr:last-child td{border-bottom:none}.membership-detail-table tbody tr:hover td{background:var(--bg-hover)}.membership-detail-table tbody tr.refunded td{opacity:.6}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.badge-trial{background:#e3f2fd;color:#1976d2}.badge-regular{background:#e8f5e9;color:#388e3c}.badge-refund{background:#ffebee;color:#d32f2f}.status-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.status-badge.attended{background:#e8f5e9;color:#388e3c}.status-badge.absent{background:#ffebee;color:#d32f2f}.status-badge.success{background:#e8f5e9;color:#388e3c}.status-badge.warning{background:#fff3e0;color:#f57c00}@media(max-width:1400px){.pt-trainer-container .stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.pt-trainer-container .stats-grid{grid-template-columns:1fr}}@media(max-width:768px){.pt-trainer-container{padding:12px}.pt-trainer-container .filter-row.six-col{grid-template-columns:1fr 1fr}.pt-trainer-container .filter-item.empty{display:none}.detail-modal{max-width:100%;max-height:90vh}}.pt-review-container{padding:16px 24px;max-width:1400px;margin:0 auto}.pt-review-container .filter-section{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:16px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.pt-review-container .filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.pt-review-container .filter-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.pt-review-container .filter-row{display:flex;align-items:flex-end;gap:12px}.pt-review-container .filter-row.six-col{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.pt-review-container .filter-item{display:flex;flex-direction:column;gap:4px}.pt-review-container .filter-item.empty{visibility:hidden}.pt-review-container .filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.pt-review-container .filter-select{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;width:100%;height:36px}.pt-review-container .filter-select:focus{outline:none;border-color:var(--primary)}.pt-review-container .filter-select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.pt-review-container .filter-input{padding:8px 12px;font-size:14px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);width:100%;height:36px;box-sizing:border-box}.pt-review-container .filter-input:focus{outline:none;border-color:var(--primary)}.pt-review-container .filter-input::placeholder{color:var(--text-muted)}.pt-review-container .period-buttons{display:flex;gap:0;height:36px;width:100%}.pt-review-container .period-btn{flex:1;padding:0 8px;font-size:13px;font-weight:500;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.pt-review-container .period-btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.pt-review-container .period-btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0;border-left:none}.pt-review-container .period-btn:not(:first-child):not(:last-child){border-left:none}.pt-review-container .period-btn:hover{background:var(--bg-hover)}.pt-review-container .period-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.pt-review-container .star-filter-buttons{display:flex;gap:0;height:36px;width:100%}.pt-review-container .star-filter-btn{flex:1;padding:0 4px;font-size:12px;font-weight:500;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.pt-review-container .star-filter-btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.pt-review-container .star-filter-btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0;border-left:none}.pt-review-container .star-filter-btn:not(:first-child):not(:last-child){border-left:none}.pt-review-container .star-filter-btn:hover{background:var(--bg-hover)}.pt-review-container .star-filter-btn.active{color:#fff}.pt-review-container .star-filter-btn:nth-child(1).active{background:#e53935;border-color:#e53935}.pt-review-container .star-filter-btn:nth-child(2).active{background:#ff5722;border-color:#ff5722}.pt-review-container .star-filter-btn:nth-child(3).active{background:#ff9800;border-color:#ff9800}.pt-review-container .star-filter-btn:nth-child(4).active{background:#ffb300;border-color:#ffb300;color:#333}.pt-review-container .star-filter-btn:nth-child(5).active{background:#ffc107;border-color:#ffc107;color:#333}.pt-review-container .loading-container,.pt-review-container .error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-tertiary)}.pt-review-container .loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.pt-review-container .error-container{color:#d32f2f}.pt-review-container .stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}.pt-review-container .stats-cards.three-col{grid-template-columns:repeat(3,1fr)}.pt-review-container .stat-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);text-align:center}.pt-review-container .stat-card.clickable{cursor:pointer;transition:all .2s ease}.pt-review-container .stat-card.clickable:hover{border-color:var(--primary);box-shadow:0 2px 8px #0000001a}.pt-review-container .stat-card.clickable.active{border-color:var(--primary);background:linear-gradient(135deg,#3b82f60d,#3b82f61a);box-shadow:0 2px 12px #3b82f633}.pt-review-container .stat-card.clickable.active .stat-label{color:var(--primary)}.pt-review-container .stat-label{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.pt-review-container .stat-value{font-size:28px;font-weight:700;color:var(--text-primary)}.pt-review-container .stat-rate{font-size:14px;font-weight:500;color:var(--primary);margin-left:6px}.pt-review-container .review-table-container{background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);overflow:hidden}.pt-review-container .review-table-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.pt-review-container .review-table-header h3{margin:0;font-size:15px;font-weight:600;color:var(--text-primary)}.pt-review-container .review-count{font-size:13px;color:var(--text-tertiary)}.pt-review-container .review-table-wrapper{overflow-x:auto;max-height:calc(100vh - 400px);min-height:300px}.pt-review-container .review-table{width:100%;border-collapse:collapse;font-size:13px}.pt-review-container .review-table th{padding:12px 10px;text-align:center;font-weight:600;font-size:12px;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:1}.pt-review-container .review-table td{padding:10px;text-align:center;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-secondary)}.pt-review-container .review-table tbody tr:hover{background:var(--bg-hover)}.pt-review-container .review-table tbody tr.no-review{opacity:.5}.pt-review-container .review-table .no-data{padding:40px;text-align:center;color:var(--text-tertiary)}.pt-review-container .star-cell{white-space:nowrap}.pt-review-container .stars{font-size:12px;letter-spacing:-1px}.pt-review-container .stars.star-5{color:#ffc107}.pt-review-container .stars.star-4{color:#ffb300}.pt-review-container .stars.star-3{color:#ff9800}.pt-review-container .stars.star-2{color:#ff5722}.pt-review-container .stars.star-1{color:#e53935}.pt-review-container .text-btn,.pt-review-container .photo-btn{padding:4px 10px;font-size:12px;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .15s ease}.pt-review-container .text-btn{background:#e3f2fd;color:#1976d2}.pt-review-container .text-btn:hover{background:#bbdefb}.pt-review-container .photo-btn{background:#e8f5e9;color:#388e3c}.pt-review-container .photo-btn:hover{background:#c8e6c9}.pt-review-container .text-cell{text-align:left;max-width:300px}.pt-review-container .text-preview{display:block;font-size:12px;color:var(--text-primary);white-space:normal;word-break:break-word;line-height:1.5}.pt-review-container .tags-cell{max-width:180px;text-align:left}.pt-review-container .tags-preview{display:block;max-width:180px;font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:help}.pt-review-container .tags-preview:hover{white-space:normal;overflow:visible;position:relative;z-index:10;background:var(--bg-primary);box-shadow:0 2px 8px #00000026;padding:8px;border-radius:4px;max-width:350px}.review-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:40px}.review-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.review-modal.image-modal{max-width:800px}.review-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.review-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.review-modal-close{background:none;border:none;font-size:24px;color:var(--text-tertiary);cursor:pointer;line-height:1;padding:0}.review-modal-close:hover{color:var(--text-primary)}.review-modal-content{flex:1;overflow-y:auto;padding:20px}.review-modal-content .review-text{font-size:14px;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;margin:0}.review-modal-content .modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--text-tertiary)}.review-modal-content .no-images{text-align:center;color:var(--text-tertiary);padding:40px}.review-modal-content .image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.review-modal-content .image-item{aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid var(--border-primary);transition:transform .2s ease}.review-modal-content .image-item:hover{transform:scale(1.02)}.review-modal-content .image-item img{width:100%;height:100%;object-fit:cover}@media(max-width:1200px){.pt-review-container .stats-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.pt-review-container{padding:12px}.pt-review-container .filter-row.six-col{grid-template-columns:1fr 1fr}.pt-review-container .filter-item.empty{display:none}.pt-review-container .stats-cards{grid-template-columns:1fr 1fr}.pt-review-container .stat-value{font-size:22px}.review-modal{max-width:100%;max-height:90vh;margin:20px}}@media(max-width:480px){.pt-review-container .stats-cards{grid-template-columns:1fr}}.reregistration-container{padding:20px;max-width:1400px;margin:0 auto;height:calc(100vh - 120px)}.content-layout{display:flex;gap:20px;height:100%}.member-list-panel{flex:7;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden}.member-list-panel .filter-section{padding:12px 16px;border-bottom:1px solid #eee;flex-shrink:0}.filter-grid-inline{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.filter-grid-4cols{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:end}.filter-item{display:flex;flex-direction:column;gap:4px}.reregistration-container .filter-item label{font-size:12px;font-weight:500;color:#666}.reregistration-container .filter-item select,.reregistration-container .filter-item input{height:32px;padding:0 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:#fff;min-width:100px}.reregistration-container .filter-item select:focus,.reregistration-container .filter-item input:focus{outline:none;border-color:#1976d2}.search-input-wrapper{display:flex;gap:6px}.search-input-wrapper input{width:140px}.search-btn{height:32px;padding:0 12px;background:#1976d2;color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background .2s}.search-btn:hover{background:#1565c0}.search-hint{font-size:10px;font-weight:400;color:#999}.search-input-inline{position:relative;display:flex;align-items:center}.search-input-inline input{width:100%;height:32px;padding:0 32px 0 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:#fff}.search-input-inline input:focus{outline:none;border-color:#1976d2}.search-btn-inside{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:24px;height:24px;padding:0;background:transparent;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity .2s}.search-btn-inside:hover{opacity:1}.week-filter-btns{display:flex;gap:6px;flex-wrap:nowrap}.week-filter-btn{height:32px;padding:0 10px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap;display:flex;align-items:center;gap:4px}.week-filter-btn:hover{background:#f5f5f5}.week-filter-btn.week-1{border-color:#ef5350;color:#c62828}.week-filter-btn.week-2{border-color:#ff7043;color:#e64a19}.week-filter-btn.week-3{border-color:#26a69a;color:#00897b}.week-filter-btn.week-4{border-color:#42a5f5;color:#1976d2}.week-filter-btn.week-etc{border-color:#9e9e9e;color:#616161}.week-filter-btn.week-1.active{background:#ffebee;border-color:#c62828;color:#c62828}.week-filter-btn.week-2.active{background:#fbe9e7;border-color:#e64a19;color:#e64a19}.week-filter-btn.week-3.active{background:#e0f2f1;border-color:#00897b;color:#00897b}.week-filter-btn.week-4.active{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.week-filter-btn.week-etc.active{background:#eee;border-color:#616161;color:#616161}.week-filter-btn .count{font-weight:600;margin-left:2px}.member-count{margin-left:auto;font-size:13px;font-weight:600;color:#1976d2}.panel-header{padding:16px 20px;border-bottom:1px solid #eee}.panel-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.loading-state,.empty-state{padding:40px;text-align:center;color:#888}.table-wrapper{flex:1;overflow-x:auto}.member-table{width:100%;border-collapse:collapse;font-size:13px}.member-table thead{background:#f8f9fa;position:sticky;top:0;z-index:10}.member-table th{padding:12px 10px;text-align:center;font-weight:600;color:#555;border-bottom:1px solid #eee;white-space:nowrap}.member-table tbody tr{cursor:pointer;transition:background .15s}.member-table tbody tr:hover{background:#f5f7fa}.member-table tbody tr.selected{background:#e3f2fd}.member-table td{padding:12px 10px;border-bottom:1px solid #f0f0f0;white-space:nowrap;text-align:center}.member-table .member-name{font-weight:500;color:#333;min-width:120px;max-width:140px;text-align:left}.member-table .product-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;text-align:left;position:relative;cursor:default}.member-table .product-name[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:0;top:100%;background:#333;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:9999;margin-top:4px;pointer-events:none}.member-table .remaining{font-weight:600}.member-table .remaining .total{font-weight:400;color:#999}.name-phone{display:flex;flex-direction:column;gap:2px}.name-phone .name{font-weight:500}.name-phone .phone{font-size:11px;color:#999}.member-table .month-start-remaining,.member-table .month-end-expected{text-align:center;color:#666}.member-table .consumption-rate,.member-table .consumption-end{color:#666}.member-table .consumption-end.warning{color:#ff1744;font-weight:600}.member-table .end-date{color:#666}.member-table .end-date.warning{color:#ff1744;font-weight:600}.week-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600}.week-badge.week-1{background:#ffebee;color:#c62828}.week-badge.week-2{background:#fbe9e7;color:#e64a19}.week-badge.week-3{background:#e0f2f1;color:#00897b}.week-badge.week-4{background:#e3f2fd;color:#1976d2}.week-badge.week-etc{background:#eee;color:#616161}.week-badge.week-none{background:#f5f5f5;color:#999}.future-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500}.future-badge.yes{background:#e8f5e9;color:#2e7d32}.future-badge.no{background:#f5f5f5;color:#999}.future-cell{position:relative}.future-badge.has-tooltip{cursor:pointer;position:relative}.future-tooltip{display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:10px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:9999;margin-top:6px;box-shadow:0 2px 8px #0003}.future-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#333}.future-badge.has-tooltip:hover .future-tooltip{display:block}.tooltip-row{line-height:1.5}.tooltip-row strong{font-weight:600}.tooltip-divider{height:1px;background:#fff3;margin:6px 0}.memo-count .memo-indicator{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#1976d2;color:#fff;border-radius:50%;font-size:11px;font-weight:600}.detail-panel{flex:3;min-width:360px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden}.no-selection{flex:1;display:flex;align-items:center;justify-content:center;color:#999;text-align:center;padding:40px}.no-selection p{line-height:1.6}.member-detail-header{padding:16px;border-bottom:1px solid #eee;background:#fafafa}.member-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.member-info h3{margin:0;font-size:18px;font-weight:600}.member-info .contact{color:#666;font-size:13px}.membership-info{display:flex;flex-direction:column;gap:6px}.info-row{display:flex;font-size:13px}.info-row .label{width:70px;color:#888}.info-row .value{color:#333}.info-row .remaining-value{font-weight:600;color:#1976d2}.info-row.future .value.success{color:#2e7d32;font-weight:500}.memo-input-section{padding:16px;border-bottom:1px solid #eee}.memo-input-section textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;resize:none;font-family:inherit}.memo-input-section textarea:focus{outline:none;border-color:#1976d2}.image-preview-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.image-preview-item{position:relative;width:60px;height:60px}.image-preview-item img{width:100%;height:100%;object-fit:cover;border-radius:6px}.image-preview-item .remove-image-btn{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#f44336;color:#fff;border:none;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.memo-action-bar{display:flex;gap:8px;margin-top:12px;align-items:center}.memo-action-bar .probability-select{height:34px;padding:0 10px;border:1px solid #ddd;border-radius:6px;font-size:13px;background:#fff;cursor:pointer;min-width:110px}.memo-action-bar .probability-select:focus{outline:none;border-color:#1976d2}.attach-btn{padding:8px 12px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s;white-space:nowrap}.attach-btn:hover{background:#eee}.save-btn{flex:1;padding:8px 16px;background:#1976d2;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.save-btn:hover:not(:disabled){background:#1565c0}.save-btn:disabled{background:#ccc;cursor:not-allowed}.memo-list{flex:1;overflow-y:auto;padding:16px}.memo-list h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#555}.no-memos{color:#999;font-size:13px;text-align:center;padding:20px}.memo-card{background:#f8f9fa;border-radius:8px;padding:12px;margin-bottom:12px}.memo-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.memo-author-info{display:flex;align-items:center;gap:6px}.memo-author-profile{width:28px;height:28px;border-radius:50%;object-fit:cover}.memo-author-placeholder{width:28px;height:28px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:14px}.memo-header .author{font-weight:500;font-size:12px;color:#333}.memo-header .date{font-size:12px;color:#999;margin-left:auto}.memo-menu-wrapper{position:relative}.memo-menu-btn{width:24px;height:24px;background:transparent;border:none;color:#999;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px}.memo-menu-btn:hover{background:#eee}.memo-menu-dropdown{display:none;position:absolute;right:0;top:100%;background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #00000026;z-index:100;min-width:80px}.memo-menu-wrapper:hover .memo-menu-dropdown{display:block}.memo-menu-dropdown button{width:100%;padding:8px 12px;border:none;background:transparent;text-align:left;cursor:pointer;font-size:12px}.memo-menu-dropdown button:hover{background:#f5f5f5}.memo-probability{margin-top:8px;display:flex;align-items:center;gap:6px}.memo-probability .prob-label{font-size:12px;color:#888}.memo-edit-area{margin-top:8px}.memo-edit-area textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px;resize:none;font-family:inherit;box-sizing:border-box}.memo-edit-area textarea:focus{outline:none;border-color:#1976d2}.memo-edit-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.memo-edit-actions .cancel-btn{padding:6px 12px;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;font-size:12px;cursor:pointer}.memo-edit-actions .cancel-btn:hover{background:#eee}.memo-edit-actions .save-btn{padding:6px 12px;background:#1976d2;color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer}.memo-edit-actions .save-btn:hover{background:#1565c0}.memo-content{font-size:14px;color:#333;line-height:1.5;white-space:pre-wrap}.memo-images{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.memo-images img{width:80px;height:80px;object-fit:cover;border-radius:6px;cursor:pointer;transition:opacity .2s}.memo-images img:hover{opacity:.8}.probability-cell{text-align:center}.prob-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500}.prob-badge.prob-unknown{background:#f5f5f5;color:#999}.prob-badge.prob-checking{background:#fff3e0;color:#ef6c00}.prob-badge.prob-low{background:#ffebee;color:#c62828}.prob-badge.prob-medium{background:#fff9c4;color:#f9a825}.prob-badge.prob-high{background:#e8f5e9;color:#2e7d32}.probability-select-section{padding:12px 16px;border-bottom:1px solid #eee;background:#fafafa}.probability-select-section label{display:block;font-size:12px;font-weight:500;color:#666;margin-bottom:8px}.probability-select-section select{width:100%;height:36px;padding:0 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.probability-select-section select:focus{outline:none;border-color:#1976d2}.name-with-profile{display:flex;align-items:center;gap:8px}.profile-img{width:28px;height:28px;border-radius:50%;object-fit:cover}.profile-placeholder{width:28px;height:28px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:14px}.detail-tabs{display:flex;border-bottom:1px solid #eee;background:#fafafa}.detail-tabs .tab-btn{flex:1;padding:12px 16px;border:none;background:transparent;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.detail-tabs .tab-btn:hover{color:#333;background:#f0f0f0}.detail-tabs .tab-btn.active{color:#1976d2;border-bottom-color:#1976d2;background:#fff}.probability-buttons{margin-top:12px;padding-top:12px;border-top:1px solid #eee}.probability-buttons label{display:block;font-size:12px;font-weight:500;color:#666;margin-bottom:8px}.prob-btn-group{display:flex;flex-wrap:wrap;gap:6px}.prob-btn{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:11px;cursor:pointer;transition:all .15s;background:#fff}.prob-btn:hover{border-color:#999}.prob-btn.selected{border-width:2px}.prob-btn.prob-0{color:#ef6c00}.prob-btn.prob-0.selected{background:#fff3e0;border-color:#ef6c00}.prob-btn.prob-1{color:#c62828}.prob-btn.prob-1.selected{background:#ffebee;border-color:#c62828}.prob-btn.prob-2{color:#e65100}.prob-btn.prob-2.selected{background:#fff3e0;border-color:#e65100}.prob-btn.prob-3{color:#f9a825}.prob-btn.prob-3.selected{background:#fff9c4;border-color:#f9a825}.prob-btn.prob-4{color:#43a047}.prob-btn.prob-4.selected{background:#e8f5e9;border-color:#43a047}.prob-btn.prob-5{color:#2e7d32}.prob-btn.prob-5.selected{background:#c8e6c9;border-color:#2e7d32}.lesson-list{padding:16px;overflow-y:auto;flex:1}.lesson-list h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#555}.no-lessons{color:#999;font-size:13px;text-align:center;padding:20px}.lesson-cards{display:flex;flex-direction:column;gap:8px}.lesson-card{display:grid;grid-template-columns:55px 75px 45px 70px auto;align-items:center;gap:8px;padding:10px 12px;background:#f8f9fa;border-radius:6px;font-size:13px;line-height:24px}.lesson-card.cancelled{opacity:.5;text-decoration:line-through}.lesson-card.noshow{background:#ffebee}.lesson-date{font-weight:500;color:#333}.lesson-time{color:#666}.lesson-trainer{color:#666;flex:1}.lesson-badge{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600}.lesson-badge.cancel{background:#f5f5f5;color:#999}.lesson-badge.noshow{background:#ffcdd2;color:#c62828}.review-list{padding:16px;overflow-y:auto;flex:1}.review-list h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#555}.no-reviews{color:#999;font-size:13px;text-align:center;padding:20px}.review-cards{display:flex;flex-direction:column;gap:10px}.review-card{background:#f8f9fa;border-radius:8px;padding:12px}.review-header{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;gap:8px;margin-bottom:8px}.review-rating{font-size:12px}.review-trainer-info{display:flex;align-items:center;gap:6px}.review-trainer-profile{width:24px;height:24px;border-radius:50%;object-fit:cover}.review-trainer-placeholder{width:24px;height:24px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:12px}.review-trainer{font-size:13px;color:#333;font-weight:500}.review-date{font-size:12px;color:#999;text-align:right}.review-content{font-size:14px;color:#333;line-height:1.5;white-space:pre-wrap}.memo-input-wrapper{position:relative;padding:16px;border-bottom:1px solid #eee}.memo-input-wrapper textarea{width:100%;padding:12px 12px 50px;border:1px solid #ddd;border-radius:8px;font-size:14px;resize:none;font-family:inherit;min-height:100px;box-sizing:border-box}.memo-input-wrapper textarea:focus{outline:none;border-color:#1976d2}.memo-input-wrapper .image-preview-list{margin:8px 0}.memo-overlay-actions{position:absolute;bottom:24px;left:24px;right:24px;display:flex;align-items:center;gap:8px;background:#fffffff2;padding:6px 8px;border-radius:6px}.probability-select-mini{height:28px;padding:0 8px;border:1px solid #ddd;border-radius:4px;font-size:12px;background:#fff;cursor:pointer;min-width:100px}.probability-select-mini:focus{outline:none;border-color:#1976d2}.probability-select-mini.prob-0{background:#fff3e0;border-color:#ef6c00;color:#ef6c00}.probability-select-mini.prob-1{background:#ffebee;border-color:#c62828;color:#c62828}.probability-select-mini.prob-2{background:#fff3e0;border-color:#e65100;color:#e65100}.probability-select-mini.prob-3{background:#fff9c4;border-color:#f9a825;color:#f9a825}.probability-select-mini.prob-4{background:#e8f5e9;border-color:#43a047;color:#43a047}.probability-select-mini.prob-5{background:#c8e6c9;border-color:#2e7d32;color:#2e7d32}.attach-btn-mini{width:28px;height:28px;padding:0;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.attach-btn-mini:hover{background:#eee}.save-btn-mini{margin-left:auto;height:28px;padding:0 14px;background:#1976d2;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer}.save-btn-mini:hover:not(:disabled){background:#1565c0}.save-btn-mini:disabled{background:#ccc;cursor:not-allowed}.lesson-card .lesson-main{display:flex;align-items:center;gap:8px;flex-shrink:0}.lesson-card .lesson-count{background:#e3f2fd;color:#1976d2;padding:4px 6px;border-radius:4px;font-size:11px;font-weight:600;min-width:40px;text-align:center;display:flex;align-items:center;justify-content:center;height:24px}.lesson-card .lesson-sub{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.lesson-card .lesson-title{color:#888;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-card .lesson-status{display:flex;align-items:center;gap:4px;flex-shrink:0}.lesson-badge.attended{background:#e8f5e9;color:#2e7d32}@media(max-width:1200px){.content-layout{flex-direction:column}.detail-panel{min-width:auto;max-height:500px}}@media(max-width:768px){.filter-row{flex-wrap:wrap}.filter-item{min-width:100%}.search-item{max-width:none}}.usage-log-container{min-height:100vh;background-color:var(--bg-secondary)}.usage-log-content{padding:24px;max-width:1400px;margin:0 auto}.usage-log-container .filter-section{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:24px}.period-button-group{display:flex;gap:8px}.period-btn{padding:8px 20px;border:1px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.period-btn:hover{background:var(--bg-hover);border-color:var(--primary)}.period-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.summary-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:20px;text-align:center}.summary-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.summary-value{font-size:28px;font-weight:700;color:var(--primary)}.chart-section{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px}.chart-section h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.chart-container{width:100%}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.stats-grid.three-columns{grid-template-columns:1fr 1fr 1fr}.stats-section{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:16px}.stats-section.full-width{grid-column:1 / -1}.stats-section h2{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 10px}.stats-table-wrapper{overflow-x:auto}.stats-table{width:100%;border-collapse:collapse}.stats-table th{padding:8px 10px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);position:sticky;top:0;z-index:1}.stats-table td{padding:6px 10px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.stats-table tr:last-child td{border-bottom:none}.stats-table tr:hover td{background:var(--bg-hover)}.rank-cell{width:44px;text-align:center}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:700;background:var(--bg-secondary);color:var(--text-secondary)}.rank-badge.rank-1{background:linear-gradient(135deg,gold,#ffb700);color:#000}.rank-badge.rank-2{background:linear-gradient(135deg,silver,#a0a0a0);color:#000}.rank-badge.rank-3{background:linear-gradient(135deg,#cd7f32,sienna);color:#fff}.name-cell{font-weight:500}.number-cell{text-align:right;font-weight:600;color:var(--primary)}.time-cell{color:var(--text-secondary);font-size:12px}.recent-active td{background:#10b9810d}.online-badge{display:inline-block;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;color:#fff;background:var(--success, #10b981);border-radius:10px}.menu-path-cell{display:flex;align-items:center;gap:6px}.menu-path-cell .tab-name{font-weight:600;font-size:12px;color:var(--text-primary)}.menu-path-cell .path-separator{color:var(--text-tertiary);font-size:11px}.menu-path-cell .subtab-name{color:var(--text-secondary);font-size:12px}.empty-message{text-align:center;color:var(--text-secondary);padding:24px}.loading-state,.error-state{text-align:center;padding:48px;color:var(--text-secondary);font-size:16px}.error-state{color:var(--error)}@media(max-width:1200px){.stats-grid.three-columns{grid-template-columns:1fr 1fr}}@media(max-width:1024px){.summary-cards{grid-template-columns:repeat(3,1fr)}.stats-grid,.stats-grid.three-columns{grid-template-columns:1fr}}@media(max-width:640px){.usage-log-content{padding:16px}.summary-cards{grid-template-columns:1fr}.usage-log-header{flex-direction:column;gap:12px}.filter-chip-group{flex-wrap:wrap}.custom-date-range{flex-direction:column;align-items:stretch}}.clickable-row{cursor:pointer;transition:background-color .15s ease}.clickable-row:hover td{background:var(--bg-hover)!important}.user-detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.user-detail-modal{background:var(--bg-primary);border-radius:var(--radius-lg);width:100%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.modal-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.close-btn{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .15s ease}.close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-loading{padding:48px;text-align:center;color:var(--text-secondary)}.modal-content{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.user-summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.user-summary-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:16px;text-align:center}.user-summary-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.user-summary-value{font-size:20px;font-weight:700;color:var(--primary)}.user-summary-value.small{font-size:14px}.user-detail-section{display:flex;flex-direction:column;gap:12px}.user-detail-section h3{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.top-menus-list{display:flex;flex-direction:column;gap:8px}.top-menu-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-secondary);border-radius:var(--radius-md)}.top-menu-item .menu-path{font-size:13px;color:var(--text-primary)}.top-menu-item .menu-visits{font-size:13px;font-weight:600;color:var(--primary)}.recent-logs-table{width:100%;border-collapse:collapse;border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden}.recent-logs-table th{padding:10px 12px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.recent-logs-table td{padding:10px 12px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.recent-logs-table tr:last-child td{border-bottom:none}.log-time{white-space:nowrap;color:var(--text-secondary);font-size:12px}.log-detail{color:var(--text-secondary)}.action-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.action-badge.action-login{background:var(--primary-light, rgba(59, 130, 246, .15));color:var(--primary)}.action-badge.action-tab{background:#10b98126;color:var(--success)}.action-badge.action-subtab{background:#8b5cf626;color:#8b5cf6}.subtab-modal .modal-header h2{display:flex;align-items:center;gap:4px}.subtab-modal .modal-header .tab-name{font-weight:700;color:var(--text-primary)}.subtab-modal .modal-header .path-separator{color:var(--text-tertiary);font-size:14px}.subtab-modal .modal-header .subtab-name{font-weight:500;color:var(--text-secondary)}.user-summary-cards.two-columns{grid-template-columns:repeat(2,1fr)}.hourly-chart-container{background:var(--bg-secondary);border-radius:var(--radius-md);padding:12px}.subtab-modal .recent-logs-table{max-height:350px;overflow-y:auto;display:block}.subtab-modal .recent-logs-table thead,.subtab-modal .recent-logs-table tbody,.subtab-modal .recent-logs-table tr{display:table;width:100%;table-layout:fixed}.subtab-modal .recent-logs-table thead{position:sticky;top:0;z-index:1}.subtab-modal .recent-logs-table th,.subtab-modal .recent-logs-table td{padding:6px 10px;font-size:12px}@media(max-width:640px){.user-summary-cards{grid-template-columns:repeat(2,1fr)}.user-detail-modal{max-height:90vh}}.tab-navigation{display:flex;gap:4px;margin-bottom:16px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:4px}.tab-btn{flex:1;padding:10px 20px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.tab-btn.active{background:var(--primary);color:#fff;font-weight:600}.summary-value.success{color:var(--success, #10b981)}.summary-value.fail{color:var(--error, #ef4444)}.phone-cell{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:13px}.fail-count{color:var(--error, #ef4444)!important}.detail-cell{color:var(--text-secondary);font-size:12px;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-cell{text-align:center}.result-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600}.result-badge.success{background:#10b98126;color:var(--success, #10b981)}.result-badge.fail{background:#ef444426;color:var(--error, #ef4444)}.success-row td{background:#10b98108}.fail-row td{background:#ef444408}.login-attempts-table{max-height:600px;overflow-y:auto}.stats-grid.two-columns{grid-template-columns:1fr 1.5fr}@media(max-width:1024px){.stats-grid.two-columns{grid-template-columns:1fr}}.border-ratio-section{margin-bottom:24px}.chart-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.chart-card h3{margin:0 0 12px;font-size:16px;color:#333}.horizontal-bar-section{padding:8px 0}.bar-container{display:flex;height:32px;border-radius:6px;overflow:hidden;background:#f5f5f5;margin-bottom:16px}.bar-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;transition:width .3s ease;min-width:0}.bar-segment.cash{background-color:#5b5fc7}.bar-segment.plate{background-color:#4caf50}.bar-legend{display:flex;flex-direction:column;gap:8px}.bar-legend .legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.bar-legend .legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.bar-legend .legend-dot.cash{background-color:#5b5fc7}.bar-legend .legend-dot.plate{background-color:#4caf50}.bar-legend .legend-value{margin-left:auto;font-weight:500;color:#666}.weekly-chart-section{margin-top:24px;padding-top:20px;border-top:1px solid #eee}.weekly-chart-section h4{margin:0 0 16px;font-size:14px;color:#666;font-weight:500}.border-ranking-dual{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.ranking-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.ranking-card h3{margin:0 0 16px;font-size:16px;color:#333}.ranking-table{width:100%;border-collapse:collapse;table-layout:fixed}.ranking-table th,.ranking-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #eee}.ranking-table th{font-weight:600;color:#666;font-size:13px;background:#f9f9f9}.ranking-table td{font-size:14px}.ranking-table td.cash{color:#5b5fc7;font-weight:500}.ranking-table td.plate{color:#4caf50;font-weight:500}.product-ranking .ranking-table th:nth-child(1),.product-ranking .ranking-table td:nth-child(1){width:50px}.product-ranking .ranking-table th:nth-child(2),.product-ranking .ranking-table td:nth-child(2){width:auto}.product-ranking .ranking-table th:nth-child(3),.product-ranking .ranking-table td:nth-child(3){width:80px}.product-ranking .ranking-table th:nth-child(4),.product-ranking .ranking-table td:nth-child(4){width:90px}.product-ranking .ranking-table th:nth-child(5),.product-ranking .ranking-table td:nth-child(5){width:90px}.border-products{display:grid;grid-template-columns:1fr 1fr;gap:20px}.product-ranking{background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.product-ranking h3{margin:0 0 12px;font-size:16px;color:#333}.ranking-table.total-row{margin-bottom:0}.ranking-table.total-row thead tr th{background:#f5f5f5}.ranking-table.total-row tbody tr.total{background:#fafafa;font-weight:600}.ranking-table.total-row tbody tr.total td{border-bottom:2px solid #ddd}.border-tooltip{background:#000000d9;color:#fff;padding:12px 16px;border-radius:6px;font-size:13px}.border-tooltip .tooltip-title{font-weight:600;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.2)}.border-tooltip .tooltip-row{display:flex;justify-content:space-between;gap:24px;padding:2px 0}.border-tooltip .tooltip-row.cash span:last-child{color:#9599e2}.border-tooltip .tooltip-row.plate span:last-child{color:#81c784}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-chart{height:100px}.skeleton-chart-large{height:320px}.skeleton-table{height:300px}.no-data-message{text-align:center;padding:60px 20px;color:#888;font-size:14px;background:#fafafa;border-radius:6px}.error-message{text-align:center;padding:40px;color:#f44336;font-size:16px}@media(max-width:1024px){.border-ranking-dual,.border-products{grid-template-columns:1fr}}.my-page{display:flex;flex-wrap:wrap;min-height:calc(100vh - 60px);background-color:var(--bg-primary)}.mobile-header{display:none}.my-sidebar{width:25%;min-width:280px;max-width:360px;background-color:var(--bg-secondary);border-right:1px solid var(--border-primary);padding:32px 24px}.profile-section{display:flex;flex-direction:column;align-items:center;text-align:center}.profile-image{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--border-secondary);margin-bottom:20px}.profile-image-placeholder{width:120px;height:120px;border-radius:50%;background-color:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:600;margin-bottom:20px}.profile-name{font-size:22px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.profile-info{width:100%}.profile-phone,.profile-email{font-size:14px;color:var(--text-secondary);margin:4px 0;word-break:break-all}.my-content{flex:1;padding:24px 32px;overflow-x:auto}.tab-header{display:flex;gap:8px;border-bottom:1px solid var(--border-primary);margin-bottom:24px}.tab-button{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;font-size:15px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-content{min-height:400px}.coupon-tab,.coupon-table-container{width:100%}.coupon-tab .table-wrapper{overflow-x:auto}.coupon-table{width:100%;border-collapse:collapse;font-size:13px}.coupon-table th,.coupon-table td{padding:12px 16px;text-align:center;border-bottom:1px solid var(--border-primary)}.coupon-table th{background-color:var(--bg-secondary);font-weight:600;color:var(--text-primary);white-space:nowrap}.coupon-table td{color:var(--text-secondary)}.coupon-table tbody tr:hover{background-color:var(--bg-hover)}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-active{background-color:#d4edda;color:#155724}.status-expired{background-color:#f8d7da;color:#721c24}.status-used{background-color:#e2e3e5;color:#383d41}.code-cell{font-family:monospace;font-size:11px;color:#666}.empty-row{text-align:center;padding:40px!important;color:#666}.loading-indicator{text-align:center;padding:40px;color:#666}.error-message{text-align:center;padding:40px;color:#dc3545}.coupon-no-phone{text-align:center;padding:60px 20px;color:#666}.coupon-no-phone h3{margin-bottom:16px;color:#333}.coupon-no-phone p{margin:8px 0;font-size:14px}.row-inactive{opacity:.5}.coupon-filter-buttons{display:flex;align-items:center;gap:8px;margin-bottom:12px}.coupon-filter-btn{padding:6px 12px;border:1px solid var(--border-primary);border-radius:4px;background-color:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s ease}.coupon-filter-btn:hover{background-color:var(--bg-hover)}.coupon-filter-btn.active{background-color:var(--primary);border-color:var(--primary);color:#fff;font-weight:500}.coupon-filter-count{font-size:12px;color:var(--text-tertiary);margin-left:8px}.coupon-image-buttons{display:flex;gap:4px;justify-content:center}.image-download-btn{background-color:#f0f0f0;border:1px solid #ddd;cursor:pointer;font-size:12px;padding:4px 10px;border-radius:4px;transition:all .2s;color:#333}.image-download-btn:hover{background-color:#e0e0e0}.image-save-btn{background-color:var(--primary);border:1px solid var(--primary);cursor:pointer;font-size:12px;padding:4px 10px;border-radius:4px;transition:all .2s;color:#fff;font-weight:500}.image-save-btn:hover{background-color:var(--primary-hover)}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding:16px 0}.pagination button{padding:8px 12px;border:1px solid var(--border-primary);background-color:var(--bg-secondary);color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s}.pagination button:hover:not(:disabled){background-color:var(--bg-hover)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.page-info{padding:0 16px;font-size:13px;color:var(--text-secondary)}.coupon-preview-overlay{position:fixed;inset:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.coupon-preview-modal{position:relative;max-width:640px}.coupon-preview-image{max-width:100%;max-height:70vh;border-radius:8px;box-shadow:0 8px 32px #0000004d}.coupon-download-btn{position:absolute;bottom:-50px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.coupon-download-btn:hover{transform:translate(-50%) scale(1.05);box-shadow:0 4px 16px #667eea66}.coupon-close-btn{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:8px;line-height:1;transition:all .2s}.coupon-close-btn:hover{transform:scale(1.2)}.coupon-save-modal{position:relative;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;align-items:center}.coupon-save-guide{margin-top:16px;padding:12px 20px;background-color:#fffffff2;border-radius:8px;text-align:center}.coupon-save-guide p{margin:0;font-size:14px;font-weight:500;color:#333;line-height:1.5}.coupon-cards{display:none}@media(max-width:768px){.my-page{flex-direction:column;min-height:100vh}.mobile-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:14px 16px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-primary);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.mobile-header-logo{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.mobile-logout-btn{padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);background-color:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;min-height:36px}.mobile-logout-btn:active{background-color:var(--bg-hover)}.my-sidebar{width:100%;max-width:none;min-width:auto;border-right:none;border-bottom:1px solid var(--border-primary);padding:16px}.profile-section{flex-direction:row;align-items:center;text-align:left;gap:16px}.profile-image,.profile-image-placeholder{width:56px;height:56px;font-size:22px;margin-bottom:0;flex-shrink:0}.profile-info{flex:1;min-width:0}.profile-name{font-size:15px;font-weight:600;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-phone,.profile-email{margin:2px 0;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-content{padding:16px;flex:1}.tab-header{margin-bottom:16px}.tab-button{padding:12px 20px;font-size:14px;min-height:44px}.coupon-table-container .table-wrapper{display:none}.coupon-cards{display:block}.coupon-card{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px}.coupon-card.inactive{opacity:.5}.coupon-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.coupon-card-name{font-size:15px;font-weight:600;color:var(--text-primary);flex:1;margin-right:8px}.coupon-card-status .status-badge{font-size:11px;padding:4px 8px}.coupon-card-info{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.coupon-card-row{display:flex;justify-content:space-between;font-size:13px}.coupon-card-label{color:var(--text-tertiary)}.coupon-card-value{color:var(--text-secondary)}.coupon-card-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border-primary)}.coupon-card-actions .image-download-btn,.coupon-card-actions .image-save-btn{flex:1;min-height:40px;font-size:13px}.coupon-card-empty{text-align:center;padding:40px 20px;color:var(--text-tertiary);background-color:var(--bg-secondary);border-radius:var(--radius-lg)}.pagination{flex-wrap:wrap;gap:6px}.pagination button{min-height:40px;padding:8px 16px}.coupon-filter-buttons{flex-wrap:wrap}.coupon-filter-btn{min-height:36px}}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;height:100vh}
