.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4a90a4,#357a8a);padding:20px}.login-container{width:100%;max-width:400px;background:var(--white);border-radius:20px;box-shadow:var(--shadow-lg);overflow:hidden}.login-header{text-align:center;padding:40px 20px 30px;background:linear-gradient(135deg,#4a90a4,#357a8a);color:var(--white)}.logo-icon{font-size:48px;margin-bottom:12px}.login-header h1{font-size:28px;font-weight:700;margin-bottom:4px}.login-header p{font-size:14px;opacity:.9}.login-form{padding:30px 24px}.form-group{margin-bottom:20px}.form-group label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-color)}.input-hint{display:block;margin-top:6px;font-size:12px;color:var(--text-muted)}.timer{font-size:14px;font-weight:600;color:var(--danger-color)}.verification-info{text-align:center;padding:20px;background:var(--primary-light);border-radius:var(--radius-sm);margin-bottom:24px}.verification-info p{color:var(--text-color);line-height:1.6}.verification-info strong{color:var(--primary-color)}.login-divider{display:flex;align-items:center;margin:24px 0}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.login-divider span{padding:0 16px;color:var(--text-muted);font-size:13px}.verification-actions{display:flex;justify-content:space-between;margin-top:20px}.btn-link{background:none;border:none;color:var(--primary-color);font-size:14px;cursor:pointer;padding:8px}.btn-link:hover:not(:disabled){text-decoration:underline}.btn-link:disabled{color:var(--text-muted);cursor:not-allowed}.login-footer{text-align:center;padding:16px;background:var(--bg-color);border-top:1px solid var(--border-color)}.login-footer p{font-size:12px;color:var(--text-muted)}@media(max-width:480px){.login-page{padding:0;align-items:flex-start}.login-container{max-width:100%;min-height:100vh;border-radius:0}.login-header{padding-top:60px}}.register-container{max-width:440px}.step-indicator{display:flex;align-items:center;justify-content:center;padding:20px 24px;background:var(--bg-color);border-bottom:1px solid var(--border-color)}.step{display:flex;flex-direction:column;align-items:center;gap:6px}.step span{width:28px;height:28px;border-radius:50%;background:var(--border-color);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.step p{font-size:11px;color:var(--text-muted);white-space:nowrap}.step.active span{background:var(--primary-color);color:var(--white)}.step.active p{color:var(--primary-color);font-weight:600}.step.completed span{background:var(--success-color);color:var(--white)}.step-line{width:40px;height:2px;background:var(--border-color);margin:0 8px 20px}.input-with-button{display:flex;gap:8px}.input-with-button input{flex:1}.input-with-button .btn{white-space:nowrap;min-width:80px}.required{color:var(--danger-color)}.completion-form{text-align:center;padding:60px 24px}.completion-icon{font-size:64px;margin-bottom:20px}.completion-form h2{font-size:24px;color:var(--success-color);margin-bottom:12px}.completion-form p{color:var(--text-color);margin-bottom:8px}.completion-form .sub-text{color:var(--text-muted);font-size:14px}@media(max-width:480px){.step-indicator{padding:16px 12px}.step-line{width:24px}.step p{font-size:10px}}.calendar-day-modal{max-width:400px;width:90%;max-height:80vh;overflow-y:auto}.calendar-day-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #eee}.calendar-day-modal .modal-header h3{margin:0;font-size:18px;color:#333}.calendar-day-modal .modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;line-height:1}.calendar-day-modal .modal-body{padding:20px}.calendar-day-modal .product-list h4{margin:0 0 15px;font-size:14px;color:#666}.calendar-day-modal .product-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8f9fa;border-radius:8px;margin-bottom:10px}.calendar-day-modal .product-info{display:flex;align-items:center;gap:8px}.calendar-day-modal .product-name{font-weight:500;color:#333}.calendar-day-modal .product-qty{color:#007bff;font-weight:600}.calendar-day-modal .delivery-type-badge{font-size:11px;padding:2px 6px;background:#e9ecef;border-radius:4px;color:#666}.calendar-day-modal .product-actions{display:flex;gap:8px}.calendar-day-modal .btn-sm{padding:6px 10px;font-size:12px;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.calendar-day-modal .btn-change{background:#e3f2fd;color:#1976d2}.calendar-day-modal .btn-change:hover{background:#bbdefb}.calendar-day-modal .btn-quantity{background:#fff3e0;color:#f57c00}.calendar-day-modal .btn-quantity:hover{background:#ffe0b2}.calendar-day-modal .no-products{text-align:center;padding:30px;color:#666}.calendar-day-modal .add-product-section{margin-top:20px;padding-top:15px;border-top:1px solid #eee}.calendar-day-modal .btn-add-product{width:100%;padding:12px;background:#f5f5f5;border:2px dashed #ddd;border-radius:8px;color:#666;font-size:14px;cursor:pointer;transition:all .2s}.calendar-day-modal .btn-add-product:hover{background:#e8f4fc;border-color:#007bff;color:#007bff}.calendar-day-modal .change-form{display:flex;flex-direction:column;gap:20px}.calendar-day-modal .form-group{display:flex;flex-direction:column;gap:8px}.calendar-day-modal .form-group label{font-size:13px;font-weight:500;color:#666}.calendar-day-modal .current-value{padding:10px 12px;background:#f8f9fa;border-radius:6px;color:#333;font-weight:500}.calendar-day-modal .form-select{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.calendar-day-modal .form-select:focus{outline:none;border-color:#007bff}.calendar-day-modal .quantity-control{display:flex;align-items:center;gap:10px}.calendar-day-modal .qty-btn{width:36px;height:36px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.calendar-day-modal .qty-btn:hover{background:#f5f5f5}.calendar-day-modal .qty-input{width:60px;text-align:center;padding:8px;border:1px solid #ddd;border-radius:6px;font-size:16px}.calendar-day-modal .help-text{font-size:12px;margin:5px 0 0}.calendar-day-modal .help-text.warning{color:#f44336}.calendar-day-modal .apply-type-options{display:flex;gap:15px}.calendar-day-modal .radio-option{display:flex;align-items:center;gap:6px;cursor:pointer}.calendar-day-modal .radio-option input[type=radio]{width:16px;height:16px;cursor:pointer}.calendar-day-modal .radio-option span{font-size:14px;color:#333}.calendar-day-modal .modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:15px 20px;border-top:1px solid #eee}.calendar-day-modal .btn-cancel{padding:10px 20px;background:#f5f5f5;border:none;border-radius:6px;color:#666;font-size:14px;cursor:pointer}.calendar-day-modal .btn-cancel:hover{background:#e0e0e0}.calendar-day-modal .btn-primary{padding:10px 20px;background:#007bff;border:none;border-radius:6px;color:#fff;font-size:14px;cursor:pointer}.calendar-day-modal .btn-primary:hover{background:#0069d9}.calendar-day-modal .btn-primary:disabled{background:#ccc;cursor:not-allowed}.post-board{margin-top:16px}.post-board .card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014}.post-board .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.post-board .card-header h3{margin:0;font-size:18px;color:#333;display:flex;align-items:center;gap:8px}.board-title{display:flex;flex-direction:column;gap:2px}.board-subtitle{font-size:11px;color:#888;margin-left:24px}.new-reply-badge{background:#ff4757;color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.btn-write{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:14px;cursor:pointer;transition:background .2s}.btn-write:hover{background:#2980b9}.post-board .message{padding:10px;border-radius:8px;margin-bottom:12px;font-size:14px}.post-board .message.success{background:#d4edda;color:#155724}.post-board .message.error{background:#f8d7da;color:#721c24}.post-board .empty-state{text-align:center;padding:40px 20px;color:#888}.post-board .empty-icon{font-size:48px;display:block;margin-bottom:12px}.post-board .empty-hint{font-size:13px;color:#aaa;margin-top:8px}.post-board .loading-state{text-align:center;padding:40px;color:#888}.post-list{display:flex;flex-direction:column;gap:8px}.post-item{padding:12px;background:#f8f9fa;border-radius:8px;cursor:pointer;transition:background .2s}.post-item:hover{background:#e9ecef}.post-item.has-new-reply{background:#fff3cd;border:1px solid #ffc107}.post-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.post-title{font-size:15px;font-weight:500;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-badge{font-size:16px;animation:shake .5s ease-in-out infinite}@keyframes shake{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.post-footer{display:flex;align-items:center;gap:12px;font-size:12px;color:#888}.badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.badge-pending{background:#e9ecef;color:#666}.badge-replied{background:#d4edda;color:#155724}.badge-closed{background:#dee2e6;color:#495057}.reply-count{margin-left:auto}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:400px;max-height:80vh;overflow-y:auto}.modal-detail{max-height:90vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eee}.modal-header h3{margin:0;font-size:16px;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-close{background:none;border:none;font-size:24px;color:#888;cursor:pointer;padding:0;line-height:1}.modal-body{padding:16px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px;border-top:1px solid #eee}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#333}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3498db}.form-group textarea{resize:vertical;min-height:100px}.btn-cancel{background:#e9ecef;color:#333;border:none;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer}.btn-submit{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer}.btn-submit:disabled{background:#bdc3c7;cursor:not-allowed}.post-content{padding:16px;background:#f8f9fa;border-radius:8px;margin-bottom:12px;font-size:14px;line-height:1.6;white-space:pre-wrap}.post-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:#888;margin-bottom:16px}.replies-section{border-top:1px solid #eee;padding-top:16px}.replies-section h4{margin:0 0 12px;font-size:14px;color:#333}.no-replies{text-align:center;color:#888;font-size:13px;padding:20px}.replies-list{display:flex;flex-direction:column;gap:8px;max-height:250px;overflow-y:auto}.reply-item{padding:10px 12px;border-radius:12px;font-size:14px}.reply-item.from-agency{background:#e3f2fd;margin-right:20px}.reply-item.from-student{background:#e8f5e9;margin-left:20px}.reply-header{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12px}.reply-writer{font-weight:500;color:#333}.reply-date{color:#888}.reply-content{color:#333;line-height:1.5;white-space:pre-wrap}.reply-input-section{margin-top:16px;display:flex;flex-direction:column;gap:8px}.reply-input-section textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:14px;resize:vertical;min-height:60px;box-sizing:border-box}.btn-reply{align-self:flex-end;background:#27ae60;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer}.btn-reply:disabled{background:#bdc3c7;cursor:not-allowed}.main-page{min-height:100vh;background:var(--bg-color);display:flex;flex-direction:column}.logout-btn{background:#fff3;border:none;color:var(--white);padding:8px 12px;border-radius:6px;font-size:13px;cursor:pointer}.logout-btn:hover{background:#ffffff4d}.student-banner{background:linear-gradient(135deg,#4a90a4,#357a8a);color:var(--white);padding:20px;text-align:center}.student-name{font-size:20px;margin-bottom:4px}.student-name strong{font-weight:700}.student-detail{font-size:14px;opacity:.9}.tabs{display:flex;background:var(--white);position:sticky;top:56px;z-index:99}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:transparent;border:none;font-size:12px;color:var(--text-muted);cursor:pointer;transition:all .2s}.tab-icon{font-size:20px}.tab-label{font-weight:500}.tab.active{color:var(--primary-color);background:var(--primary-light)}.main-content{flex:1;padding:16px}.tab-content{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header h3{font-size:16px;font-weight:600;color:var(--text-color);margin:0}.card h3{font-size:16px;font-weight:600;color:var(--text-color);margin-bottom:16px}.btn-edit{padding:6px 16px;font-size:13px;font-weight:500;background:var(--primary-light);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:6px;cursor:pointer;transition:all .2s}.btn-edit:hover{background:var(--primary-color);color:var(--white)}.edit-buttons{display:flex;gap:8px}.btn-cancel{padding:6px 12px;font-size:13px;background:var(--white);color:var(--text-muted);border:1px solid var(--border-color);border-radius:6px;cursor:pointer}.btn-cancel:hover:not(:disabled){background:var(--bg-color)}.btn-save{padding:6px 16px;font-size:13px;font-weight:500;background:var(--primary-color);color:var(--white);border:none;border-radius:6px;cursor:pointer}.btn-save:hover:not(:disabled){background:var(--primary-dark)}.btn-save:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.edit-input{width:100%;max-width:180px;padding:8px 10px;font-size:14px;border:1px solid var(--primary-color);border-radius:6px;text-align:right}.edit-input:focus{outline:none;box-shadow:0 0 0 2px #4a90a433}.address-input-row{display:flex;gap:8px;align-items:center;flex:1;justify-content:flex-end}.address-input-row .edit-input{flex:1;max-width:none;min-width:120px}.btn-address-search{padding:8px 12px;font-size:12px;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;white-space:nowrap}.btn-address-search:hover{background:#357a8a}.message{padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.message.success{background:#d4edda;color:#155724}.message.error{background:#f8d7da;color:#721c24}.info-list{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f0f0f0}.info-item:last-child{border-bottom:none}.info-item .label{font-size:14px;color:var(--text-muted);min-width:80px}.info-item .value{font-size:14px;color:var(--text-color);text-align:right;flex:1;word-break:break-word}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-icon{font-size:48px;display:block;margin-bottom:16px;opacity:.5}.empty-state p{font-size:15px;margin-bottom:4px}.empty-state .sub{font-size:13px;color:var(--text-muted)}.loading-state{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.day-product-list{display:flex;flex-direction:column;gap:12px}.day-product-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-color);border-radius:8px}.day-label{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:var(--white);border-radius:50%;font-size:14px;font-weight:600;flex-shrink:0}.product-select{flex:1;padding:10px 12px;font-size:14px;border:1px solid var(--border-color);border-radius:6px;background:var(--white);cursor:pointer}.product-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a90a433}.product-name{flex:1;font-size:14px;color:var(--text-color)}.product-name small{color:var(--text-muted);font-size:12px}.no-product{color:var(--text-muted)}.product-row-card{margin-top:16px;padding:16px;background:var(--bg-color);border-radius:10px;border:1px solid var(--border-color)}.product-row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px dashed var(--border-color)}.row-number{font-weight:600;color:var(--primary-color);font-size:14px}.btn-remove-row{padding:4px 10px;font-size:12px;background:#fee;color:#c44;border:1px solid #c44;border-radius:4px;cursor:pointer}.btn-remove-row:hover{background:#c44;color:#fff}.row-info{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.row-info-item{display:flex;flex-direction:column;gap:4px;flex:1;min-width:90px}.row-info-item .label{font-size:11px;color:var(--text-muted)}.row-info-item .value{font-size:13px;color:var(--text-color);font-weight:500}.edit-input-sm{padding:6px 8px;font-size:13px;border:1px solid var(--border-color);border-radius:4px;width:100%}.edit-input-sm:focus{outline:none;border-color:var(--primary-color)}.day-product-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.day-product-cell{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:#fff;border-radius:6px;border:1px solid #e8e8e8;min-height:90px}.day-badge{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;border-radius:50%;font-size:11px;font-weight:600}.product-select-sm{width:100%;padding:4px 2px;font-size:11px;border:1px solid var(--border-color);border-radius:4px;text-align:center}.product-name-sm{font-size:11px;color:var(--text-color);text-align:center;word-break:keep-all}.quantity-input-sm{width:100%;max-width:50px;padding:4px 2px;font-size:12px;text-align:center;border:1px solid var(--border-color);border-radius:4px;margin-top:4px}.quantity-input-sm:focus{outline:none;border-color:var(--primary-color)}.btn-add-row{width:100%;padding:12px;margin-top:16px;background:var(--primary-light);color:var(--primary-color);border:2px dashed var(--primary-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-add-row:hover{background:var(--primary-color);color:#fff;border-style:solid}.btn-add-product{padding:12px 24px;margin-top:16px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.btn-add-product:hover{background:var(--primary-dark)}@media(max-width:480px){.header{padding:12px 16px}.student-banner{padding:16px}.main-content{padding:12px}.card{padding:16px}}@supports (padding: env(safe-area-inset-top)){.header{padding-top:calc(16px + env(safe-area-inset-top))}}.day-product-cell.suspended{background:#f5f5f5;border-color:#ccc;opacity:.8}.day-badge.suspended{background:#999}.suspended-info{display:flex;flex-direction:column;align-items:center;gap:6px}.suspended-label{font-size:11px;color:#999;font-weight:500}.btn-resume-sm{padding:4px 8px;font-size:10px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn-resume-sm:hover{background:#388e3c}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:360px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:18px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:20px}.modal-info{margin:0 0 20px;padding:12px;background:var(--bg-color);border-radius:8px;text-align:center;font-size:14px}.modal-footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color)}.modal-footer button{flex:1;padding:12px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-color);margin-bottom:8px}.form-input{width:100%;padding:12px;font-size:14px;border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a90a426}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-label{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-color);border-radius:8px;cursor:pointer;transition:background .2s}.radio-label:hover{background:#e8e8e8}.radio-label input[type=radio]{width:18px;height:18px;accent-color:var(--primary-color)}.radio-label span{font-size:14px;color:var(--text-color)}.btn-danger{background:#e74c3c;color:#fff;border:none}.btn-danger:hover{background:#c0392b}.btn-primary{background:var(--primary-color);color:#fff;border:none}.btn-primary:hover{background:var(--primary-dark)}.help-message{background:#fff8e1;border:1px solid #ffca28;border-radius:8px;padding:12px 16px;margin:12px 0;font-size:13px;color:#795548;display:flex;align-items:center;gap:8px}.row-action-buttons{display:flex;gap:8px;align-items:center}.btn-all-suspend{background:#ff9800;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;font-weight:500;transition:background .2s}.btn-all-suspend:hover{background:#f57c00}.btn-all-resume{background:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;font-weight:500;transition:background .2s}.btn-all-resume:hover{background:#388e3c}.btn-row-edit{background:#2196f3;color:#fff;border:none;padding:5px 10px;border-radius:5px;font-size:12px;cursor:pointer;transition:background .2s}.btn-row-edit:hover{background:#1976d2}.btn-row-cancel{background:#9e9e9e;color:#fff;border:none;padding:5px 10px;border-radius:5px;font-size:12px;cursor:pointer;transition:background .2s}.btn-row-cancel:hover{background:#757575}.btn-row-cancel:disabled{opacity:.6;cursor:not-allowed}.btn-row-save{background:#4caf50;color:#fff;border:none;padding:5px 10px;border-radius:5px;font-size:12px;cursor:pointer;transition:background .2s}.btn-row-save:hover{background:#388e3c}.btn-row-save:disabled{opacity:.6;cursor:not-allowed}.quantity-input-sm.no-spinner{-moz-appearance:textfield;appearance:textfield;text-align:center}.quantity-input-sm.no-spinner::-webkit-outer-spin-button,.quantity-input-sm.no-spinner::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.suspended-label.once{background:#ff9800;color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700}.auto-resume-hint{font-size:9px;color:#888;margin-top:2px;display:block}.quick-date-buttons{display:flex;gap:8px;margin-bottom:10px}.quick-date-btn{flex:1;padding:10px 8px;border:1px solid var(--border-color);background:#fff;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-color);cursor:pointer;transition:all .2s}.quick-date-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.quick-date-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.product-change-info{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:#f8f9fa;border-radius:8px;margin-bottom:16px}.change-item{display:flex;align-items:center;gap:8px;width:100%}.change-label{font-size:13px;color:#666;min-width:70px}.change-value{font-weight:600;font-size:14px}.change-value.old{color:#dc3545;text-decoration:line-through}.change-value.new{color:#28a745}.change-arrow{font-size:20px;color:var(--primary-color);font-weight:700}.modal-note{font-size:12px;color:#666;text-align:center;margin-top:12px;padding:8px;background:#fff3cd;border-radius:4px}.calendar-card{padding:15px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.calendar-title{margin:0;font-size:18px;color:#333}.month-nav-btn{width:36px;height:36px;border:1px solid #ddd;border-radius:50%;background:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.month-nav-btn:hover{background:#f5f5f5;border-color:var(--primary-color);color:var(--primary-color)}.loading-state{text-align:center;padding:40px;color:#666}.loading-state .loading-icon{font-size:32px;display:block;margin-bottom:10px}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:5px}.weekday{text-align:center;padding:8px 0;font-size:13px;font-weight:600;color:#666}.weekday.weekend{color:#dc3545}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{min-height:70px;padding:5px;background:#fafafa;border-radius:4px;cursor:pointer;transition:background .2s;display:flex;flex-direction:column}.calendar-day:hover:not(.weekend){background:#e8f4fc}.calendar-day.other-month{opacity:.4}.calendar-day.weekend{background:#fff5f5;cursor:default}.calendar-day.today{border:2px solid var(--primary-color)}.calendar-day.has-products{background:#e8f5e9}.calendar-day.has-products:hover:not(.weekend){background:#c8e6c9}.day-number{font-size:13px;font-weight:600;color:#333;margin-bottom:3px}.calendar-day.weekend .day-number{color:#dc3545}.calendar-day.other-month .day-number{color:#999}.day-products{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.day-product-item{display:flex;align-items:center;gap:3px;font-size:10px;padding:2px 4px;background:#fff;border-radius:3px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.day-product-item .product-name{color:#333;overflow:hidden;text-overflow:ellipsis}.day-product-item .product-qty{color:var(--primary-color);font-weight:600;flex-shrink:0}.day-product-more{font-size:10px;color:#666;text-align:center}.calendar-help{margin-top:15px;padding:10px;background:#fff3cd;border-radius:6px;font-size:13px;color:#856404;text-align:center}@media(max-width:480px){.calendar-day{min-height:55px;padding:3px}.day-number{font-size:11px}.day-product-item{font-size:9px;padding:1px 3px}.day-product-item .product-qty{display:none}}.billing-card{margin-top:15px}.billing-title{font-size:16px;font-weight:600;color:#333;margin-bottom:15px}.billing-table{width:100%;border-collapse:collapse;font-size:13px}.billing-table th{background:#f8f9fa;padding:10px 6px;border:1px solid #dee2e6;font-weight:600;color:#333}.billing-table td{padding:8px 6px;border:1px solid #dee2e6}.billing-table .product-name{font-weight:500}.billing-table .center{text-align:center}.billing-table .right{text-align:right}.billing-table .quantity{color:var(--primary-color);font-weight:600}.billing-table .amount{font-weight:500}.billing-table tfoot .total-row{background:#e7f3ff;font-weight:700}.billing-table .total-amount{color:#dc3545;font-size:14px}.billing-info{margin-top:10px;padding:8px 12px;background:#f0f4f8;border-radius:6px;font-size:12px;color:#666;text-align:center}@media(max-width:480px){.billing-table{font-size:11px}.billing-table th,.billing-table td{padding:6px 4px}.billing-title{font-size:14px}}.payment-card{padding:20px}.payment-title{font-size:18px;font-weight:600;color:#333;margin-bottom:20px}.payment-notice{background:linear-gradient(135deg,#fff3e0,#ffe0b2);padding:15px;border-radius:10px;margin-bottom:20px;text-align:center}.payment-notice .notice-main{font-size:15px;font-weight:600;color:#e65100;margin-bottom:8px}.payment-notice .notice-sub{font-size:13px;color:#666;margin:3px 0}.payment-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.payment-option{display:flex;align-items:center;padding:15px;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;transition:all .2s ease;background:#fff}.payment-option:hover{border-color:var(--primary-color);background:#f8f9fa}.payment-option.selected{border-color:var(--primary-color);background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.payment-option input[type=radio]{margin-right:12px;width:18px;height:18px}.payment-option .option-icon{font-size:24px;margin-right:12px}.payment-option .option-label{flex:1;font-size:15px;font-weight:500;color:#333}.payment-option .current-badge{background:var(--primary-color);color:#fff;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600}.cash-notice{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);padding:20px;border-radius:10px;margin-top:15px}.cash-notice h4{font-size:15px;color:#2e7d32;margin-bottom:10px}.cash-notice>p{font-size:13px;color:#666;margin-bottom:12px}.cash-notice .account-info{background:#fff;padding:15px;border-radius:8px;text-align:center}.cash-notice .account-info .bank{font-size:14px;color:#666;margin-bottom:5px}.cash-notice .account-info .account{font-size:20px;font-weight:700;color:#1976d2;margin-bottom:5px}.cash-notice .account-info .holder{font-size:13px;color:#333}.cash-notice .cash-note{margin-top:12px;font-size:12px;color:#888;text-align:center}.payment-message{padding:12px;border-radius:8px;margin-top:15px;text-align:center;font-size:14px}.payment-message.success{background:#d4edda;color:#155724}.payment-message.error{background:#f8d7da;color:#721c24}.payment-modal{max-width:400px}.payment-form{padding:10px 0}.payment-form .form-group{margin-bottom:15px}.payment-form label{display:block;font-size:13px;font-weight:500;color:#333;margin-bottom:6px}.payment-form label .required{color:#dc3545}.payment-form input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px}.payment-form input:focus{border-color:var(--primary-color);outline:none}.payment-notice-box{background:#f8f9fa;padding:15px;border-radius:8px;margin-top:10px}.payment-notice-box p{font-size:13px;color:#666;margin:5px 0;text-align:center}.btn-submit{background:linear-gradient(135deg,#4caf50,#388e3c)!important;font-weight:600}.btn-submit:disabled{background:#ccc!important;cursor:not-allowed}@media(max-width:480px){.payment-option{padding:12px}.payment-option .option-icon{font-size:20px}.payment-option .option-label{font-size:14px}.cash-notice .account-info .account{font-size:18px}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #4A90A4;--primary-dark: #3a7a8a;--primary-light: #e8f4f8;--success-color: #28a745;--warning-color: #ffc107;--danger-color: #dc3545;--text-color: #333;--text-light: #666;--text-muted: #999;--border-color: #ddd;--bg-color: #f5f5f5;--white: #fff;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15);--radius: 12px;--radius-sm: 8px}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans KR,sans-serif;font-size:16px;line-height:1.5;color:var(--text-color);background-color:var(--bg-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh;overflow-x:hidden}#root,.app{min-height:100vh}input,select,textarea{font-family:inherit;font-size:16px}input[type=text],input[type=tel],input[type=number],select{width:100%;padding:14px 16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;background-color:var(--white);transition:border-color .2s,box-shadow .2s}input:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a90a41a}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;font-size:16px;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary{background-color:var(--primary-color);color:var(--white)}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-primary:disabled{background-color:#b0c4cc;cursor:not-allowed}.btn-secondary{background-color:var(--white);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--bg-color)}.btn-full{width:100%}.btn-sm{padding:10px 16px;font-size:14px}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--white);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:var(--danger-color);font-size:14px;margin-top:8px}.success-message{color:var(--success-color);font-size:14px;margin-top:8px}.tabs{display:flex;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.tab{flex:1;padding:12px 8px;text-align:center;background:transparent;border:none;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:var(--primary-light)}.header{background:var(--primary-color);color:var(--white);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header h1{font-size:18px;font-weight:600}@supports (padding: env(safe-area-inset-top)){.header{padding-top:calc(16px + env(safe-area-inset-top))}.footer-nav{padding-bottom:calc(8px + env(safe-area-inset-bottom))}}
