@charset "UTF-8";*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #1a73e8;--primary-hover: #1765cc;--primary-light: #e0e7ff;--secondary-color: #6b7280;--success-color: #34a853;--error-color: #ea4335;--warning-color: #fbbc04;--info-color: #4285f4;--background-color: #f3f4f6;--surface-color: #ffffff;--surface-hover: #e5e7eb;--border-color: #d1d5db;--border-light: #e5e7eb;--text-primary: #111827;--text-secondary: #4b5563;--text-tertiary: #6b7280;--text-on-primary: #ffffff;--shadow-sm: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);--shadow-md: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 2px 6px 2px rgba(60, 64, 67, .15);--shadow-lg: 0 2px 4px 0 rgba(60, 64, 67, .3), 0 4px 8px 3px rgba(60, 64, 67, .15);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-3xl: 24px;--radius-full: 9999px;--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-600: #2563eb;--blue-700: #1d4ed8;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--gray-50: #f9fafb;--gray-100: #f3f4f6;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}body{font-family:Noto Sans JP,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-primary);line-height:1.5;font-size:14px;letter-spacing:.01em;overflow-x:hidden;overflow-y:hidden;-webkit-overflow-scrolling:touch}*:focus-visible{outline:3px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}button,a.btn-primary,a.btn-secondary,a.btn-danger,a.btn-warning,a.btn-success,.nav-list a,.sidebar-logo,.action-btn{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}p,span:not(.status-badge):not(.badge),div:not(.status-badge):not(.badge):not(.card):not(.request-card),h1,h2,h3,h4,h5,h6,label:not(.checkbox-label),input[type=text],input[type=email],input[type=tel],input[type=date],input[type=time],textarea,select{user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.scrollable,.chat-messages,.sidebar,.nav,.main-content,.table-container,.admin-table-scrollable-large,.admin-table-scrollable-medium{user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;scroll-behavior:smooth}button{font-family:inherit;cursor:pointer;border:none;padding:.625rem 1.5rem;font-size:14px;font-weight:500;letter-spacing:.25px;border-radius:var(--radius-md);transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);min-height:36px}button:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-md)}button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}button:disabled{opacity:.38;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--primary-color);color:var(--text-on-primary);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md);color:var(--text-on-primary)}.btn-primary:active:not(:disabled){box-shadow:var(--shadow-sm);transform:translateY(1px);color:var(--text-on-primary)}.btn-secondary{background-color:transparent;color:var(--primary-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--primary-color);border-color:var(--primary-color);color:var(--text-on-primary)}.btn-danger{background-color:var(--error-color);color:var(--text-on-primary);box-shadow:var(--shadow-sm)}.btn-danger:hover:not(:disabled){background-color:#d32f2f;box-shadow:var(--shadow-md);color:var(--text-on-primary)}.btn-danger:active:not(:disabled){box-shadow:var(--shadow-sm);transform:translateY(1px);color:var(--text-on-primary)}.btn-warning{background-color:var(--warning-color);color:#1a1a1a;box-shadow:var(--shadow-sm)}.btn-warning:hover:not(:disabled){background-color:#f9ab00;box-shadow:var(--shadow-md);color:#1a1a1a}.btn-warning:active:not(:disabled){box-shadow:var(--shadow-sm);transform:translateY(1px);color:#1a1a1a}.btn-success{background-color:var(--success-color);color:var(--text-on-primary);box-shadow:var(--shadow-sm)}.btn-success:hover:not(:disabled){background-color:#2d8f47;box-shadow:var(--shadow-md);color:var(--text-on-primary)}.btn-success:active:not(:disabled){box-shadow:var(--shadow-sm);transform:translateY(1px);color:var(--text-on-primary)}a.btn-danger,a.btn-warning,a.btn-success{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}a.btn-danger:hover,a.btn-warning:hover,a.btn-success:hover{text-decoration:none}.btn-with-icon{display:inline-flex;align-items:center;gap:var(--spacing-sm);justify-content:center;transition:all var(--transition-fast)}.btn-with-icon:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-with-icon:active:not(:disabled){transform:translateY(0)}.btn-with-icon svg{flex-shrink:0;stroke:currentColor}.btn-with-icon span{white-space:nowrap}.btn-icon{display:inline-flex;align-items:center;gap:var(--spacing-xs);justify-content:center;padding:5px;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.btn-icon:hover:not(:disabled){background-color:var(--background-color);opacity:.9;transform:translateY(-1px)}.btn-icon:active:not(:disabled){transform:translateY(0)}.btn-icon .icon{flex-shrink:0;width:20px;height:20px;stroke:currentColor}.btn-icon span{white-space:nowrap}.btn-block{width:100%}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover);text-decoration:underline}a:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}a.btn-primary,a.btn-secondary{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}a.btn-primary:hover,a.btn-secondary:hover{text-decoration:none}input,textarea,select{font-family:inherit;font-size:14px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;background-color:var(--surface-color);color:var(--text-primary);transition:all var(--transition-fast)}input:hover,textarea:hover,select:hover{border-color:var(--text-secondary)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-color);border-width:1px;border-radius:var(--radius-md);box-shadow:0 0 0 1px #1a73e81a}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}label{display:block;font-weight:500;font-size:14px;color:var(--text-primary)}small{display:block;margin-top:var(--spacing-xs);color:var(--text-secondary);font-size:12px;line-height:1.4}.error-message{background-color:#fce8e6;color:var(--error-color);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border-left:4px solid var(--error-color);font-size:14px}.flash-message{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);margin:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-size:14px;font-weight:500;box-shadow:var(--shadow-md);animation:slideDown .3s ease-out;position:relative}.flash-message .flash-icon{flex-shrink:0;width:20px;height:20px}.flash-message span{flex:1;line-height:1.5}.flash-message .flash-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:currentColor;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0;width:24px;height:24px;opacity:.7}.flash-message .flash-close:hover{opacity:1;background-color:#0000000d}.flash-message .flash-close svg{width:16px;height:16px}.flash-success{background-color:#e8f5e9;color:#1b5e20;border-left:4px solid var(--success-color)}.flash-success .flash-icon{color:var(--success-color)}.flash-error{background-color:#fce8e6;color:#b71c1c;border-left:4px solid var(--error-color)}.flash-error .flash-icon{color:var(--error-color)}.flash-info{background-color:#e3f2fd;color:#0d47a1;border-left:4px solid var(--info-color)}.flash-info .flash-icon{color:var(--info-color)}.card{background-color:var(--surface-color);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-color)}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;gap:var(--spacing-md);color:var(--text-secondary);font-size:14px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.small{width:24px;height:24px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.pagination-wrapper{display:flex;justify-content:center;margin:var(--spacing-lg) 0;padding:var(--spacing-md) 0}.pagination{display:flex;align-items:center;gap:var(--spacing-md)}.pagination-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background-color:var(--surface-color);border:1px solid var(--border-color);color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast)}.pagination-link:hover:not(.disabled){background-color:var(--primary-color);color:var(--text-on-primary);border-color:var(--primary-color)}.pagination-link:focus-visible{outline:3px solid var(--primary-color);outline-offset:2px}.pagination-link.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.pagination-link svg{flex-shrink:0}.pagination-info{color:var(--text-secondary);font-size:14px;padding:0 var(--spacing-sm)}.modal-checkbox-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:4px;padding:12px;border:1px solid #d1d5db;border-radius:4px;background:#fafafa}.modal-checkbox-grid.modal-checkbox-grid-scroll{max-height:300px;overflow-y:auto}@media (max-width: 768px){.modal-checkbox-grid{grid-template-columns:1fr}}.modal-checkbox-label{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--surface-color);cursor:pointer;transition:all var(--transition-fast);font-size:14px;min-height:44px}.modal-checkbox-label:hover{background-color:var(--surface-hover);border-color:var(--primary-color)}.modal-checkbox-label:has(input:checked){background-color:var(--primary-light);border-color:var(--primary-color);font-weight:500}.modal-checkbox-label:has(input:focus-visible){outline:3px solid var(--primary-color);outline-offset:2px}.modal-checkbox-label input[type=checkbox]{width:20px;height:20px;flex-shrink:0;cursor:pointer;margin:0}.modal-checkbox-label span{flex:1;-webkit-user-select:none;user-select:none}.modal-checkbox-horizontal{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}.modal-checkbox-horizontal .modal-checkbox-label{min-width:100px}.modal-cancel-btn{background-color:#6b7280!important;color:#fff!important;border:2px solid #4b5563!important}.modal-cancel-btn:hover:not(:disabled){background-color:#4b5563!important;border-color:#374151!important}.modal-cancel-btn:focus-visible{outline:3px solid #6b7280;outline-offset:2px}[x-cloak]{display:none!important}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:1100;display:flex;align-items:center;justify-content:center}.modal-content{position:relative;background:#fff;border-radius:8px;max-width:800px;width:90%;max-height:90vh;overflow:auto;padding:24px;box-shadow:0 10px 30px #00000026;margin:auto}.modal-content.modal-content-sm{max-width:800px;max-height:80vh}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h2{font-size:1.1rem;font-weight:600}.modal-header>div{display:flex;gap:8px;align-items:center}.modal-body{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;font-size:.9rem}.report-modal-body{display:block!important;grid-template-columns:1fr 1fr;gap:12px 24px;font-size:.9rem}.modal-section{grid-column:1/-1;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.modal-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.modal-section h3{font-size:1rem;font-weight:600;margin-bottom:12px;padding:8px 12px;background-color:#f3f4f6;border-left:4px solid var(--primary-color);border-radius:4px}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 32px}.modal-grid.modal-grid-full{grid-column:1/-1}@media (max-width: 640px){.modal-grid{grid-template-columns:1fr;gap:12px}}.modal-field{display:block}.modal-field strong{display:block;margin-bottom:4px}.modal-input,.modal-textarea{width:100%;padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:inherit}.modal-input:focus,.modal-textarea:focus{outline:2px solid var(--primary-color);outline-offset:2px;border-color:var(--primary-color)}.modal-textarea{resize:vertical}.modal-display-box{border:1px solid #e5e7eb;border-radius:4px;padding:8px;margin-top:4px;background:#fafafa;min-height:60px;text-align:center}.modal-display-box.modal-display-box-scroll{max-height:200px;overflow:auto}.modal-display-box.modal-display-box-sm{max-height:160px;overflow:auto}.modal-display-box.modal-display-box-xs{min-height:40px}.modal-help-text{display:block;margin-top:4px;color:#6b7280;font-size:.85rem}.modal-help-text.modal-help-text-before{margin-top:0;margin-bottom:4px}.modal-button-group{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.modal-label-optional{font-weight:400;color:#6b7280;font-size:.9em}.modal-field-spaced{margin-top:12px}.modal-field-compact{font-size:.85rem}.modal-field-compact strong{font-size:.9rem}.modal-edit-button{position:relative;background:#fff;padding:16px 0;margin-top:16px;border-top:1px solid #e5e7eb;z-index:10;text-align:center;width:100%}.modal-edit-button button{min-width:120px}.layout{height:100vh;display:flex;background-color:var(--background-color);overflow:hidden}.layout-body{display:flex;flex:1;min-height:0;overflow:hidden}.sidebar{width:300px;background-color:#f9fafb;border-right:1px solid var(--border-color);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;flex-shrink:0;z-index:10;height:100vh;display:flex;flex-direction:column;transition:transform var(--transition-base),width var(--transition-base);transform:translate(0);position:relative}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.sidebar.sidebar-hidden{transform:translate(-100%);width:0;border-right:none;overflow:hidden}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;z-index:1000;box-shadow:2px 0 8px #0000001a;transform:translate(-100%);transition:transform var(--transition-base)}.sidebar:not(.sidebar-hidden){transform:translate(0)}.sidebar.sidebar-hidden{transform:translate(-100%)}}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-md);text-decoration:none;color:var(--text-primary);font-size:17px;font-weight:600;transition:all var(--transition-fast);padding:var(--spacing-xs);border-radius:var(--radius-md);flex-direction:column;text-align:center}.sidebar-logo:hover .logo-icon{filter:drop-shadow(0 4px 8px rgba(59,130,246,.3));animation:none}.sidebar-logo:hover .sidebar-logo-text,.sidebar-logo:hover{text-decoration:none!important}@media (max-width: 768px){.sidebar-logo{font-size:16px}}@media (max-width: 480px){.sidebar-logo{font-size:14px}}.logo-icon-wrapper{display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.logo-icon{width:64px;height:64px;transition:all var(--transition-base);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));animation:logoFloat 3s ease-in-out infinite}@media (max-width: 768px){.logo-icon{width:28px;height:28px}}@media (max-width: 480px){.logo-icon{width:24px;height:24px}}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.sidebar-logo-text{display:inline-block;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:-.5px;text-decoration:none}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}@media (max-width: 768px){.main-wrapper{flex:1;min-height:0;width:100%}}.main-wrapper .footer{background-color:#fff;border-top:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);text-align:center;color:var(--text-secondary);font-size:12px;flex-shrink:0;width:100%;box-sizing:border-box}.main-wrapper .footer p{margin:0;padding:0}.header{background-color:#fff;border-bottom:1px solid var(--border-color);padding:0;flex-shrink:0;z-index:100;box-shadow:0 1px 2px #3c404333,0 1px 3px 1px #3c40431a}.header .menu-toggle-btn{background:none!important;border:none!important;cursor:pointer;padding:var(--spacing-sm)!important;display:inline-flex;align-items:center;justify-content:center;color:var(--text-primary);border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:40px;min-height:40px;font-weight:400;letter-spacing:normal;gap:0}.header .menu-toggle-btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.header .menu-toggle-btn:active{transform:scale(.95)}.header .menu-toggle-btn svg{width:24px;height:24px;stroke:currentColor}.header-content{max-width:100%;margin:0 auto;padding:0 var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;height:64px;gap:var(--spacing-lg)}@media (max-width: 768px){.header-content{padding:0 var(--spacing-md);height:56px}}@media (max-width: 480px){.header-content{padding:0 var(--spacing-sm);height:56px}}.logo{display:flex;align-items:center;margin:0;gap:var(--spacing-md)}.menu-toggle-btn{background:none!important;border:none!important;cursor:pointer;padding:var(--spacing-sm)!important;display:inline-flex;align-items:center;justify-content:center;color:var(--text-primary);border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:40px;min-height:40px;font-weight:400;letter-spacing:normal;gap:0}.menu-toggle-btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.menu-toggle-btn:active{transform:scale(.95)}.menu-toggle-btn svg{width:24px;height:24px;stroke:currentColor}.header-logo-link{display:flex;align-items:center;gap:var(--spacing-md);text-decoration:none;color:var(--text-primary);font-size:20px;font-weight:600;transition:all var(--transition-fast);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);margin-left:var(--spacing-sm)}.header-logo-link:hover{background-color:var(--surface-hover);text-decoration:none;transform:translateY(-1px)}.header-logo-link:hover .header-logo-icon{transform:scale(1.1) rotate(-5deg) translateY(-2px);filter:drop-shadow(0 4px 8px rgba(59,130,246,.3));animation:none}.header-logo-link:hover .header-logo-text,.header-logo-link:hover{text-decoration:none!important}@media (max-width: 768px){.header-logo-link{font-size:16px;padding:var(--spacing-xs);margin-left:0}}@media (max-width: 480px){.header-logo-link{font-size:14px}}.header-logo-icon-wrapper{display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.header-logo-icon{width:32px;height:32px;transition:all var(--transition-base);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));animation:logoFloat 3s ease-in-out infinite}@media (max-width: 768px){.header-logo-icon{width:28px;height:28px}}@media (max-width: 480px){.header-logo-icon{width:24px;height:24px}}.header-logo-text{display:inline-block;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:-.5px;white-space:nowrap;text-decoration:none}@media (max-width: 768px){.header-logo-text{font-size:16px}}@media (max-width: 480px){.header-logo-text{font-size:14px}}.logo-text{display:none}.user-menu{display:flex;align-items:center;gap:var(--spacing-md);margin-left:auto}.header-icon-btn{position:relative;background-color:transparent;border:none;padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--text-secondary);min-width:40px;min-height:40px}.header-icon-btn:hover{background-color:var(--surface-hover);color:var(--text-primary)}.header-icon-btn.has-notifications .notification-badge{display:flex}.header-icon{width:20px;height:20px;stroke:currentColor}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 4px;background-color:var(--error-color);color:#fff;border-radius:var(--radius-full);border:2px solid var(--surface-color);display:none;font-size:11px;font-weight:600;line-height:14px;text-align:center;box-sizing:border-box;white-space:nowrap;align-items:center;justify-content:center}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:inherit;transition:all var(--transition-fast);border-radius:var(--radius-md);padding:var(--spacing-xs);margin:calc(var(--spacing-xs) * -1)}.user-info:hover{background-color:var(--surface-hover);text-decoration:none}.user-name{font-weight:400;font-size:14px;color:var(--text-primary);white-space:nowrap}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--primary-color);color:var(--text-on-primary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;flex-shrink:0;box-shadow:var(--shadow-sm)}@media (max-width: 768px){.user-avatar{width:32px;height:32px;font-size:12px}}.nav{padding:var(--spacing-md) 0;flex:1;overflow-y:auto}@media (max-width: 768px){.nav{padding:var(--spacing-md) 0}}.nav-list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0;gap:var(--spacing-xs)}@media (max-width: 768px){.nav-list{flex-direction:column;overflow-y:auto;padding:0;gap:var(--spacing-xs);-webkit-overflow-scrolling:touch;scrollbar-width:none}.nav-list::-webkit-scrollbar{display:none}}.nav-list li{display:flex;align-items:center;flex-direction:column}@media (max-width: 768px){.nav-list li{flex-shrink:0;width:100%}}.nav-list a{color:var(--text-secondary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:0;font-size:14px;font-weight:500;transition:all var(--transition-fast);position:relative;width:100%;display:flex;align-items:center;gap:var(--spacing-md);min-height:40px}.nav-list a:hover{background-color:var(--surface-hover);color:var(--text-primary);text-decoration:none}.nav-list a[aria-current=page]{color:var(--primary-color);background-color:var(--primary-light);border-left:3px solid var(--primary-color);padding-left:calc(var(--spacing-lg) - 3px)}.nav-list a[aria-current=page]:after{display:none}@media (max-width: 768px){.nav-list a[aria-current=page]{border-left:3px solid var(--primary-color);padding-left:calc(var(--spacing-lg) - 3px)}}@media (max-width: 768px){.nav-list a{padding:var(--spacing-sm) var(--spacing-lg);white-space:nowrap;border-radius:0;min-height:40px;width:100%}}.nav-list li form{width:100%;display:flex;justify-content:flex-start}.nav-list .btn-logout{background-color:transparent;color:var(--text-secondary);padding:var(--spacing-sm) var(--spacing-lg);border:none;font-size:14px;font-weight:500;margin:0;min-height:40px;width:100%;text-align:left;justify-content:flex-start;border-radius:0;display:flex;align-items:center;gap:var(--spacing-md)}.nav-list .btn-logout:hover{background-color:var(--surface-hover);color:var(--text-primary)}.nav-list .btn-logout span{flex:1;text-align:left}@media (max-width: 768px){.nav-list .btn-logout{padding:var(--spacing-sm) var(--spacing-lg);border-radius:0;min-height:40px;width:100%}}.nav-list a span{flex:1}.nav-icon{flex-shrink:0;width:20px;height:20px;stroke:currentColor;transition:all var(--transition-fast)}.nav-item-button{color:var(--text-secondary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:0;font-size:14px;font-weight:500;transition:all var(--transition-fast);position:relative;width:100%;display:flex;align-items:center;gap:var(--spacing-md);background:none;border:none;cursor:pointer;text-align:left}.nav-item-button:hover{background-color:var(--surface-hover);color:var(--text-primary)}.nav-item-button.active{color:var(--primary-color);background-color:var(--primary-light);border-left:3px solid var(--primary-color);padding-left:calc(var(--spacing-lg) - 3px)}.nav-chevron{flex-shrink:0;width:16px;height:16px;margin-left:auto;transition:transform var(--transition-fast)}.nav-chevron.rotate-90{transform:rotate(90deg)}.nav-submenu{list-style:none;margin:0;padding:0;border-left:2px solid var(--border-light);margin-left:var(--spacing-lg);position:relative;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.nav-submenu li{display:flex;align-items:center;width:100%;max-width:100%;box-sizing:border-box}.nav-submenu a{color:var(--text-secondary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:0;font-size:13px;font-weight:500;transition:all var(--transition-fast);position:relative;width:100%;max-width:100%;display:flex;align-items:center;gap:var(--spacing-md);box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-submenu a:hover{background-color:var(--surface-hover);color:var(--text-primary);text-decoration:none}.nav-submenu a.active{color:#2563eb;background-color:#eff6ff;border-left:3px solid #2563eb;padding-left:calc(var(--spacing-lg) - 3px)}.nav-submenu .nav-icon{flex-shrink:0;width:18px;height:18px}.nav-divider{height:1px;background-color:var(--border-color);margin:var(--spacing-sm) var(--spacing-lg);list-style:none}@media (max-width: 768px){.nav-divider{display:none}}.main-content{flex:1;min-width:0;padding:var(--spacing-xl) var(--spacing-lg);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;background-color:var(--background-color)}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.main-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 768px){.main-content{padding:var(--spacing-lg) var(--spacing-md);width:100%}}@media (max-width: 480px){.main-content{padding:var(--spacing-md) var(--spacing-sm)}}.footer{background-color:#fff;border-top:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);text-align:center;color:var(--text-secondary);font-size:12px;flex-shrink:0;width:100%;box-sizing:border-box}.footer p{margin:0;padding:0}.sidebar-overlay{display:none}@media (max-width: 768px){.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}html{scroll-behavior:smooth}.home-container{width:100%;min-height:100vh;background-color:#fff;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hero-section{background:linear-gradient(135deg,#1e40af,#2563eb,#4338ca,#6366f1,#818cf8);color:#0f172a;padding:calc(var(--spacing-2xl) * 1.5) var(--spacing-lg);min-height:100vh;position:relative;overflow:hidden;display:flex;flex-direction:column}@media (min-width: 768px){.hero-section{padding:calc(var(--spacing-2xl) * 1.5) var(--spacing-xl)}}.hero-gradient-bg{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;overflow:hidden}.hero-gradient-layer{position:absolute;width:200%;height:200%;border-radius:50%;filter:blur(80px);opacity:.6;animation:gradient-float 20s ease-in-out infinite}.hero-gradient-1{background:radial-gradient(circle,rgba(99,102,241,.8) 0%,transparent 70%);top:-50%;left:-50%;animation-delay:0s}.hero-gradient-2{background:radial-gradient(circle,rgba(139,92,246,.6) 0%,transparent 70%);top:30%;right:-50%;animation-delay:7s;animation-duration:25s}.hero-gradient-3{background:radial-gradient(circle,rgba(59,130,246,.7) 0%,transparent 70%);bottom:-30%;left:20%;animation-delay:14s;animation-duration:30s}@keyframes gradient-float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(10%,-10%) scale(1.1)}66%{transform:translate(-10%,10%) scale(.9)}}.hero-dot-pattern{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;background-image:radial-gradient(circle,rgba(255,255,255,.15) 1px,transparent 1px);background-size:40px 40px;background-position:0 0;animation:dot-move 20s linear infinite;opacity:.4}@keyframes dot-move{0%{background-position:0 0}to{background-position:40px 40px}}.hero-glow-effect{position:absolute;border-radius:50%;filter:blur(60px);z-index:1;pointer-events:none;animation:glow-pulse 4s ease-in-out infinite}.hero-glow-1{width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);top:10%;right:10%;animation-delay:0s}.hero-glow-2{width:300px;height:300px;background:radial-gradient(circle,rgba(250,204,21,.2) 0%,transparent 70%);bottom:20%;left:15%;animation-delay:2s}@keyframes glow-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.2)}}.hero-logo{position:absolute;top:var(--spacing-xl);left:var(--spacing-xl);height:100px;width:auto;z-index:10;opacity:0;animation:fadeIn .6s ease-out .1s forwards}@media (max-width: 768px){.hero-logo{top:var(--spacing-lg);left:var(--spacing-lg);height:60px;max-width:calc(50% - var(--spacing-lg) - .5rem)}}@media (max-width: 480px){.hero-logo{top:var(--spacing-md);left:var(--spacing-md);height:50px;max-width:calc(50% - var(--spacing-md) - .5rem)}}.hero-login-btn{position:absolute;top:var(--spacing-xl);right:var(--spacing-xl);padding:.75rem 1.5rem;font-size:16px;font-weight:500;background-color:#fff;color:#2563eb;border:1px solid #2563eb;border-radius:9999px;text-decoration:none;transition:all var(--transition-base);z-index:10;display:inline-flex;align-items:center;justify-content:center;min-height:44px;opacity:0;animation:fadeIn .6s ease-out .1s forwards}.hero-login-btn:hover{background-color:#f9fafb;border-color:#1d4ed8;color:#1d4ed8;text-decoration:none;box-shadow:var(--shadow-md)}@media (max-width: 768px){.hero-login-btn{top:var(--spacing-lg);right:var(--spacing-lg);padding:.625rem 1.25rem;font-size:14px}}@media (max-width: 480px){.hero-login-btn{top:var(--spacing-md);right:var(--spacing-md);padding:.5rem 1rem;font-size:13px;min-height:36px}}.hero-wave-bg{position:absolute;bottom:0;left:0;width:100%;height:120px;z-index:2;overflow:hidden}.hero-wave-bg .wave-svg{position:absolute;bottom:0;left:-5%;width:110%;height:100%;display:block}.hero-wave-bg .wave-layer-1{z-index:2}.hero-wave-bg .wave-layer-1 .wave-path{animation:wave-animation-1 8s ease-in-out infinite}.hero-wave-bg .wave-layer-2{z-index:1;opacity:.7}.hero-wave-bg .wave-layer-2 .wave-path{animation:wave-animation-2 12s ease-in-out infinite}@keyframes wave-animation-1{0%,to{transform:translate(0)}50%{transform:translate(-20px)}}@keyframes wave-animation-2{0%,to{transform:translate(0)}50%{transform:translate(30px)}}.hero-content{max-width:80rem;margin:0 auto;padding:210px 2rem calc(var(--spacing-2xl) * 1.5);box-sizing:border-box;position:relative;z-index:3;display:flex;flex-direction:column;gap:var(--spacing-2xl)}@media (min-width: 1025px){.hero-content{flex-direction:row;align-items:center;gap:3rem;padding-top:100px}}@media (max-width: 768px){.hero-content{padding-top:150px;padding-left:1.5rem;padding-right:1.5rem}}@media (max-width: 480px){.hero-content{padding-top:135px;padding-left:1rem;padding-right:1rem}}.hero-text-area{flex:1;text-align:center;position:relative;animation:fadeInUp .8s ease-out}@media (min-width: 1024px){.hero-text-area{text-align:left}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-catchphrase{font-size:1.25rem;font-weight:500;letter-spacing:.05em;margin-bottom:.5rem;color:#dbeafe;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}@media (max-width: 480px){.hero-catchphrase{font-size:1.125rem}}.hero-main-title{font-size:3rem;font-weight:900;line-height:1.1;margin-top:0;margin-bottom:var(--spacing-2xl);color:#fff;letter-spacing:-.02em;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}@media (min-width: 768px){.hero-main-title{font-size:3.75rem}}@media (max-width: 480px){.hero-main-title{font-size:2.5rem}}.hero-keyword{color:#fff;position:relative;display:inline-block;white-space:nowrap;text-shadow:0 2px 20px rgba(0,0,0,.3)}.hero-keyword:before{content:"";position:absolute;bottom:.2em;left:0;right:0;height:.4em;background:linear-gradient(90deg,#facc154d,#facc1533,#facc154d);z-index:-1;border-radius:2px;animation:marker-shine 3s ease-in-out infinite}.hero-keyword:first-letter{font-size:1.1em;letter-spacing:-.05em;background:linear-gradient(135deg,#ffffff4d,#ffffff1a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes marker-shine{0%,to{opacity:.3;transform:scaleX(1)}50%{opacity:.5;transform:scaleX(1.05)}}.hero-subtitle{font-size:18px;font-weight:400;line-height:1.7;margin-bottom:var(--spacing-xl);color:#fffffff2;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}@media (max-width: 480px){.hero-subtitle{font-size:16px}}.hero-actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-xl)}@media (min-width: 1024px){.hero-actions{flex-direction:row}}.hero-actions .btn-hero-primary,.hero-actions .btn-hero-secondary{height:48px!important;padding:0 24px!important;font-size:16px!important;font-weight:700!important;border-radius:6px!important;min-height:48px!important}.btn-hero-primary{background-color:#fff;color:#2563eb;font-weight:700;padding:1rem 2rem;border-radius:9999px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a,0 0 #2563eb66;transition:all var(--transition-base);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:48px;font-size:16px;border:none;position:relative;overflow:hidden}.btn-hero-primary:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#2563eb1a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-hero-primary:hover{transform:scale(1.05);text-decoration:none;color:#2563eb;box-shadow:0 25px 30px -5px #00000026,0 15px 15px -5px #0000000f,0 0 20px #2563eb4d}.btn-hero-primary:hover:before{width:300px;height:300px}.btn-hero-primary:active{transform:scale(1.02)}@media (max-width: 767px){.btn-hero-primary{width:100%;padding:1rem 1.5rem}}.btn-hero-secondary{background-color:transparent;color:#fff;font-weight:700;padding:1rem 2rem;border-radius:9999px;border:2px solid rgba(255,255,255,.5);transition:all var(--transition-base);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:48px;font-size:16px;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-hero-secondary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.btn-hero-secondary:hover{background-color:#ffffff1a;border-color:#fffc;text-decoration:none;color:#fff;box-shadow:0 0 20px #fff3}.btn-hero-secondary:hover:before{left:100%}@media (max-width: 767px){.btn-hero-secondary{width:100%;padding:1rem 1.5rem}}.hero-visual-area{flex:1;position:relative;min-height:300px;display:flex;align-items:center;justify-content:center;animation:fadeInRight .8s ease-out .2s both}@media (min-width: 768px){.hero-visual-area{min-height:400px}}@keyframes fadeInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.hero-visual-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.8;width:80%;max-width:400px;height:80%;max-height:400px;z-index:1;overflow:visible}.hero-decorative-svg{width:100%;height:100%;opacity:.5}.hero-main-visual{position:relative;z-index:2;width:100%;max-width:400px;height:100%;max-height:400px;display:flex;align-items:center;justify-content:center;opacity:.8}.hero-floating{animation:floating-subtle 4s ease-in-out infinite}@keyframes floating-subtle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero-illustration{width:100%;max-width:400px;height:auto}.features-section{padding:var(--spacing-2xl) var(--spacing-lg) 0;background-color:#fff;position:relative}@media (min-width: 768px){.features-section{padding:var(--spacing-2xl) var(--spacing-xl) 0}}.features-wave-bg{position:absolute;bottom:-1px;left:0;width:100%;height:120px;z-index:1;overflow:hidden}.features-wave-bg .wave-svg{width:100%;height:100%;display:block}.features-wave-bg .wave-path{animation:wave-animation 10s ease-in-out infinite reverse}.container{max-width:1200px;margin:0 auto;position:relative;z-index:2}.section-title{font-size:32px;font-weight:700;text-align:center;margin-bottom:var(--spacing-2xl);color:#0f172a;letter-spacing:-.01em}@media (max-width: 768px){.section-title{font-size:28px}}@media (max-width: 480px){.section-title{font-size:24px}}.features-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl);margin-top:var(--spacing-xl);padding-bottom:var(--spacing-2xl)}@media (min-width: 768px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.features-grid{grid-template-columns:repeat(4,1fr)}}.feature-card{background-color:#fff;padding:var(--spacing-xl);border-radius:24px;box-shadow:var(--shadow-md);text-align:center;transition:all var(--transition-base);border:1px solid transparent}.feature-card:hover{transform:scale(1.05);box-shadow:var(--shadow-lg);border-color:#eff6ff}@media (max-width: 480px){.feature-card{padding:var(--spacing-lg)}}.feature-icon-wrapper{width:64px;height:64px;margin-bottom:var(--spacing-md);margin-left:auto;margin-right:auto;display:flex;align-items:center;justify-content:center}.feature-icon-svg{width:64px;height:64px;color:#2563eb;fill:none;stroke:currentColor;stroke-width:3}.feature-title{font-size:20px;font-weight:600;margin-bottom:var(--spacing-sm);color:#1e293b;text-align:center}.feature-description{font-size:16px;color:#334155;line-height:1.6;text-align:left}.how-it-works-section{padding:var(--spacing-2xl) var(--spacing-lg) 0;background-color:#f9fafb;position:relative}@media (min-width: 768px){.how-it-works-section{padding:var(--spacing-2xl) var(--spacing-xl) 0}}.how-it-works-intro{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-2xl);font-size:16px;line-height:1.75;color:#334155}.flow-subsection-title{font-size:18px;font-weight:600;color:#1e293b;margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-md)}.flow-subsection-title:first-of-type{margin-top:0}.flow-subsection-note{font-size:15px;line-height:1.7;color:#334155;margin-bottom:var(--spacing-lg)}.steps-wave-bg{position:absolute;bottom:-1px;left:0;width:100%;height:120px;z-index:1;overflow:hidden}.steps-wave-bg .wave-svg{width:100%;height:100%;display:block}.steps-wave-bg .wave-path{animation:wave-animation 12s ease-in-out infinite}.steps-container{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl);margin-top:var(--spacing-xl);padding-bottom:var(--spacing-2xl)}@media (min-width: 768px){.steps-container{grid-template-columns:repeat(3,1fr)}}.step-item{text-align:left;position:relative;background-color:#fff;padding:var(--spacing-xl);border-radius:24px;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.step-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}@media (max-width: 480px){.step-item{padding:var(--spacing-lg)}}.step-number-wrapper{position:relative;width:100px;height:100px;margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center}.step-number-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.step-number{position:relative;z-index:2;font-size:48px;font-weight:800;color:#2563eb;display:flex;align-items:center;justify-content:center}.step-illustration{width:120px;height:120px;margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center}.step-illustration-svg{width:100%;height:100%;color:#2563eb;fill:none;stroke:currentColor;stroke-width:2}.step-title{font-size:20px;font-weight:600;margin-bottom:var(--spacing-sm);color:#1e293b;text-align:center}.step-description{font-size:16px;color:#334155;line-height:1.6}.step-connector{display:none}@media (min-width: 768px){.step-connector{display:block;position:absolute;top:50%;right:-2rem;transform:translateY(-50%);width:4rem;height:20px;z-index:10}}@media (min-width: 1024px){.step-connector{right:-3rem;width:6rem}}.step-arrow{width:100%;height:100%}.step-item:last-child .step-connector{display:none}.cta-section{padding:8rem var(--spacing-lg);background-color:#eff6ff;text-align:center;position:relative;overflow:hidden}@media (min-width: 768px){.cta-section{padding:8rem var(--spacing-xl)}}@media (max-width: 480px){.cta-section{padding:4rem var(--spacing-md)}}.cta-title{font-size:32px;font-weight:400;margin-bottom:var(--spacing-md);color:var(--text-primary);position:relative;z-index:1}@media (max-width: 768px){.cta-title{font-size:28px}}@media (max-width: 480px){.cta-title{font-size:24px}}.cta-description{font-size:16px;color:var(--text-secondary);margin-bottom:var(--spacing-xl);position:relative;z-index:1}.cta-microcopy{display:flex;justify-content:center;align-items:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl);flex-wrap:wrap;position:relative;z-index:1}@media (max-width: 768px){.cta-microcopy{gap:var(--spacing-md);flex-direction:column}}.cta-point{display:flex;align-items:center;gap:var(--spacing-sm);font-size:14px;color:#1d4ed8;font-weight:500}.cta-check-icon{flex-shrink:0;color:#1d4ed8;stroke:currentColor}.cta-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap;position:relative;z-index:1}@media (max-width: 767px){.cta-actions{flex-direction:column}}.btn-cta-primary{background-color:#2563eb;color:#fff;font-weight:700;padding:.875rem 2rem;border-radius:8px;box-shadow:0 20px 25px -5px #3b82f680,0 10px 10px -5px #3b82f633;transition:all var(--transition-base);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:48px;font-size:16px}.btn-cta-primary:hover{background-color:#1d4ed8;box-shadow:0 25px 30px -5px #3b82f699,0 15px 15px -5px #3b82f64d;transform:translateY(-2px);text-decoration:none;color:#fff}@media (max-width: 767px){.btn-cta-primary{width:100%}}.cta-note{margin-top:var(--spacing-lg);color:#6b7280;font-size:12px;line-height:1.5;position:relative;z-index:1}.btn-large{padding:.875rem 2rem;font-size:16px;min-height:44px}@media (max-width: 767px){.btn-large{width:100%}}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background-color:var(--background-color);padding:var(--spacing-lg)}.login-card{background-color:var(--surface-color);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000001a;width:100%;max-width:420px;border:1px solid var(--border-color);position:relative;z-index:1;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-header h1{font-size:28px;font-weight:500;margin-bottom:var(--spacing-sm);color:var(--text-primary);letter-spacing:-.5px}.login-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.form-group label{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs);font-size:14px;font-weight:500;color:var(--text-primary)}.password-voice-hint{font-size:13px;color:var(--text-secondary);margin:0 0 var(--spacing-xs);line-height:1.4}.input-icon{width:18px;height:18px;color:var(--text-secondary);flex-shrink:0}.input-wrapper{position:relative}.input-wrapper .input-with-icon{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 44px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;transition:all var(--transition-base);background-color:var(--background-color);color:var(--text-primary)}.input-wrapper .input-with-icon:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-color-rgb),.1)}.input-wrapper .input-with-icon::placeholder{color:var(--text-secondary);opacity:.6}.input-wrapper .input-with-icon:hover:not(:focus){border-color:var(--border-hover)}.input-wrapper:before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;pointer-events:none}.password-wrapper .input-with-icon{padding-right:44px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-base);border-radius:var(--radius-sm)}.password-toggle svg{width:20px;height:20px}.password-toggle:hover:not(:disabled){color:var(--text-primary);background-color:var(--background-color);transform:translateY(-50%) scale(1.1)}.password-toggle:active:not(:disabled){transform:translateY(-50%) scale(1)}.password-toggle:focus{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}.btn-block{width:100%;margin-top:var(--spacing-lg)}.btn-login{position:relative;overflow:hidden;transition:all var(--transition-base);background-color:var(--primary-color)!important;color:var(--text-on-primary);border-color:var(--primary-color);font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px;display:flex;align-items:center;justify-content:center}.btn-login:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.3)}.btn-login:active:not(:disabled){transform:translateY(0);background-color:var(--primary-hover)}.btn-login:disabled{opacity:.7;cursor:not-allowed;background-color:var(--primary-color)}.btn-content{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.btn-icon{width:18px;height:18px;flex-shrink:0}.btn-icon.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background-color:#fef2f2;color:#dc2626;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border:1px solid #fecaca;font-size:14px;display:flex;align-items:flex-start;gap:var(--spacing-xs);line-height:1.5}.error-message .error-icon{width:20px;height:20px;flex-shrink:0;margin-top:2px}.login-footer{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-light)}.register-link{text-align:center;color:var(--text-secondary);font-size:14px;line-height:1.6}.register-link a{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color var(--transition-base)}.register-link a:hover{color:var(--primary-hover);text-decoration:underline}@media (max-width: 768px){.login-container{padding:var(--spacing-lg)}.login-card{padding:var(--spacing-xl);max-width:100%}.login-header h1{font-size:24px}.login-subtitle{font-size:13px}}@media (max-width: 480px){.login-container{padding:var(--spacing-md)}.login-card{padding:var(--spacing-lg);box-shadow:var(--shadow-md);border-radius:var(--radius-md)}.login-header h1{font-size:22px}.login-subtitle{font-size:12px}}.register-container{min-height:100vh;max-height:100vh;display:flex;justify-content:center;align-items:flex-start;background-color:var(--background-color);padding:var(--spacing-md);overflow:hidden}.register-card{background-color:var(--surface-color);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:1000px;max-height:calc(100vh - var(--spacing-md) * 2);border:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.register-card h1{font-size:24px;font-weight:500;margin-bottom:var(--spacing-xl);text-align:center;color:var(--text-primary);letter-spacing:-.5px;flex-shrink:0;padding:0}.register-card form{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:var(--spacing-xs);padding-bottom:var(--spacing-md)}.register-card form::-webkit-scrollbar{width:6px}.register-card form::-webkit-scrollbar-track{background:transparent}.register-card form::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.register-card form::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.form-sections-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);align-items:flex-start}.form-section{margin-bottom:0;padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-light);position:relative}.form-section-half{border-right:1px solid var(--border-light);padding-right:var(--spacing-lg);display:flex;flex-direction:column}.form-section-half:last-child{border-right:none;padding-right:0;padding-left:var(--spacing-lg)}.form-section-full{width:100%;grid-column:1/-1;margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--border-color)}.form-group-third{margin-bottom:var(--spacing-md)}.form-row .form-group-third{grid-template-columns:1fr 1fr 1fr}.sub-label{font-size:12px;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.qualifications-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.qualification-item{padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--surface-hover);position:relative}.btn-remove{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background-color:var(--error-color);color:#fff;border:none;border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.btn-remove:hover{background-color:#d33b2c}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:14px;transition:all var(--transition-fast)}.info-box{background-color:var(--primary-light);border:1px solid var(--primary-color);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm)}.info-text{font-size:13px;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.info-list{margin:var(--spacing-xs) 0 0 var(--spacing-lg);padding:0;font-size:13px;color:var(--text-primary)}.info-list li{margin-bottom:var(--spacing-xs)}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-subsection{margin-bottom:var(--spacing-xl)}.form-subsection:last-child{margin-bottom:0}.section-title{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-xs);border-bottom:2px solid var(--primary-color);display:block;width:100%;letter-spacing:.3px}.form-group,.name-group{margin-bottom:var(--spacing-md)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-group-half{margin-bottom:var(--spacing-md)}.name-inputs{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.name-input-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.name-input-item input{margin-top:0}.input-label{font-size:11px;color:var(--text-secondary);margin-top:2px}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:14px;font-weight:500;color:var(--text-primary)}.label-hint{font-size:12px;font-weight:400;color:var(--text-secondary)}.form-group input,.form-group textarea,.form-group select{margin-top:var(--spacing-xs)}small{display:block;margin-top:2px;color:var(--text-secondary);font-size:11px;line-height:1.4}.btn-block{width:100%;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xs);flex-shrink:0;position:sticky;bottom:0;padding-top:var(--spacing-sm);padding-bottom:var(--spacing-xs);z-index:10}.btn-primary{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px;display:flex;align-items:center;justify-content:center;background-color:var(--primary-color)!important;color:var(--text-on-primary)!important;border-color:var(--primary-color)!important}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)!important;color:var(--text-on-primary)!important}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fce8e6;color:var(--error-color);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border-left:4px solid var(--error-color);font-size:14px;flex-shrink:0;line-height:1.5}.error-message-field{display:block;color:var(--error-color);font-size:12px;margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:#fce8e6;border-left:3px solid var(--error-color);border-radius:var(--radius-sm);line-height:1.4}.error-summary-list{margin:var(--spacing-sm) 0 0;padding-left:1.25rem;list-style:disc}.error-summary-list li{margin-bottom:var(--spacing-xs);line-height:1.5}.error-summary-field{font-weight:600}.login-link{text-align:center;margin-top:var(--spacing-md);padding-top:var(--spacing-md);color:var(--text-secondary);font-size:14px;flex-shrink:0;border-top:1px solid var(--border-color);background-color:var(--surface-color)}.login-link a{color:var(--primary-color);font-weight:500}.registration-notice{background-color:var(--primary-light);border:1px solid var(--primary-color);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-md);display:flex;gap:var(--spacing-sm);align-items:flex-start}.notice-icon{font-size:30px;color:var(--error-color);flex-shrink:0;margin-top:2px}.notice-content{flex:1}.notice-text{font-size:13px;color:var(--text-primary);line-height:1.6;margin:0;margin-bottom:var(--spacing-xs)}.notice-text:last-child{margin-bottom:0}@media (max-width: 968px){.form-sections-row{grid-template-columns:1fr;gap:var(--spacing-lg)}.form-section-half{border-right:none;border-bottom:1px solid var(--border-light);padding-right:0;padding-bottom:var(--spacing-lg);padding-left:0}.form-section-half:last-child{border-bottom:none;padding-left:0;padding-top:var(--spacing-lg)}.form-subsection{margin-bottom:var(--spacing-lg)}}@media (max-width: 768px){.register-container{padding:var(--spacing-sm);align-items:flex-start;padding-top:var(--spacing-sm)}.register-card{max-height:calc(100vh - var(--spacing-sm) * 2);padding:var(--spacing-lg);margin-top:var(--spacing-sm);max-width:100%}.register-card h1{font-size:22px;margin-bottom:var(--spacing-lg)}.form-sections-row{gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.form-section{margin-bottom:0;padding-bottom:var(--spacing-md)}.form-subsection{margin-bottom:var(--spacing-md)}.section-title{font-size:15px;margin-bottom:var(--spacing-sm)}.form-group,.name-group{margin-bottom:var(--spacing-sm)}.form-row{grid-template-columns:1fr;gap:var(--spacing-sm)}.registration-notice{padding:var(--spacing-sm);margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm)}.notice-text{font-size:12px}}@media (max-width: 480px){.register-container{padding:var(--spacing-xs);padding-top:var(--spacing-xs)}.register-card{padding:var(--spacing-md);max-height:calc(100vh - var(--spacing-xs) * 2);margin-top:var(--spacing-xs)}.register-card h1{font-size:20px;margin-bottom:var(--spacing-md)}.form-sections-row{gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-section{margin-bottom:0;padding-bottom:var(--spacing-sm)}.form-section-half{padding-bottom:var(--spacing-md)}.form-subsection{margin-bottom:var(--spacing-md)}.section-title{font-size:14px;margin-bottom:var(--spacing-sm)}.name-inputs{grid-template-columns:1fr}.form-group,.name-group{margin-bottom:var(--spacing-sm)}.form-row{grid-template-columns:1fr}.registration-notice{padding:var(--spacing-xs);margin-top:var(--spacing-sm);margin-bottom:var(--spacing-xs);flex-direction:column;gap:var(--spacing-xs)}.notice-icon{font-size:18px}.notice-text{font-size:11px}}.confirm-section{padding:var(--spacing-lg) 0;max-width:720px;margin:0 auto}.confirm-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-color)}.confirm-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0;letter-spacing:-.02em}.confirm-description{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.confirm-block{margin-bottom:var(--spacing-xl)}.confirm-block:last-of-type{margin-bottom:var(--spacing-lg)}.confirm-block-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-sm) 0;padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-light)}.confirm-list{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--surface-color);box-shadow:0 1px 2px #0000000a}.confirm-row{display:flex;flex-wrap:wrap;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);align-items:flex-start;border-bottom:1px solid var(--border-light);min-height:2.75rem;box-sizing:border-box}.confirm-row:nth-child(2n){background:#00000005}.confirm-row:last-child{border-bottom:none}.confirm-label{flex:0 0 200px;font-weight:500;color:var(--text-secondary);font-size:.875rem;line-height:1.5;padding-top:.125rem}.confirm-value{flex:1;min-width:0;word-break:break-word;white-space:pre-wrap;font-size:.9375rem;line-height:1.5;color:var(--text-primary)}.confirm-value.confirm-text-block{white-space:pre-wrap;max-height:8em;overflow-y:auto;padding-right:var(--spacing-xs)}.confirm-qual-item{padding:var(--spacing-xs) 0;border-bottom:1px dashed var(--border-light)}.confirm-qual-item:last-child{border-bottom:none}.confirm-actions{display:flex;gap:var(--spacing-lg);flex-wrap:wrap;justify-content:center;align-items:center;padding:var(--spacing-xl) 0 var(--spacing-md);margin-top:var(--spacing-lg);border-top:2px solid var(--border-color);background:var(--surface-color);border-radius:var(--radius-md)}.btn-confirm-back{min-width:140px}.btn-confirm-submit{min-width:160px;font-weight:600}@media (max-width: 600px){.confirm-section{padding:var(--spacing-md) 0}.confirm-row{flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);min-height:auto}.confirm-label{flex:none;width:100%;font-size:.8rem;color:var(--text-secondary);padding-top:0}.confirm-value{width:100%;padding-left:0}.confirm-actions{flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg) 0}.btn-confirm-back,.btn-confirm-submit{width:100%;max-width:280px}}.main-content.admin-main-content{padding:0;background-color:#f8faff}.admin-dashboard-wrapper{min-height:100vh;background-color:#f8faff;width:100%;position:relative;display:flex;flex-direction:column;margin:0;padding:0}.admin-dashboard-main{flex:1;padding:var(--spacing-xl);overflow-x:hidden;overflow-y:auto;min-height:0;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.admin-breadcrumb{margin-bottom:var(--spacing-lg)}.admin-breadcrumb-list{display:flex;align-items:center;gap:var(--spacing-sm);list-style:none;padding:0;margin:0;font-size:14px}.admin-breadcrumb-item{color:#64748b}.admin-breadcrumb-link{color:#2563eb;text-decoration:none;transition:color var(--transition-fast)}.admin-breadcrumb-link:hover{color:#1d4ed8;text-decoration:underline}.admin-breadcrumb-separator{color:#cbd5e1}.admin-dashboard{max-width:1400px;margin:0 auto;width:100%;position:relative}.admin-dashboard-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-light)}.admin-dashboard-header h1{margin:0 0 var(--spacing-xs) 0;font-size:32px;font-weight:600;color:var(--text-primary);letter-spacing:-.5px;line-height:1.2}.admin-welcome-message{font-size:16px;color:var(--text-secondary);font-weight:400;margin:0;line-height:1.5}.admin-section{background-color:#fff;padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:0 2px 8px #00000014;margin-bottom:var(--spacing-xl);border:1px solid var(--border-color);transition:all var(--transition-base);position:relative;overflow:hidden}.admin-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#9333ea,#a855f7);opacity:0;transition:opacity var(--transition-base)}.admin-section:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px);border-color:#9333ea}.admin-section:hover:before{opacity:1}.admin-section .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.admin-section .section-header h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:20px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.users-toolbar{margin-bottom:var(--spacing-lg);display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md)}.users-search-sort{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm)}.users-search-input{min-width:200px;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;transition:border-color var(--transition-base)}.users-search-input:focus{outline:none;border-color:var(--primary-color)}.users-sort-select{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;background-color:var(--surface-color);cursor:pointer}.users-sort-select:focus{outline:none;border-color:var(--primary-color)}.users-result-count{margin:0;font-size:14px;color:var(--text-secondary)}.setting-section-note{margin:0 0 var(--spacing-md);font-size:13px;color:var(--text-secondary);line-height:1.4}.section-title-hint{font-size:14px;color:#6366f1;cursor:help;margin-left:4px;font-weight:400;opacity:.7;transition:opacity .2s ease;position:relative;display:inline-block;vertical-align:middle}.section-title-hint:hover{opacity:1}.section-title-hint[title]:hover:after{content:attr(title);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);padding:6px 10px;background-color:#1e293b;color:#f1f5f9;font-size:12px;white-space:nowrap;border-radius:4px;z-index:10000;pointer-events:none;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;opacity:1;visibility:visible}.section-title-hint[title]:hover:before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#1e293b;z-index:10001;pointer-events:none;opacity:1;visibility:visible}.section-title-hint[title]:after,.section-title-hint[title]:before{opacity:0;visibility:hidden;transition:opacity .05s ease,visibility 0s linear .05s}.section-title-hint[title]:hover:after,.section-title-hint[title]:hover:before{transition:opacity .1s ease,visibility 0s linear 0s}.admin-section .section-icon{color:#9333ea;flex-shrink:0}.admin-section h2{margin-bottom:1.5rem;color:var(--text-primary);font-size:20px;font-weight:600}.section-description{font-size:14px;color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:1.6}.empty-state-small{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary);font-size:14px}.setting-item{margin-bottom:1rem}.setting-item label{display:flex;align-items:center;gap:.5rem;font-weight:500;cursor:pointer}.setting-item input[type=checkbox]{width:auto;margin:0}.setting-description{margin-top:.5rem;margin-left:1.75rem;color:var(--text-secondary);font-size:.875rem}.section-actions{display:flex;gap:1rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.section-actions button{border-radius:8px}.filter-controls{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background-color:#f8fafc;border-radius:6px;border:1px solid var(--border-light)}.filter-toggle{display:flex;align-items:center;gap:var(--spacing-xs);font-size:13px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.filter-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary-color, #6366f1)}.filter-toggle span{white-space:nowrap}.filter-days-select{padding:4px 8px;font-size:13px;border:1px solid var(--border-color);border-radius:4px;background-color:#fff;color:var(--text-primary);cursor:pointer}.filter-days-select:focus{outline:2px solid var(--primary-color, #6366f1);outline-offset:2px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;position:relative}.table-container::-webkit-scrollbar{height:8px}.table-container::-webkit-scrollbar-track{background:var(--background-color);border-radius:4px}.table-container::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:4px}.table-container::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary)}.admin-table{width:100%;min-width:1000px;border-collapse:collapse;table-layout:fixed}.admin-table-scrollable-large{min-width:1800px;width:auto;table-layout:auto}.admin-table-scrollable-medium{min-width:1000px;width:auto;table-layout:auto}.admin-table th,.admin-table td{padding:.75rem;text-align:center;border-bottom:1px solid var(--border-color);white-space:nowrap;vertical-align:middle}.admin-table th:first-child,.admin-table td:first-child{min-width:60px}.admin-table th:nth-child(2),.admin-table td:nth-child(2){min-width:100px}.admin-table th:nth-child(3),.admin-table td:nth-child(3){min-width:100px}.admin-table th:nth-child(4),.admin-table td:nth-child(4){min-width:120px}.admin-table th:nth-child(5),.admin-table td:nth-child(5){width:215px;white-space:normal;text-align:center!important}.admin-table th:nth-child(5) .status-badge,.admin-table td:nth-child(5) .status-badge{white-space:normal;word-break:keep-all;line-height:1.4;display:inline-block!important;text-align:center;width:auto;max-width:300px;box-sizing:border-box;margin:0 auto}.admin-table th:nth-child(6),.admin-table td:nth-child(6){width:150px;white-space:normal}.admin-table td:nth-child(4){white-space:normal}.table-inline-field{display:flex;gap:.5rem;align-items:center;justify-content:center}.table-inline-field input{min-width:90px;max-width:120px;text-align:center}.users-table thead{background-color:#f8fafc}.users-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color)}.users-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.users-table tbody tr:hover{background-color:#3b82f608}.users-table tbody tr td{padding:16px var(--spacing-lg);vertical-align:middle}.guides-table thead{background-color:#f8fafc}.guides-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color)}.guides-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.guides-table tbody tr:hover{background-color:#3b82f608}.guides-table tbody tr td{padding:16px var(--spacing-lg);vertical-align:middle}.monthly-limits-table{min-width:1200px}.monthly-limits-table .limit-type-th{text-align:center;width:215px}.monthly-limits-table .sub-header th{font-size:11px;padding-top:4px;border-bottom:1px solid var(--border-color)}.monthly-limits-table .sub-header th:nth-child(4),.monthly-limits-table tbody td:nth-child(4){width:100px;min-width:100px}.monthly-limits-table .sub-header th:nth-child(5),.monthly-limits-table tbody td:nth-child(5){width:57px;min-width:57px;text-align:right;white-space:nowrap}.monthly-limits-table .sub-header th:nth-child(6),.monthly-limits-table tbody td:nth-child(6){width:58px;min-width:58px;text-align:right;white-space:nowrap}.monthly-limits-table .monthly-limits-th-limit:not(.monthly-limits-th-outing),.monthly-limits-table .monthly-limits-cell-limit:not(.monthly-limits-cell-outing){min-width:100px;width:100px}.monthly-limits-table .monthly-limits-th-used:not(.monthly-limits-th-outing),.monthly-limits-table .monthly-limits-cell-used:not(.monthly-limits-cell-outing){min-width:72px;width:72px;text-align:right}.monthly-limits-table .monthly-limits-th-remaining:not(.monthly-limits-th-outing),.monthly-limits-table .monthly-limits-cell-remaining:not(.monthly-limits-cell-outing){min-width:72px;width:72px;text-align:right}.monthly-limits-table .monthly-limits-cell-year-month,.monthly-limits-table .monthly-limits-th-year-month{min-width:160px}.monthly-limits-table .monthly-limits-cell-limit .limit-hours-input{width:72px;min-width:72px;box-sizing:border-box}.monthly-limits-table th:last-child,.monthly-limits-table td:last-child{min-width:240px;width:240px;white-space:nowrap;box-sizing:border-box}.monthly-limits-table .user-action-buttons{flex-wrap:nowrap;justify-content:center}.monthly-limits-table thead{background-color:#f8fafc}.monthly-limits-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color)}.monthly-limits-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.monthly-limits-table tbody tr:hover{background-color:#3b82f608}.monthly-limits-table tbody tr td{padding:12px var(--spacing-md);vertical-align:middle}.monthly-limits-year-month{display:flex;align-items:center;flex-wrap:nowrap;gap:4px}.monthly-limits-year-month .year-month-input{flex-shrink:0}.monthly-limits-year-month .year-month-sep{flex-shrink:0;color:#64748b;font-size:14px;margin:0 2px}.year-month-input{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:6px 8px;font-size:14px;width:80px;transition:all var(--transition-base)}.year-month-input:focus{background-color:#fff;outline:none;box-shadow:0 0 0 2px #3b82f680;border-color:#3b82f6}.year-month-input[id*=month]{width:60px}.year-month-label{color:#64748b;font-size:14px;margin:0 4px}.limit-hours-input{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:6px 12px;font-size:14px;width:100px;transition:all var(--transition-base)}.limit-hours-input:focus{background-color:#fff;outline:none;box-shadow:0 0 0 2px #3b82f680;border-color:#3b82f6}.hours-value{color:#0f172a;font-size:14px;font-weight:500}.operation-logs-table thead{background-color:#f8fafc}.operation-logs-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color)}.operation-logs-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.operation-logs-table tbody tr:hover{background-color:#3b82f608}.operation-logs-table tbody tr td{padding:16px var(--spacing-lg);vertical-align:middle}.operation-type{color:#0f172a;font-size:14px;font-weight:500}.target-type{color:#475569;font-size:14px;font-weight:500}.ip-address{color:#64748b;font-size:14px;font-family:Courier New,Courier,monospace}.ip-address.empty-data{color:#cbd5e1}.modal-header .btn-primary,.modal-header .btn-secondary,.modal-edit-button .btn-primary,.modal-edit-button .btn-secondary,.modal-button-group .btn-primary,.modal-button-group .btn-secondary,.modal-header .btn-sm,.modal-edit-button .btn-sm,.modal-button-group .btn-sm{font-weight:700;font-size:14px}.btn-set-limit{background-color:#2563eb;color:#fff;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all var(--transition-base);box-shadow:0 1px 2px #0000000d;display:inline-flex;align-items:center;justify-content:center}.btn-set-limit:hover:not(:disabled){background-color:#1d4ed8;box-shadow:0 2px 4px -1px #0000001a}.btn-set-limit:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 2px #0000000d}.btn-set-limit:disabled{opacity:.6;cursor:not-allowed}.btn-set-limit:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.user-id-number{color:#64748b;font-weight:700;font-family:Courier New,Courier,monospace;font-size:14px}.user-name-bold{color:#0f172a;font-weight:700;font-size:16px}.user-email,.user-phone{color:#64748b;font-size:14px}.user-phone.empty-data{color:#cbd5e1}.recipient-number-input{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:6px 12px;font-size:14px;transition:all var(--transition-base)}.recipient-number-input:focus{background-color:#fff;outline:none;box-shadow:0 0 0 2px #3b82f680;border-color:#3b82f6}.btn-save-meta{background-color:#2563eb;color:#fff;font-weight:700;height:32px;padding:0 12px;border-radius:6px;border:none;cursor:pointer;transition:all var(--transition-base);box-shadow:0 1px 2px #0000000d;font-size:14px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.btn-save-meta:hover:not(:disabled){background-color:#1d4ed8;box-shadow:0 2px 4px -1px #0000001a}.btn-save-meta:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 2px #0000000d}.btn-save-meta:disabled{opacity:.6;cursor:not-allowed}.btn-save-meta:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.user-action-buttons{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.btn-detail-user,.btn-edit-user{background-color:#f1f5f9;color:#475569;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center}.btn-detail-user:hover:not(:disabled),.btn-edit-user:hover:not(:disabled){background-color:#e2e8f0}.btn-detail-user:active:not(:disabled),.btn-edit-user:active:not(:disabled){transform:translateY(1px)}.btn-detail-user:disabled,.btn-edit-user:disabled{opacity:.6;cursor:not-allowed}.btn-detail-user:focus-visible,.btn-edit-user:focus-visible{outline:2px solid #475569;outline-offset:2px}.btn-edit-user{background-color:var(--primary-color, #2563eb);color:#fff}.btn-edit-user:hover:not(:disabled){background-color:var(--primary-hover, #1d4ed8)}.btn-edit-user:focus-visible{outline:2px solid var(--primary-color, #2563eb);outline-offset:2px}.btn-approve-user{background:linear-gradient(135deg,#10b981,#34d399);color:#fff;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all var(--transition-base);box-shadow:0 1px 2px #0000000d;display:inline-flex;align-items:center;justify-content:center}.btn-approve-user:hover:not(:disabled){background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 2px 4px -1px #0000001a}.btn-approve-user:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 2px #0000000d}.btn-approve-user:disabled{opacity:.6;cursor:not-allowed}.btn-approve-user:focus-visible{outline:2px solid #10b981;outline-offset:2px}.btn-reject-user{background-color:#fff;color:#ef4444;border:1px solid #fecaca;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center}.btn-reject-user:hover:not(:disabled){background-color:#fef2f2;border-color:#fca5a5}.btn-reject-user:active:not(:disabled){background-color:#fee2e2;transform:translateY(1px)}.btn-reject-user:disabled{opacity:.6;cursor:not-allowed}.btn-reject-user:focus-visible{outline:2px solid #ef4444;outline-offset:2px}.admin-table th{background-color:var(--background-color);font-weight:600;color:var(--text-primary)}.acceptances-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.reports-by-month{display:flex;flex-direction:column;gap:var(--spacing-xl)}.month-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.month-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background-color:#f8fafc;border-left:4px solid var(--primary-color, #6366f1);border-radius:6px}.month-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.month-count{font-size:14px;color:var(--text-secondary);background-color:#fff;padding:4px 12px;border-radius:12px;border:1px solid var(--border-light)}.month-filter-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.month-filter-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:14px;color:var(--text-secondary)}.month-filter-label span{white-space:nowrap}.month-filter-select{padding:6px 12px;font-size:14px;border:1px solid var(--border-color);border-radius:6px;background-color:#fff;color:var(--text-primary);cursor:pointer;min-width:150px}.month-filter-select:focus{outline:2px solid var(--primary-color, #6366f1);outline-offset:2px}.acceptance-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color, #6366f1);margin:0}.acceptance-checkbox:disabled{cursor:not-allowed;opacity:.4}.acceptance-checkbox:not(:disabled):hover{transform:scale(1.1);transition:transform .2s ease}.acceptance-checkbox:focus{outline:2px solid var(--primary-color, #6366f1);outline-offset:2px;border-radius:2px}.acceptance-checkbox-select-all{width:20px;height:20px}.checkbox-cell{width:40px;text-align:center;vertical-align:middle;padding:var(--spacing-sm) var(--spacing-md)}.acceptances-table thead{background-color:#f8fafc}.acceptances-table thead tr th{background-color:#f8fafc;color:#64748b;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.acceptances-table thead tr th.checkbox-cell{text-align:center;vertical-align:middle}.acceptances-table thead tr th:nth-child(5){width:130px}.acceptances-table thead tr th:nth-child(6){width:215px}.acceptances-table thead tr th{font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color);text-align:center!important}.acceptances-table tbody tr{transition:background-color var(--transition-fast)}.acceptances-table tbody tr:hover{background-color:#3b82f60d}.acceptances-table tbody tr td{padding:24px var(--spacing-lg);vertical-align:middle;text-align:center!important}.acceptances-table tbody tr td:nth-child(5){width:130px}.acceptances-table tbody tr td:nth-child(6){width:215px;white-space:normal;word-break:keep-all}.acceptances-table tbody tr td:nth-child(6) .status-badge{display:inline-block!important;text-align:center;margin:0 auto;max-width:100%;box-sizing:border-box;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.4}.request-id{color:#475569;font-family:Courier New,Courier,monospace;font-size:14px;font-weight:500}.download-link{display:inline-flex;align-items:center;gap:4px;color:#2563eb;background:none;border:none;padding:4px 8px;cursor:pointer;font-size:14px;font-weight:500;text-decoration:none;transition:color var(--transition-base)}.download-link:hover{color:#1e40af}.download-link svg{flex-shrink:0}.download-link span{white-space:nowrap}.user-name{color:#0f172a;font-weight:600;font-size:14px}.datetime-date{color:#0f172a;font-size:14px;font-weight:500;line-height:1.4}.datetime-time{color:#64748b;font-size:12px;line-height:1.4}.action-buttons{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.action-buttons .btn-secondary{min-width:100px;height:36px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.btn-approve{background-color:#2563eb;color:#fff;border-radius:6px;min-width:100px;height:36px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-base);box-shadow:0 1px 2px #0000000d;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;padding:0 16px}.btn-approve:hover:not(:disabled){background-color:#1d4ed8;box-shadow:0 2px 4px -1px #0000001a}.btn-approve:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 2px #0000000d}.btn-approve:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.btn-reject{background-color:#fff;color:#dc2626;border:1px solid #fca5a5;border-radius:6px;min-width:100px;height:36px;font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition-base);box-shadow:0 1px 2px #0000000d;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;padding:0 16px}.btn-reject:hover:not(:disabled){background-color:#fef2f2;border-color:#f87171;color:#b91c1c}.btn-reject:active:not(:disabled){background-color:#fee2e2;transform:translateY(1px);box-shadow:0 1px 2px #0000000d}.btn-reject:disabled{opacity:.6;cursor:not-allowed}.btn-reject:focus-visible{outline:2px solid #dc2626;outline-offset:2px}.btn-sm{padding:.25rem .75rem;font-size:.875rem;margin-right:.5rem;transition:all var(--transition-fast)}.status-approved{background-color:#dcfce7;color:#15803d;border:none}.status-draft{background-color:#f3f4f6;color:#374151}.status-pending{background-color:#fef3c7;color:#92400e}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:.25rem;font-size:.875rem;font-weight:700;box-sizing:border-box;max-width:100%;word-wrap:break-word;overflow-wrap:break-word}@media (max-width: 480px){.status-badge{font-size:.75rem;padding:.2rem .5rem}}.acceptances-table .status-approved{background-color:#dcfce7;color:#15803d;border:none}.acceptances-table .status-pending{background-color:#fef3c7;color:#92400e}.acceptances-table .status-badge{display:inline-block;white-space:normal;word-break:keep-all;line-height:1.3;padding:.25rem .5rem;font-size:.75rem;max-width:100%;text-align:center}@media (max-width: 768px){.acceptances-table .status-badge{font-size:.7rem;padding:.2rem .4rem;line-height:1.2}}.admin-stats-section{margin-bottom:var(--spacing-xl)}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg)}@media (max-width: 1200px){.admin-stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.admin-stats-grid{grid-template-columns:1fr}}.admin-stat-card{background-color:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 1px 2px #0000000d;border:1px solid #f1f5f9;transition:all var(--transition-base)}.admin-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.admin-stat-title{font-size:14px;font-weight:500;color:#64748b;margin:0 0 var(--spacing-md) 0}.admin-stat-value{font-size:32px;font-weight:700;color:#0f172a;line-height:1.2;margin-bottom:var(--spacing-xs)}.admin-stat-subtitle{margin-top:var(--spacing-sm);display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.admin-stat-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;background-color:#f1f5f9;color:#475569}.admin-stat-badge.pending{background-color:#fef3c7;color:#92400e}.admin-stat-badge.alert{background-color:#fee2e2;color:#991b1b}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1rem}.stat-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 2px 8px #00000014;transition:all var(--transition-base)}.stat-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.stat-card h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.stat-content{display:flex;flex-direction:column;gap:.75rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:400}.stat-value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.stat-value.approved{color:#059669}.stat-value.pending{color:#d97706}.admin-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--border-color);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.admin-tabs::-webkit-scrollbar{height:6px}.admin-tabs::-webkit-scrollbar-track{background:transparent}.admin-tabs::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.admin-tabs::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary)}.admin-tab-content{width:100%;position:relative;contain:layout style;box-sizing:border-box;min-height:400px}.admin-tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);margin-bottom:-2px;white-space:nowrap;flex-shrink:0}.admin-tab:hover{color:var(--text-primary);background-color:var(--surface-hover)}.admin-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background-color:transparent}.dashboard{max-width:100%;width:100%;box-sizing:border-box;overflow-x:hidden;padding:0}.dashboard-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-light)}.dashboard-title h1{font-size:32px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);letter-spacing:-.5px;line-height:1.2}.welcome-message{font-size:16px;color:var(--text-secondary);font-weight:400;margin:0;line-height:1.5}.dashboard-content{display:flex;flex-direction:column;gap:var(--spacing-xl);width:100%}.dashboard-intro-required{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid var(--primary-light, #93c5fd);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.dashboard-intro-required-text{margin:0 0 var(--spacing-md) 0;font-size:15px;color:var(--text-primary);line-height:1.6}.dashboard-intro-required-btn{display:inline-block;padding:.5rem 1rem;font-size:14px;font-weight:600;text-decoration:none;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.dashboard-alerts{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.guide-proposals-section{margin-bottom:1.5rem;padding:1.25rem;background:#eff6ff;border:1px solid #93c5fd;border-radius:8px}.guide-proposals-section__title{font-size:1.1rem;margin:0 0 .75rem}.guide-proposals-section__desc{font-size:.9rem;color:#1e40af;margin-bottom:1rem}.guide-proposals-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.guide-proposal-card{padding:1rem;background:#fff;border-radius:6px;border:1px solid #bfdbfe}.guide-proposal-card__head{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.guide-proposal-card__content{margin:.25rem 0 0;font-size:.9rem}.guide-proposal-card__message{margin:.25rem 0 0;font-size:.9rem;color:#64748b}.guide-proposal-card__actions{margin-top:.75rem;display:flex;gap:.5rem}@media (min-width: 769px){.guide-proposal-card{padding:1.25rem}}@media (min-width: 769px){.guide-proposals-section{padding:1.5rem 1.75rem;margin-bottom:2rem}.guide-proposals-section__title{font-size:1.2rem}.guide-proposals-section__desc{font-size:.95rem}.guide-proposals-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.guide-proposal-card__actions{margin-top:1rem}}.section-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0;display:flex;align-items:center;gap:var(--spacing-sm)}.quick-actions-section{margin-bottom:var(--spacing-xl)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.section-header h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:20px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.notifications-section{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:2px solid #d1d5db;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 4px 12px #00000014;transition:all var(--transition-base)}.notifications-section:hover{box-shadow:0 6px 16px #0000001f;transform:translateY(-1px);border-color:#9ca3af}.notification-count{background-color:var(--primary-light);color:var(--primary-color);padding:2px 10px;border-radius:var(--radius-full);font-size:13px;font-weight:500}.notification-list{list-style:none;display:flex;flex-direction:column;gap:0;margin:0;padding:0}.notification-item{padding:var(--spacing-md);border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--surface-hover)}.notification-content{flex:1}.notification-content strong{display:block;margin-bottom:var(--spacing-xs);color:var(--text-primary);font-size:14px;font-weight:500}.notification-content p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.5}.notification-item small{color:var(--text-tertiary);font-size:12px;white-space:nowrap}.announcements-section{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 4px 12px #3b82f626;transition:all var(--transition-base)}.announcements-section:hover{box-shadow:0 6px 16px #3b82f633;transform:translateY(-1px)}.announcements-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.view-all-link{font-size:14px;color:var(--primary-color);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.view-all-link:hover{color:var(--primary-hover);text-decoration:underline}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);width:100%}.quick-action-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-lg);font-size:16px;font-weight:700;text-decoration:none;transition:all var(--transition-base);position:relative;min-height:56px;box-shadow:0 2px 8px #00000014}.quick-action-btn.primary{background:linear-gradient(135deg,var(--primary-color) 0%,#1557b0 100%);color:#fff;box-shadow:0 4px 12px #1a73e84d;border:none}.quick-action-btn.primary:hover{transform:translateY(-3px);box-shadow:0 8px 20px #1a73e866;text-decoration:none;color:#fff}.quick-action-btn.primary:active{transform:translateY(-1px);box-shadow:0 4px 12px #1a73e84d}.quick-action-btn.secondary{background-color:#fff;color:var(--text-primary);border:2px solid var(--border-color)}.quick-action-btn.secondary:hover{background-color:var(--surface-hover);border-color:var(--primary-color);text-decoration:none;color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.quick-action-btn.secondary:active{transform:translateY(0);box-shadow:0 2px 8px #00000014}.action-badge{background-color:var(--error-color);color:#fff;font-size:12px;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-left:var(--spacing-xs)}.pending-reports-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 4px 12px #f59e0b26;transition:all var(--transition-base)}.pending-reports-section:hover{box-shadow:0 6px 16px #f59e0b33}.pending-count{background-color:#f59e0b;color:#fff;padding:2px 10px;border-radius:var(--radius-full);font-size:13px;font-weight:500}.pending-reports-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pending-report-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:#fff;border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast)}.pending-report-item:hover{box-shadow:var(--shadow-sm);text-decoration:none}.report-info{display:flex;align-items:center;gap:var(--spacing-md)}.report-type{background-color:var(--primary-light);color:var(--primary-color);padding:2px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:500}.report-date{color:var(--text-primary);font-size:14px;font-weight:500}.report-guide,.report-user{color:var(--text-secondary);font-size:13px}.report-right-info{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.revision-notes-preview{font-size:12px;color:#92400e;font-style:italic;max-width:200px;text-align:right}.pending-report-item.revision-requested{border-left:4px solid #f59e0b;background-color:#fffbeb}.report-status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;margin-left:var(--spacing-xs)}.report-status-badge.revision-badge{background-color:#fef3c7;color:#92400e}.report-status-badge.submitted-badge{background-color:#dbeafe;color:#1d4ed8}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl);width:100%;box-sizing:border-box}.dashboard-cards .card{max-width:100%;min-width:0}.dashboard-cards .limit-card{grid-column:1/-1;min-width:0}.card{background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-base);box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;width:100%;box-sizing:border-box;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color) 0%,#1557b0 100%);opacity:0;transition:opacity var(--transition-base)}.card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px);border-color:var(--primary-color)}.card:hover:before{opacity:1}.card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}.usage-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.card-header-left{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.card-icon{color:var(--primary-color)}.card h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.card p{color:var(--text-secondary);font-size:14px;margin:0 0 var(--spacing-md) 0;line-height:1.5;flex:1}.stats-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat-item{text-align:center;padding:var(--spacing-md);background-color:var(--surface-color);border-radius:var(--radius-md);border:1px solid var(--border-color)}.stat-item.highlight{background-color:var(--primary-light);border-color:var(--primary-color)}.stat-item.alert{background-color:#fef3c7;border-color:#f59e0b}.stat-value{display:block;font-size:28px;font-weight:600;color:var(--text-primary);line-height:1.2}.stat-item.highlight .stat-value{color:var(--primary-color)}.stat-item.alert .stat-value{color:#d97706}.stat-label{display:block;font-size:12px;color:var(--text-secondary);margin-top:var(--spacing-xs)}.usage-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);flex-direction:column;justify-content:space-between;overflow:visible}.usage-stats{display:flex;flex-direction:column;gap:var(--spacing-md)}.limit-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac;flex-direction:column;justify-content:space-between}.limit-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);gap:var(--spacing-md)}.limit-card-header-left{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.limit-card-icon{color:#16a34a;flex-shrink:0}.limit-card-title-section{display:flex;flex-direction:column;gap:2px}.limit-card-title-section h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.limit-card-subtitle{font-size:13px;color:#16a34a;font-weight:500;margin:0}.limit-stats{display:flex;flex-direction:column;gap:var(--spacing-md)}.limit-content{background-color:var(--surface-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 2px 8px #0000000a}.limit-content-dual{display:flex;flex-direction:row;gap:var(--spacing-xl);width:100%;box-sizing:border-box}.limit-type-block{flex:1;min-width:200px;padding:var(--spacing-md);border-radius:var(--radius-md);background:#ffffffb3;border:1px solid rgba(34,197,94,.2);box-sizing:border-box}@media (max-width: 768px){.limit-content-dual{flex-direction:column}.limit-type-block{min-width:0}}.limit-type-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0;padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-light)}.limit-summary{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:var(--radius-md);border:1px solid #86efac}.limit-summary-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);flex:1}.limit-summary-item.remaining .limit-number{color:#16a34a;font-size:32px;font-weight:700;line-height:1}.limit-summary-item.total .limit-number{color:var(--text-primary);font-size:28px;font-weight:600;line-height:1}.limit-summary-value{display:flex;align-items:baseline;gap:4px;white-space:nowrap}.limit-number{font-weight:600;transition:all var(--transition-base)}.limit-unit{font-size:16px;font-weight:500;color:var(--text-secondary)}.limit-summary-label{font-size:13px;color:var(--text-secondary);font-weight:500}.limit-summary-divider{width:1px;height:50px;background-color:#bbf7d0}@media (max-width: 768px){.limit-card .limit-summary{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.limit-card .limit-summary-item.remaining .limit-number{font-size:24px}.limit-card .limit-summary-item.total .limit-number{font-size:22px}.limit-card .limit-unit{font-size:13px}.limit-card .limit-summary-label{font-size:11px;line-height:1.2}.limit-card .limit-summary-divider{height:40px}.limit-card .limit-summary-item{gap:2px}.limit-card .limit-progress-label,.limit-card .limit-progress-percentage,.limit-card .limit-progress-details{font-size:12px}.limit-card .limit-type-title{font-size:14px}}.limit-progress-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.limit-progress-header{display:flex;justify-content:space-between;align-items:center}.limit-progress-label{font-size:13px;color:var(--text-secondary);font-weight:500}.limit-progress-percentage{font-size:16px;font-weight:600;color:var(--text-primary)}.limit-progress-bar{width:100%;height:12px;background-color:#e5e7eb;border-radius:var(--radius-full);overflow:hidden;position:relative;box-shadow:inset 0 1px 2px #0000001a}.limit-progress-fill{height:100%;border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1),background .3s ease;position:relative;overflow:hidden}.limit-progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}.limit-progress-fill.progress-safe{background:linear-gradient(90deg,#10b981,#34d399)}.limit-progress-fill.progress-warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.limit-progress-fill.progress-danger{background:linear-gradient(90deg,#ef4444,#f87171)}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.limit-progress-details{display:flex;justify-content:center;font-size:12px;color:var(--text-secondary)}.limit-progress-details strong{color:var(--text-primary);font-weight:600}.limit-empty{text-align:center;color:var(--text-secondary);font-size:14px;margin:0;padding:var(--spacing-md)}.btn-icon-small{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);margin:0 auto}.btn-icon-small:hover{background-color:var(--surface-hover);color:var(--primary-color)}.btn-icon-small:focus{outline:none;box-shadow:0 0 0 2px #1a73e833}.month-selector-header{display:flex;justify-content:flex-end;margin:0;flex-shrink:0}.month-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--surface-color);color:var(--text-primary);font-size:13px;cursor:pointer;min-width:120px;max-width:200px;transition:all var(--transition-fast)}.month-select:hover{border-color:var(--primary-color)}.month-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #1a73e833}.usage-content{background-color:var(--surface-color);border-radius:var(--radius-md);padding:var(--spacing-md)}.usage-total{font-size:36px;font-weight:600;color:var(--primary-color);margin:0 0 var(--spacing-md) 0;line-height:1}.usage-unit{font-size:16px;font-weight:400;color:var(--text-secondary);margin-left:var(--spacing-xs)}.usage-breakdown{display:flex;flex-direction:column;gap:var(--spacing-md)}.usage-bar-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.usage-bar-header{display:flex;justify-content:space-between;align-items:center}.usage-bar-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:13px;color:var(--text-secondary)}.usage-dot{width:8px;height:8px;border-radius:50%}.usage-dot.outing{background-color:#3b82f6}.usage-dot.home{background-color:#10b981}.usage-bar-value{font-size:13px;font-weight:500;color:var(--text-primary)}.usage-bar{height:8px;background-color:var(--border-color);border-radius:var(--radius-full);overflow:hidden}.usage-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base);min-width:4px}.usage-bar-fill.outing{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.usage-bar-fill.home{background:linear-gradient(90deg,#10b981,#34d399)}.matchings-section{background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 2px 8px #00000014;transition:all var(--transition-base)}.matchings-section:hover{box-shadow:0 4px 16px #0000001f}.matchings-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.matching-card{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);transition:all var(--transition-base)}.matching-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color)}.matching-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.matching-type{font-size:12px;color:var(--text-secondary);background-color:var(--surface-hover);padding:2px 8px;border-radius:var(--radius-sm)}.badge-info{background-color:#dbeafe;color:#1d4ed8}.badge-warning{background-color:#fef3c7;color:#d97706}.badge-success{background-color:#d1fae5;color:#059669}.badge-error{background-color:#fee2e2;color:#dc2626}.badge-default{background-color:var(--surface-hover);color:var(--text-secondary)}.matching-info h3{font-size:16px;font-weight:500;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0}.matching-details{display:flex;flex-direction:column;gap:var(--spacing-xs)}.matching-details p{display:flex;align-items:center;gap:var(--spacing-xs);font-size:14px;color:var(--text-secondary);margin:0}.matching-details svg{color:var(--text-tertiary);flex-shrink:0}.matching-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md);flex-wrap:wrap}.matching-actions .btn-primary,.matching-actions .btn-secondary{flex:1;min-width:120px;justify-content:center;border-radius:6px;font-weight:700;font-size:14px;height:36px;padding:0 16px}.matching-actions .btn-icon{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.matching-actions .btn-icon svg{width:18px;height:18px;flex-shrink:0}.matching-actions .btn-icon span{white-space:nowrap}.matchings-table-wrapper{overflow-x:auto;margin-top:var(--spacing-md)}.matchings-table{width:100%;border-collapse:collapse;font-size:14px}.matchings-table caption{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.matchings-table thead{background-color:#f8fafc}.matchings-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color);white-space:nowrap}.matchings-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.matchings-table tbody tr:hover{background-color:#3b82f608}.matchings-table tbody tr td{padding:16px var(--spacing-lg);border-bottom:1px solid var(--border-light);color:var(--text-secondary);vertical-align:middle}.matchings-table tbody tr:last-child td{border-bottom:none}.table-actions{text-align:center;vertical-align:middle;gap:var(--spacing-xs)}.action-buttons{display:inline-flex;gap:var(--spacing-xs);align-items:center;justify-content:center}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;transition:all .2s ease;text-decoration:none;cursor:pointer;position:relative}.action-btn svg{width:20px;height:20px;stroke:currentColor;flex-shrink:0}.action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.action-btn:active{transform:translateY(0);box-shadow:0 1px 4px #0000001a}.action-btn[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-4px);padding:6px 10px;background-color:#000000d9;color:#fff;font-size:12px;font-weight:500;white-space:nowrap;border-radius:var(--radius-sm);pointer-events:none;z-index:1000;margin-bottom:4px}.action-btn[title]:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000d9;pointer-events:none;z-index:1000}.action-btn-chat{background-color:var(--primary-color);color:#fff}.action-btn-chat:hover{background-color:var(--primary-hover)}.action-btn-chat:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.action-btn-detail{background-color:var(--surface-color);color:var(--text-primary);border:1px solid var(--border-color)}.action-btn-detail:hover{background-color:var(--background-color);border-color:var(--text-secondary);color:var(--text-primary)}.action-btn-detail:focus-visible{outline:2px solid var(--text-secondary);outline-offset:2px}.usage-table-wrapper{overflow-x:auto;margin-top:var(--spacing-md);width:100%;-webkit-overflow-scrolling:touch}.usage-table{width:auto;min-width:100%;border-collapse:collapse;font-size:13px;margin-top:var(--spacing-md)}.usage-table caption{font-size:14px;font-weight:500;color:var(--text-primary);text-align:left;margin-bottom:var(--spacing-sm)}.usage-table thead{background-color:#f8fafc}.usage-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color);text-align:left;white-space:nowrap}.usage-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.usage-table tbody tr:hover{background-color:#3b82f608}.usage-table tbody tr td{padding:16px var(--spacing-lg);border-bottom:1px solid var(--border-light);color:var(--text-secondary);font-size:14px;vertical-align:middle;white-space:nowrap}.usage-table tbody tr:last-child td{border-bottom:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.empty-state svg{color:var(--text-tertiary);margin-bottom:var(--spacing-md)}.empty-state .btn-primary{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px;margin-top:var(--spacing-lg)}.empty-state h3{font-size:18px;font-weight:500;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0}.empty-state p{font-size:14px;color:var(--text-secondary);margin:0 0 var(--spacing-lg) 0}.empty-state .btn-primary{padding:0 16px;min-height:36px;height:36px;border-radius:6px;font-size:14px;font-weight:700;letter-spacing:.25px;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-base);text-decoration:none}.admin-card{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#c084fc}.admin-card .card-icon{color:#9333ea}@media (max-width: 768px){.dashboard-header{padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-lg)}.dashboard-title h1{font-size:24px}.welcome-message{font-size:14px}.dashboard-content{gap:var(--spacing-lg)}.dashboard-alerts{gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.section-title{font-size:18px}.quick-actions-section{margin-bottom:var(--spacing-lg)}.quick-actions{grid-template-columns:1fr;gap:var(--spacing-sm)}.quick-action-btn{width:100%;justify-content:center;min-height:52px;padding:var(--spacing-md) var(--spacing-lg)}.dashboard-cards{grid-template-columns:1fr;gap:var(--spacing-lg);width:100%;box-sizing:border-box}.card{padding:var(--spacing-lg)}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.card h3{font-size:18px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.stat-value{font-size:24px}.usage-total{font-size:28px}.usage-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.month-selector-header{width:100%;justify-content:flex-start}.matching-card{padding:var(--spacing-md)}.matching-actions{flex-direction:column}.matching-actions .btn-primary,.matching-actions .btn-secondary{width:100%}.notification-item{flex-direction:column;gap:var(--spacing-sm)}.pending-report-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.section-header{flex-wrap:wrap;gap:var(--spacing-sm)}.matchings-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.acceptances-table-container{margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.acceptances-table{min-width:600px}.acceptances-table tbody tr td:nth-child(4){min-width:140px}.acceptances-table tbody tr td:nth-child(6){min-width:180px;white-space:nowrap}.monthly-limits-table{min-width:700px}.monthly-limits-table tbody tr td:nth-child(2){min-width:180px}.monthly-limits-table tbody tr td:nth-child(6){min-width:120px}.operation-logs-table{min-width:800px}.operation-logs-table tbody tr td:nth-child(1){min-width:140px}.operation-logs-table tbody tr td:nth-child(6){min-width:120px}.matchings-table{min-width:750px}.matchings-table thead tr th{padding:var(--spacing-sm) var(--spacing-md)}.matchings-table tbody tr td{padding:var(--spacing-sm) var(--spacing-md);white-space:normal;word-break:break-word;line-height:1.4}.matchings-table tbody tr td:nth-child(3){min-width:140px}.matchings-table tbody tr td:nth-child(4){min-width:180px}.table-actions{padding:var(--spacing-xs);white-space:nowrap}.action-buttons{flex-wrap:wrap;justify-content:center}.action-btn{width:36px;height:36px}.action-btn svg{width:18px;height:18px}.usage-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.usage-table{min-width:500px}.usage-table thead tr th{padding:var(--spacing-sm) var(--spacing-md)}.usage-table tbody tr td{padding:var(--spacing-sm) var(--spacing-md);white-space:normal;word-break:break-word;line-height:1.4}}@media (max-width: 480px){.dashboard-title h1{font-size:20px}.section-title,.section-header h2{font-size:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.stat-item{padding:var(--spacing-sm)}.stat-value{font-size:20px}.stat-label{font-size:11px}.card{padding:var(--spacing-md)}.card h3{font-size:16px}.quick-action-btn{font-size:14px;padding:var(--spacing-sm) var(--spacing-md);min-height:48px}.matchings-table-wrapper{margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.matchings-table{min-width:700px}.matchings-table thead tr th{padding:8px var(--spacing-sm)}.matchings-table tbody tr td{padding:10px var(--spacing-sm);line-height:1.4}.matchings-table tbody tr td:first-child{min-width:80px}.matchings-table tbody tr td:nth-child(2){min-width:10px}.matchings-table tbody tr td:nth-child(3){min-width:140px}.matchings-table tbody tr td:nth-child(4){min-width:180px}.matchings-table tbody tr td:nth-child(5){min-width:140px}.matchings-table tbody tr td:nth-child(6){min-width:140px}.matchings-table tbody tr td:nth-child(7){min-width:140px}.usage-table-wrapper{margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.usage-table{min-width:450px}.usage-table thead tr th{padding:8px var(--spacing-sm)}.usage-table tbody tr td{padding:10px var(--spacing-sm);line-height:1.4}}.email-templates-list{display:flex;flex-direction:column;gap:var(--spacing-xl)}.email-template-card{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.email-template-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color)}.template-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-color)}.template-title-section{flex:1}.template-title-section h3{font-size:20px;font-weight:700;color:#0f172a;margin:0 0 var(--spacing-xs) 0}.template-meta-info{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.template-recipient-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-md);font-size:13px;font-weight:600;white-space:nowrap}.template-recipient-badge.recipient-user{background-color:#dbeafe;color:#1e40af}.template-recipient-badge.recipient-guide{background-color:#fef3c7;color:#92400e}.template-recipient-badge.recipient-both{background-color:#e0e7ff;color:#3730a3}.template-trigger-info{font-size:13px;color:#64748b;font-style:italic}.template-toggle-section{display:flex;align-items:center;gap:var(--spacing-md)}.template-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.template-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.template-actions .btn-primary,.template-actions .btn-secondary{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px}.toggle-switch{position:relative;display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;display:inline-block;width:48px;height:24px;background-color:#cbd5e1;border-radius:24px;transition:background-color var(--transition-base)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:transform var(--transition-base);box-shadow:0 2px 4px #0003}.toggle-switch input[type=checkbox]:checked+.toggle-slider{background-color:var(--primary-color)}.toggle-switch input[type=checkbox]:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input[type=checkbox]:focus+.toggle-slider{box-shadow:0 0 0 3px #1a73e833}.toggle-label{font-size:14px;font-weight:500;color:var(--text-primary);min-width:40px}.email-settings-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.email-setting-card{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.email-setting-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color)}.setting-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-color)}.setting-title-section{flex:1}.setting-title-section h3{font-size:18px;font-weight:700;color:#0f172a;margin:0 0 var(--spacing-xs) 0}.setting-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.setting-toggle-section{display:flex;align-items:center;gap:var(--spacing-md)}.setting-card-body{display:flex;flex-direction:column;gap:var(--spacing-md)}.reminder-input-group{display:flex;align-items:center;gap:var(--spacing-sm)}.input-suffix{font-size:14px;color:var(--text-secondary);font-weight:500}.setting-actions{display:flex;justify-content:flex-end;margin-top:var(--spacing-md)}.setting-actions .btn-primary{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.form-group:last-child{margin-bottom:0}.form-control{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);background-color:var(--surface-color);transition:all var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a}.form-control::placeholder{color:var(--text-tertiary)}.form-text{display:block;margin-top:var(--spacing-xs);font-size:12px;color:var(--text-secondary);line-height:1.5}@media (max-width: 1024px){.admin-dashboard-wrapper{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid #e2e8f0}.admin-sidebar-nav{flex-direction:row;overflow-x:auto;gap:var(--spacing-sm)}.admin-sidebar-item{white-space:nowrap;flex-shrink:0}}@media (max-width: 768px){.admin-dashboard-wrapper{flex-direction:column}.admin-dashboard-main{padding:var(--spacing-md)}.admin-dashboard{padding:0}.admin-dashboard-header{padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-lg)}.admin-dashboard-header h1{font-size:24px}.admin-welcome-message{font-size:14px}.admin-section .section-header h2{font-size:18px}.admin-tabs{gap:.25rem;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-xs)}.admin-tab{padding:var(--spacing-sm) var(--spacing-md);font-size:14px;min-width:auto}.admin-section{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.admin-section h2{font-size:20px;margin-bottom:var(--spacing-md)}.section-actions{flex-direction:column;gap:var(--spacing-sm);align-items:flex-end}.section-actions button{width:100%}.filter-controls{width:100%;flex-direction:column;align-items:stretch;gap:var(--spacing-xs);padding:var(--spacing-sm)}.filter-toggle{width:100%;justify-content:space-between}.filter-days-select{width:100%;padding:8px 12px}.pending-count{font-size:13px;padding:2px 10px;text-align:center;display:block;width:100%}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{min-width:800px;font-size:14px}.admin-table th,.admin-table td{padding:var(--spacing-sm);white-space:nowrap;text-align:center}.admin-table td:nth-child(4),.admin-table td:nth-child(5),.admin-table td:nth-child(6){white-space:normal}.table-actions{flex-direction:column;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center;align-items:center}.setting-card-header{flex-direction:column;gap:var(--spacing-md)}.setting-toggle-section{width:100%;justify-content:space-between}.reminder-input-group{flex-direction:column;align-items:flex-start}.setting-actions{flex-direction:column}.setting-actions button{width:100%}.cards-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.card{padding:var(--spacing-lg)}.card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.limit-info-grid{grid-template-columns:1fr}.limit-remaining-section{align-items:center}}@media (max-width: 480px){.admin-dashboard-header h1{font-size:20px}.admin-welcome-message{font-size:13px}.admin-section .section-header h2{font-size:16px}.section-actions{gap:var(--spacing-xs)}.filter-controls{padding:var(--spacing-xs);font-size:12px;flex-direction:column;align-items:stretch;gap:var(--spacing-xs)}.filter-toggle{font-size:12px;width:100%;justify-content:space-between}.filter-toggle span{font-size:12px}.filter-days-select{font-size:12px;padding:6px 10px;width:100%}.section-actions .btn-primary{font-size:14px;padding:10px 16px;width:100%}.section-actions .btn-primary svg{width:14px;height:14px}.pending-count{font-size:13px;padding:2px 10px;text-align:center;display:block;width:50px}.admin-tabs{gap:0;margin-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color);padding-bottom:0}.admin-tab{padding:var(--spacing-sm) var(--spacing-sm);font-size:12px;border-bottom:2px solid transparent;margin-bottom:-1px}.admin-tab.active{border-bottom-color:var(--primary-color)}.admin-section{padding:var(--spacing-md)}.admin-section h2{font-size:18px}.admin-table{min-width:600px}.admin-table th,.admin-table td{padding:8px var(--spacing-xs);white-space:nowrap;text-align:center;line-height:1.3;min-width:140px}.admin-table td:nth-child(4),.admin-table td:nth-child(5),.admin-table td:nth-child(6){white-space:normal;word-break:break-word}.table-container{margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.monthly-limits-table{min-width:1250px}.monthly-limits-table tbody tr td:nth-child(2){min-width:160px}.monthly-limits-table tbody tr td:nth-child(6){min-width:100px}.operation-logs-table{min-width:900px}.operation-logs-table tbody tr td:nth-child(1){min-width:140px}.operation-logs-table tbody tr td:nth-child(6){min-width:100px}.acceptances-table thead tr th{padding:var(--spacing-sm) var(--spacing-md);font-size:11px;width:140px}.acceptances-table tbody tr td{padding:var(--spacing-sm) var(--spacing-md)}.acceptances-table .user-info-cell{flex-direction:column;align-items:flex-start;gap:4px}.acceptances-table .action-buttons{flex-direction:column;width:100%}.acceptances-table .action-buttons .btn-approve,.acceptances-table .action-buttons .btn-reject{width:100%}.table-inline-field{align-items:center}.table-inline-field input{min-width:auto;max-width:none;width:100%}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px}.modal-content{width:95%!important;max-height:90vh!important;padding:var(--spacing-md)!important}.modal-body{grid-template-columns:1fr!important;gap:var(--spacing-sm)!important;font-size:14px!important}}.profile-container{max-width:800px;margin:0 auto}.profile-container h1{font-size:32px;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-xl);letter-spacing:0}@media (max-width: 768px){.profile-container{padding:0 var(--spacing-md)}.profile-container h1{font-size:24px}}@media (max-width: 480px){.profile-container{padding:0 var(--spacing-sm)}.profile-container h1{font-size:20px}}.profile-form{background-color:var(--surface-color);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}@media (max-width: 768px){.profile-form{padding:var(--spacing-lg)}}@media (max-width: 480px){.profile-form{padding:var(--spacing-md)}}.form-group>label:not(.radio-label){margin-bottom:var(--spacing-xs);font-size:14px;font-weight:500;color:var(--text-primary)}.readonly-label{font-size:12px;font-weight:400;color:var(--text-secondary);margin-left:var(--spacing-xs)}.checkbox-group{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-sm)}@media (max-width: 768px){.checkbox-group{flex-direction:row;justify-content:flex-start;gap:var(--spacing-sm)}}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:14px;color:var(--text-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.checkbox-label:hover{background-color:var(--surface-hover)}.checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer}.radio-group{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-top:.25rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:14px;color:var(--text-primary);white-space:nowrap}.radio-label input[type=radio]{flex-shrink:0;margin:0;cursor:pointer}.proposal-preference-group fieldset{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);margin:0}.proposal-preference-group legend{font-weight:600;padding:0 .5rem}.form-help-text--note{margin-top:.5rem;color:var(--text-secondary);font-size:13px}.form-help-text{font-size:13px;color:var(--text-secondary);margin:var(--spacing-xs) 0 var(--spacing-sm) 0;line-height:1.5}.readonly-textarea{background-color:var(--surface-hover);color:var(--text-secondary);cursor:not-allowed;resize:none}.success-message{background-color:#d1fae5;color:#065f46;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border-left:4px solid var(--success-color);font-size:14px}.form-actions .btn-primary,.form-actions .btn-secondary{min-width:120px;font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px}.loading-spinner.small{width:16px;height:16px;border-width:2px}.stats-list{margin-top:var(--spacing-sm)}.stats-list p{margin-bottom:var(--spacing-sm);font-size:14px;color:var(--text-primary)}.stats-list ul{list-style:none;padding:0;margin:var(--spacing-sm) 0 0 0}.stats-list li{padding:var(--spacing-xs) 0;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.stats-list li:last-child{border-bottom:none}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:calc(100vh - 200px);max-width:900px;margin:0 auto;background-color:var(--background-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}@media (max-width: 768px){.chat-container{height:calc(100vh - 150px);max-height:calc(100vh - 150px);border-radius:0;box-shadow:none}}@media (max-width: 480px){.chat-container{height:calc(100vh - 120px);max-height:calc(100vh - 120px)}}.chat-header{background-color:var(--surface-color);border-bottom:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);flex-shrink:0;box-shadow:var(--shadow-sm)}@media (max-width: 768px){.chat-header{padding:var(--spacing-sm) var(--spacing-md)}}.chat-header-info{display:flex;align-items:center;gap:var(--spacing-md);width:100%}.chat-header-info h1{font-size:18px;font-weight:500;color:var(--text-primary);margin:0;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.chat-header-info h1{font-size:16px}}.chat-back-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);flex-shrink:0}.chat-back-link:hover{background-color:var(--surface-hover);color:var(--text-primary);transform:translate(-2px)}.chat-header-content{display:flex;justify-content:space-between;align-items:center;flex:1;gap:var(--spacing-md)}@media (max-width: 768px){.chat-header-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.chat-header-main{flex:1;min-width:0}.chat-header-title-section{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.chat-header-badge{display:flex;align-items:center}.chat-role-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:11px;font-weight:500;white-space:nowrap}.chat-role-badge.chat-role-badge-guide{background-color:#3b82f61a;color:#3b82f6}.chat-role-badge.chat-role-badge-user{background-color:#10b9811a;color:#10b981}.chat-header-details{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.chat-subtitle{font-size:12px;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:var(--spacing-xs)}@media (max-width: 768px){.chat-subtitle{font-size:11px}}.chat-detail-icon{flex-shrink:0;color:var(--text-tertiary)}.chat-header-status{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}@media (max-width: 768px){.chat-header-status{align-self:flex-end}}.status-dot{width:8px;height:8px;border-radius:var(--radius-full);background-color:#10b981;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.status-text{font-size:12px;color:var(--text-secondary);font-weight:400}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-lg);background-color:var(--background-color);display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:0}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.chat-messages>div{display:contents}@media (max-width: 768px){.chat-messages{padding:var(--spacing-md)}}.chat-network-error{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-network-error-content{display:flex;align-items:center;gap:var(--spacing-sm);font-size:13px;color:#92400e}.chat-network-error-content svg{flex-shrink:0;color:#f59e0b}.chat-network-error-retry{margin-left:auto;padding:var(--spacing-xs) var(--spacing-sm);background-color:#f59e0b;color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.chat-network-error-retry:hover{background-color:#d97706;transform:scale(1.05)}.chat-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 200px);color:var(--text-secondary)}.chat-loading-spinner{display:flex;gap:8px;margin-bottom:var(--spacing-md)}.spinner-ring{width:12px;height:12px;border-radius:var(--radius-full);background-color:var(--primary-color);animation:spinner-bounce 1.4s ease-in-out infinite both}.spinner-ring:nth-child(1){animation-delay:-.32s}.spinner-ring:nth-child(2){animation-delay:-.16s}@keyframes spinner-bounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.empty-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--text-secondary);text-align:center;padding:var(--spacing-2xl)}.empty-messages h3{font-size:18px;font-weight:500;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.empty-messages-icon{width:80px;height:80px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-light) 0%,var(--primary-color) 100%);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg);color:var(--text-on-primary);opacity:.8}@media (max-width: 768px){.empty-messages-icon{width:64px;height:64px}}.empty-messages-hint{font-size:14px;color:var(--text-tertiary);margin:0}.chat-info-box{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);max-width:500px;width:100%}.chat-info-icon{flex-shrink:0;color:var(--primary-color);margin-top:2px}.chat-info-content{flex:1;text-align:left}.chat-info-title{font-size:14px;font-weight:500;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0}.chat-info-text{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.message-date-separator{display:flex;align-items:center;justify-content:center;margin:var(--spacing-lg) 0;position:relative}.message-date-separator:before,.message-date-separator:after{content:"";flex:1;height:1px;background-color:var(--border-color)}.message-date-separator span{padding:0 var(--spacing-md);font-size:12px;color:var(--text-tertiary);background-color:var(--background-color);font-weight:500}.message-wrapper{display:flex;align-items:flex-end;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs);max-width:75%;animation:messageSlideIn .3s ease-out;opacity:1;width:100%}.message-wrapper.message-sending{opacity:.7}@media (max-width: 768px){.message-wrapper{max-width:85%}}@media (max-width: 480px){.message-wrapper{max-width:90%}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-wrapper-sent{align-self:flex-end!important;flex-direction:row-reverse;margin-left:auto}.message-wrapper-received{align-self:flex-start!important;margin-right:auto}.message-avatar{width:32px;height:32px;border-radius:var(--radius-full);background-color:var(--primary-color);color:var(--text-on-primary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;flex-shrink:0}@media (max-width: 768px){.message-avatar{width:28px;height:28px;font-size:12px}}.message-avatar.message-avatar-own{background-color:var(--secondary-color)}.message{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);word-wrap:break-word;word-break:break-word;position:relative;max-width:100%}@media (max-width: 480px){.message{padding:var(--spacing-xs) var(--spacing-sm)}}.message-sent{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:var(--text-on-primary);border-bottom-right-radius:4px;box-shadow:0 1px 2px #0000001a}.message-received{background-color:var(--surface-color);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:4px;box-shadow:0 1px 2px #0000000d}.message-received .message-footer{justify-content:flex-start}.message-received .message-time{color:var(--text-tertiary)}.message-sender-name{font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs);opacity:.8}.message-content{font-size:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}@media (max-width: 480px){.message-content{font-size:13px}}.message-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.message-time{font-size:11px;opacity:.7;color:inherit}.message-status{display:flex;align-items:center;opacity:.6}.message-status-sending{font-size:10px;opacity:.8}.message-status-icon{width:14px;height:14px;color:currentColor;opacity:.7}.chat-input-form{background-color:var(--surface-color);border-top:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);flex-shrink:0;box-shadow:0 -1px 2px #3c40431a}@media (max-width: 768px){.chat-input-form{padding:var(--spacing-sm) var(--spacing-md)}}.chat-input-wrapper{display:flex;gap:var(--spacing-sm);align-items:center;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-fast)}.chat-input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}@media (max-width: 768px){.chat-input-wrapper{padding:var(--spacing-xs)}}.chat-voice-button{background:none;border:none;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-full);transition:all var(--transition-fast);flex-shrink:0;padding:0}.chat-voice-button:hover{background-color:var(--surface-hover);color:var(--primary-color)}.chat-voice-button.chat-voice-button-recording{color:var(--error-color);background-color:#ea43351a;animation:pulse 1.5s ease-in-out infinite}.chat-voice-button svg{width:20px;height:20px}.chat-recording-indicator{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:12px;color:var(--error-color)}.chat-recording-dot{width:8px;height:8px;border-radius:var(--radius-full);background-color:var(--error-color);animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.chat-input{flex:1;border:none;background:transparent;padding:var(--spacing-sm) var(--spacing-md);font-size:14px;color:var(--text-primary);outline:none}.chat-input::placeholder{color:var(--text-tertiary)}.chat-send-button{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:var(--text-on-primary);border:none;border-radius:var(--radius-full);min-width:36px;width:auto;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;padding:0 var(--spacing-sm);box-shadow:0 2px 4px #0000001a}.chat-send-button:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-hover) 0%,var(--primary-color) 100%);transform:scale(1.08);box-shadow:0 4px 8px #00000026}.chat-send-button:active:not(:disabled){transform:scale(.95)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-send-button svg{width:18px;height:18px}@media (max-width: 768px){.chat-send-button{min-width:32px;height:32px;padding:0 var(--spacing-xs)}}.chat-sending{font-size:12px;white-space:nowrap;line-height:1;padding:0 var(--spacing-xs)}@media (max-width: 768px){.chat-sending{font-size:11px;padding:0 4px}}.requests-container{max-width:1000px;margin:0 auto}.requests-container h1{font-size:32px;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-lg);letter-spacing:0}.requests-container .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.requests-container .page-header h1{margin-bottom:0}.requests-container .btn-primary-icon{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px;display:inline-flex;align-items:center;gap:var(--spacing-sm)}@media (max-width: 768px){.requests-container{padding:0 var(--spacing-md)}.requests-container h1{font-size:24px}}@media (max-width: 480px){.requests-container{padding:0 var(--spacing-sm)}.requests-container h1{font-size:20px}}.info-text{background-color:#dbeafe;color:#1e40af;padding:var(--spacing-md);border-radius:var(--radius-md);font-size:14px;line-height:1.5}.proposal-section{margin-bottom:2rem;padding:1.25rem;background:#f0fdf4;border:1px solid #86efac;border-radius:8px}.proposal-section h2{font-size:1.1rem;margin:0 0 .75rem}.proposal-section .proposal-section-desc{font-size:.9rem;color:#166534;margin-bottom:1rem}.proposal-section .proposal-section-note{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) 0}.proposal-section .proposal-toggle-btn{margin-bottom:1rem}.proposal-section .proposal-form-wrap{width:100%;max-width:100%}.proposal-section .proposal-form-wrap .form-group>label{display:block;margin-bottom:.25rem}.proposal-section .proposal-form-wrap .form-group{width:100%}.proposal-section .proposal-form-wrap select,.proposal-section .proposal-form-wrap input[type=text],.proposal-section .proposal-form-wrap input[type=date],.proposal-section .proposal-form-wrap input[type=time],.proposal-section .proposal-form-wrap textarea{width:100%;max-width:100%;box-sizing:border-box}.proposal-section .radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:.25rem}.proposal-section .radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:14px;color:var(--text-primary);white-space:nowrap}.proposal-section .radio-label input[type=radio]{flex-shrink:0;width:1rem;height:1rem;margin:0;cursor:pointer}.proposal-section .proposal-form-row{display:flex;gap:.5rem;margin-bottom:.75rem}.proposal-section .proposal-form-row .form-group{flex:1;min-width:0}.proposal-section .proposal-form-row .form-group select,.proposal-section .proposal-form-row .form-group input{width:100%;max-width:100%;box-sizing:border-box}.proposal-section .proposal-my-list{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #86efac}.proposal-section .proposal-my-list__title{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:var(--text-primary)}.proposal-section .proposal-my-list__hint{font-size:.8125rem;font-weight:400;color:var(--text-secondary)}.proposal-section .proposal-sent-cards{display:flex;flex-direction:column;gap:.75rem;max-height:320px;overflow-y:auto;overflow-x:hidden;padding-right:.25rem;scrollbar-width:thin;scrollbar-color:#86efac transparent}.proposal-section .proposal-sent-cards::-webkit-scrollbar{width:6px}.proposal-section .proposal-sent-cards::-webkit-scrollbar-track{background:transparent}.proposal-section .proposal-sent-cards::-webkit-scrollbar-thumb{background:#86efac;border-radius:3px}.proposal-section .proposal-sent-cards::-webkit-scrollbar-thumb:hover{background:#4ade80}.proposal-section .proposal-sent-card{background:#fff;border:1px solid #bbf7d0;border-radius:8px;padding:1rem;box-shadow:0 1px 2px #0000000a}.proposal-section .proposal-sent-card--bulk{border-left:4px solid #166534}.proposal-section .proposal-sent-card__body{display:flex;flex-direction:column;gap:.5rem}.proposal-section .proposal-sent-card__type{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0}.proposal-section .proposal-sent-card__meta{display:grid;gap:.25rem 1rem;margin:0;font-size:.875rem}.proposal-section .proposal-sent-card__meta dt{color:var(--text-secondary);font-weight:500;margin:0}.proposal-section .proposal-sent-card__meta dd{margin:0;color:var(--text-primary)}.proposal-section .proposal-sent-card__meta-row{display:flex;gap:.5rem;align-items:baseline}.proposal-section .proposal-sent-card__meta-row dt{flex:0 0 4.5em}.proposal-section .proposal-sent-card__meta-row dd{flex:1}.proposal-section .proposal-sent-card__bulk-stats{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.proposal-section .proposal-sent-card__stat{font-size:.8125rem;padding:.2rem .5rem;border-radius:4px;font-weight:500}.proposal-section .proposal-sent-card__stat--accepted{background:#dcfce7;color:#166534}.proposal-section .proposal-sent-card__stat--rejected{background:#fee2e2;color:#b91c1c}.proposal-section .proposal-sent-card__stat--pending{background:#e0e7ff;color:#3730a3}.proposal-section .proposal-sent-card__status{margin:.5rem 0 0}@media (min-width: 769px){.proposal-section{padding:1.5rem 1.75rem}.proposal-section h2{font-size:1.2rem}.proposal-section .proposal-section-desc{font-size:.95rem}.proposal-section .proposal-form-wrap{max-width:100%;min-width:0}.proposal-section .proposal-form-row{margin-bottom:1rem}.proposal-section .proposal-my-list__title{font-size:1.05rem;margin-bottom:.75rem}.proposal-section .proposal-sent-cards{max-height:400px}.proposal-section .proposal-sent-card{padding:1.125rem}}@media (max-width: 768px){.proposal-section{padding:1rem;margin-bottom:1.5rem}}.success-message{background-color:#e8f5e9;color:#2e7d32;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);border-left:4px solid #2e7d32;font-size:14px;display:flex;align-items:center;gap:var(--spacing-sm)}.success-icon{width:20px;height:20px;flex-shrink:0}.error-message,.error-message-with-retry{background-color:#fce8e6;color:var(--error-color);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);border-left:4px solid var(--error-color);font-size:14px}.error-message-with-retry p{margin:0 0 var(--spacing-md) 0}.error-message-with-retry .btn-primary{margin-top:var(--spacing-sm)}.requests-list{display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-width: 768px){.requests-list{gap:var(--spacing-md)}}.request-card{background-color:var(--surface-color);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all var(--transition-base)}.request-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-color);transform:translateY(-1px)}@media (max-width: 768px){.request-card{padding:var(--spacing-lg)}}@media (max-width: 480px){.request-card{padding:var(--spacing-md)}}.request-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.request-header h3{margin:0;font-size:18px;font-weight:700;color:#0f172a;letter-spacing:0;flex:1}@media (max-width: 768px){.request-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}}.status-badge-wrapper{display:flex;align-items:center;justify-content:center}.status-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:12px;font-weight:500;letter-spacing:.25px;white-space:nowrap;transition:all var(--transition-base);line-height:1}@media (max-width: 480px){.status-badge{font-size:11px;padding:.25rem .5rem;gap:.25rem}}.status-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;flex-shrink:0;margin-right:var(--spacing-xs)}.status-icon svg{width:100%;height:100%;display:block}.status-pending{background-color:#fef3c7;color:#92400e;border:1px solid #fde68a}.status-approval-pending{background-color:#fed7aa;color:#9a3412;border:2px solid #fdba74}.status-accepted{background-color:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.status-matched{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.status-in-progress{background-color:#e9d5ff;color:#6b21a8;border:1px solid #c084fc}.status-completed{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.status-cancelled{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.request-details{margin-bottom:var(--spacing-md)}.request-details p{margin:var(--spacing-xs) 0;color:var(--text-secondary);font-size:14px;line-height:1.5}.request-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.request-actions>button,.request-actions>a.btn-primary,.request-actions>div{flex:1;min-width:140px}.request-actions button,.request-actions a.btn-primary{width:100%;justify-content:center;padding:0 16px;min-height:36px;height:36px;border-radius:6px;font-size:14px;font-weight:700;letter-spacing:.25px;display:inline-flex;align-items:center;transition:all var(--transition-base)}.request-actions>div{display:flex;flex-direction:column;gap:var(--spacing-xs)}.request-actions button:disabled,.request-actions .btn-disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.request-actions .btn-danger{background-color:#fff;color:#ef4444;border:1px solid #fecaca;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center}.request-actions .btn-danger:hover:not(:disabled){background-color:#fef2f2;border-color:#fca5a5}.request-actions .btn-danger:active:not(:disabled){background-color:#fee2e2;transform:translateY(1px)}.request-actions .btn-danger:disabled{opacity:.6;cursor:not-allowed}.request-actions .btn-danger:focus-visible{outline:2px solid #ef4444;outline-offset:2px}@media (max-width: 768px){.request-actions{width:100%;flex-direction:column;gap:var(--spacing-sm)}.request-actions button{width:100%;min-width:auto}}.chat-availability-info{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:#3b82f60d;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-sm);margin-top:var(--spacing-xs)}.chat-availability-icon{flex-shrink:0;color:#3b82f6}.chat-availability-text{font-size:12px;color:#1e40af;line-height:1.4}.empty-state{text-align:center;padding:var(--spacing-2xl);background-color:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.empty-state p{margin-bottom:var(--spacing-md);color:var(--text-secondary);font-size:14px}.empty-state .btn-primary{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px}.applicants-panel{margin-top:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-color);display:flex;flex-direction:column;gap:var(--spacing-sm)}.loading-inline{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:14px}.applicants-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.applicant-card{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm);background:var(--surface-hover)}.applicant-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.applicant-name{font-weight:600;color:var(--text-primary)}.applicant-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md);color:var(--text-secondary);font-size:13px}.applicant-actions{margin-top:var(--spacing-sm)}.applicant-actions .btn-primary{min-width:auto;font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px}.btn-sm{padding:.375rem .75rem;font-size:13px;transition:all var(--transition-fast)}.btn-sm:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-sm:active:not(:disabled){transform:translateY(0)}@media (max-width: 480px){.request-meta{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.request-form-container{max-width:1200px;margin:0 auto;width:100%}.request-form-container h1{font-size:32px;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-xl);letter-spacing:0}@media (max-width: 768px){.request-form-container{max-width:100%}.request-form-container h1{font-size:24px}}.request-form{background-color:var(--surface-color);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);align-items:start}.request-form .form-row{grid-column:1/-1}@media (max-width: 1024px){.request-form{grid-template-columns:1fr;gap:var(--spacing-lg)}}@media (max-width: 768px){.request-form{padding:var(--spacing-lg);grid-template-columns:1fr}}@media (max-width: 480px){.request-form{padding:var(--spacing-md)}}.form-group.full-width{grid-column:1/-1}@media (max-width: 1024px){.form-group.full-width{grid-column:1}}.form-group label{margin-bottom:var(--spacing-xs);font-size:14px;font-weight:500;color:var(--text-primary)}.section-subtitle{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light);padding-bottom:var(--spacing-xs)}.form-block-full{grid-column:1/-1}.form-section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md);margin-top:0}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.voice-input-section,.textarea-with-voice{position:relative}.textarea-with-voice textarea{padding-right:50px}.input-with-voice{position:relative;display:block}.input-with-voice input[type=text]{padding-right:48px;width:100%;box-sizing:border-box}.input-with-voice .voice-input-btn{right:var(--spacing-sm)}.voice-input-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-base);z-index:1}.voice-input-btn:hover:not(:disabled){background-color:var(--primary-color);color:var(--text-on-primary);border-color:var(--primary-color)}.voice-input-btn:disabled{opacity:.5;cursor:not-allowed}.voice-input-btn.recording{background-color:var(--error-color);color:var(--text-on-primary);border-color:var(--error-color);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.voice-recording-indicator{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-xs);font-size:14px;color:var(--error-color)}.recording-dot{width:8px;height:8px;background-color:var(--error-color);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.voice-controls{margin-top:var(--spacing-sm);display:flex;gap:var(--spacing-sm);flex-wrap:wrap}@media (max-width: 480px){.voice-controls{flex-direction:column}.voice-controls button{width:100%}}.btn-voice{background-color:var(--primary-color);color:var(--text-on-primary);padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.btn-voice:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.btn-voice:disabled{opacity:.6;cursor:not-allowed}.btn-voice-stop{background-color:var(--error-color);color:var(--text-on-primary);padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.btn-voice-stop:hover{background-color:#d33b2c;box-shadow:var(--shadow-md)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);justify-content:flex-end;padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.form-actions.full-width{grid-column:1/-1}@media (max-width: 768px){.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.error-message.full-width{grid-column:1/-1}.field-error{color:var(--error-color);font-size:13px;margin-top:var(--spacing-xs);display:block;line-height:1.4}.is-invalid{border-color:var(--error-color)!important}.is-invalid:focus{border-color:var(--error-color)!important;box-shadow:0 0 0 3px #ea43351a!important}.date-input-wrapper{position:relative;display:flex;align-items:center}.date-input-wrapper input[type=date]{flex:1;padding-right:40px}.date-picker-button{position:absolute;right:8px;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color var(--transition-base);pointer-events:auto}.date-picker-button:hover{color:var(--primary-color)}.date-picker-button:focus{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}.date-picker-button svg{width:20px;height:20px}.time-input-group{display:flex;align-items:flex-end;gap:var(--spacing-md);flex-wrap:wrap}@media (max-width: 768px){.time-input-group{flex-direction:column;align-items:stretch}}.time-input-item{flex:1;min-width:160px;display:flex;flex-direction:column;gap:var(--spacing-xs)}@media (max-width: 768px){.time-input-item{min-width:100%}}.time-label{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:0}.time-select-group{display:flex;align-items:center;gap:var(--spacing-xs);background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-xs);transition:border-color var(--transition-base);width:100%}.time-select-group:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a}.time-select{flex:1;padding:var(--spacing-sm) var(--spacing-xs);border:none;background:transparent;font-size:15px;font-weight:500;color:var(--text-primary);cursor:pointer;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;padding-right:24px}.time-select:focus{outline:none}.time-colon{color:var(--text-secondary);font-size:16px;font-weight:600;flex-shrink:0;padding:0 var(--spacing-xs)}.time-separator{color:var(--text-secondary);font-size:18px;font-weight:500;flex-shrink:0;margin-bottom:var(--spacing-xs);align-self:flex-end;padding-bottom:calc(var(--spacing-sm) + 2px)}@media (max-width: 768px){.time-separator{align-self:center;margin:var(--spacing-xs) 0;padding-bottom:0}}.time-help-text{display:block;margin-top:var(--spacing-xs);color:var(--text-secondary);font-size:13px;line-height:1.4}.guide-nomination-group{grid-column:1/-1}.guide-nomination-desc{font-size:13px;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.btn-open-guide-search{padding:.5rem 1rem;font-size:14px;font-weight:500;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:var(--radius-md);cursor:pointer}.btn-open-guide-search:hover{background:var(--primary-hover)}.nominated-guide-selected-block .guide-nomination-desc{margin-bottom:var(--spacing-sm)}.nominated-guide-selected{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--surface-hover, #f8fafc);border-radius:var(--radius-md);border:1px solid var(--border-color)}.nominated-guide-name{font-weight:600;color:var(--text-primary)}.btn-change-guide{padding:.35rem .75rem;font-size:14px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--primary-color);margin-left:auto}.btn-change-guide:hover{background:var(--surface-hover);border-color:var(--primary-color)}.guide-search-box{border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);background:var(--surface-color)}.guide-search-filters{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md);align-items:end;margin-bottom:var(--spacing-lg)}@media (max-width: 768px){.guide-search-filters{grid-template-columns:1fr 1fr}}.guide-filter-item label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:2px}.guide-filter-item select,.guide-filter-item input{width:100%;padding:.5rem .6rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px}.guide-filter-keyword{grid-column:span 2}@media (max-width: 768px){.guide-filter-keyword{grid-column:1/-1}}.guide-filter-actions{display:flex;align-items:flex-end}.btn-search-guide{padding:.5rem 1rem;font-size:14px;font-weight:600;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:var(--radius-md);cursor:pointer}.btn-search-guide:hover:not(:disabled){background:var(--primary-hover)}.btn-search-guide:disabled{opacity:.7;cursor:not-allowed}.guide-search-results-heading{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md)}.guide-search-modal-content{max-height:85vh;display:flex;flex-direction:column}.guide-search-modal-content .modal-header{flex-shrink:0}.guide-search-modal-content .guide-search-box{flex:1;min-height:0;overflow:auto}.modal-close-btn{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-secondary);padding:.25rem}.modal-close-btn:hover{color:var(--text-primary)}.guide-search-results{margin-top:var(--spacing-md)}.guide-result-card{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);background:var(--surface-color);flex-wrap:wrap}.guide-result-actions{display:flex;gap:var(--spacing-sm);flex-shrink:0;align-items:center}.btn-guide-detail{padding:.35rem .7rem;font-size:13px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary)}.btn-guide-detail:hover{background:var(--surface-hover);border-color:var(--primary-color);color:var(--primary-color)}.guide-result-main{flex:1;min-width:0}.guide-result-name{font-weight:600;color:var(--text-primary);display:block;margin-bottom:2px}.guide-result-meta{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.guide-result-meta span+span:before{content:"・";margin:0 2px}.guide-result-intro{font-size:13px;color:var(--text-tertiary);line-height:1.4;margin:0}.btn-select-guide{flex-shrink:0;padding:.4rem .9rem;font-size:14px;font-weight:600;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:var(--radius-md);cursor:pointer}.btn-select-guide:hover{background:var(--primary-hover)}.btn-load-more-guides{display:block;width:100%;margin-top:var(--spacing-md);padding:var(--spacing-sm);font-size:14px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary)}.btn-load-more-guides:hover{background:var(--surface-hover);border-color:var(--primary-color);color:var(--primary-color)}.guide-search-empty{margin-top:var(--spacing-md);padding:var(--spacing-md);color:var(--text-secondary);font-size:14px;text-align:center}.guide-detail-modal-body{padding:0}.guide-detail-dl{margin:0 0 var(--spacing-lg);font-size:14px}.guide-detail-dl dt{font-weight:600;color:var(--text-secondary);margin-top:var(--spacing-md);margin-bottom:2px}.guide-detail-dl dt:first-child{margin-top:0}.guide-detail-dl dd{margin:0;color:var(--text-primary)}.guide-detail-intro{white-space:pre-wrap;line-height:1.5}.guide-detail-actions{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.matching-detail-container{max-width:900px;margin:0 auto}.matching-detail-container h1{font-size:28px;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-xl);letter-spacing:0}@media (max-width: 768px){.matching-detail-container{padding:0 var(--spacing-md)}.matching-detail-container h1{font-size:24px}}@media (max-width: 480px){.matching-detail-container{padding:0 var(--spacing-sm)}.matching-detail-container h1{font-size:20px}}.matching-card{background-color:var(--surface-color);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}@media (max-width: 768px){.matching-card{padding:var(--spacing-lg)}}@media (max-width: 480px){.matching-card{padding:var(--spacing-md)}}.matching-info,.matching-participants{margin-bottom:var(--spacing-xl)}.matching-info h2,.matching-info h3,.matching-participants h2,.matching-participants h3{font-size:18px;font-weight:500;margin-bottom:var(--spacing-md);color:var(--text-primary);letter-spacing:0}@media (max-width: 480px){.matching-info h2,.matching-info h3,.matching-participants h2,.matching-participants h3{font-size:16px}}.matching-info p,.matching-participants p{font-size:14px;margin:var(--spacing-sm) 0;color:var(--text-secondary);line-height:1.6}@media (max-width: 480px){.matching-info p,.matching-participants p{font-size:13px}}.matching-info strong{color:var(--text-primary);font-weight:500;margin-right:var(--spacing-xs)}.matching-actions{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;gap:var(--spacing-md)}.matching-actions .btn-primary,.matching-actions .btn-secondary{min-width:160px;padding:var(--spacing-md) var(--spacing-lg)}@media (max-width: 768px){.matching-actions{flex-direction:column}.matching-actions .btn-primary,.matching-actions .btn-secondary{width:100%;min-width:auto}}.report-form-container{max-width:900px;margin:0 auto}.report-form-container h1{font-size:32px;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-xl);letter-spacing:0}.report-form{background-color:var(--surface-color);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{margin-bottom:var(--spacing-xs);font-size:14px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:4px}.required{color:var(--error-color);margin-left:2px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color);justify-content:flex-end}.form-actions .btn-primary,.form-actions .btn-secondary{min-width:120px}.error-message{background-color:#fce8e6;color:var(--error-color);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border-left:4px solid var(--error-color);font-size:14px}.revision-request-alert{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-sm)}.revision-request-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.revision-request-header svg{color:#f59e0b;flex-shrink:0}.revision-request-header h3{font-size:16px;font-weight:600;color:#92400e;margin:0}.revision-request-content{background-color:#fff;border-radius:var(--radius-sm);padding:var(--spacing-md);border:1px solid #fbbf24}.revision-request-label{font-size:13px;font-weight:500;color:#92400e;margin:0 0 var(--spacing-xs) 0}.revision-request-notes{font-size:14px;color:var(--text-primary);line-height:1.6;white-space:pre-wrap;margin:0;padding:var(--spacing-sm);background-color:#fffbeb;border-radius:var(--radius-sm)}@media (max-width: 768px){.report-form-container{padding:0 var(--spacing-md)}.report-form-container h1{font-size:24px}.report-form{padding:var(--spacing-lg)}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}.revision-request-header{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.report-form-container{padding:0 var(--spacing-sm)}.report-form-container h1{font-size:20px}.report-form{padding:var(--spacing-md)}.form-group label{font-size:13px}.revision-request-alert{padding:var(--spacing-md)}}.report-detail-container{max-width:1000px;margin:0 auto;padding:0 var(--spacing-md)}.report-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-light);flex-wrap:wrap;gap:var(--spacing-md)}.report-detail-header h1{font-size:32px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.5px;line-height:1.2}.back-link{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all var(--transition-fast);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md)}.back-link:hover{color:var(--primary-color);background-color:var(--surface-hover);text-decoration:none}.report-card{background-color:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:0 2px 8px #00000014;border:1px solid var(--border-color);transition:all var(--transition-base);position:relative;overflow:hidden}.report-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color) 0%,#1557b0 100%);opacity:0;transition:opacity var(--transition-base)}.report-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.report-card:hover:before{opacity:1}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-light);flex-wrap:wrap;gap:var(--spacing-md)}.report-header-left{flex:1}.report-guide-info{display:flex;align-items:center;gap:var(--spacing-md)}.guide-icon{color:var(--primary-color);flex-shrink:0}.report-label{display:block;font-size:12px;color:var(--text-secondary);font-weight:500;margin-bottom:var(--spacing-xs);text-transform:uppercase;letter-spacing:.5px}.report-header h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.status-badge{display:inline-flex;align-items:center;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:14px;font-weight:600;white-space:nowrap}@media (max-width: 480px){.status-badge{font-size:12px;padding:.375rem .75rem}}.status-badge.status-pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:2px solid #f59e0b}.status-badge.status-approved{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border:2px solid #10b981}.status-badge.status-revision{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border:2px solid #ef4444}.report-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.report-section{background-color:var(--surface-color);border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--border-light);transition:all var(--transition-fast)}.report-section:hover{border-color:var(--border-color);box-shadow:0 2px 8px #0000000a}.report-section-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-light)}.section-icon{color:var(--primary-color);flex-shrink:0}.report-section-header h3{font-size:18px;font-weight:600;margin:0;color:var(--text-primary);line-height:1.3}.report-section-content{padding-top:var(--spacing-sm)}.report-section-content p{color:var(--text-primary);font-size:15px;line-height:1.8;white-space:pre-wrap;margin:0;word-break:break-word}.date-time-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-value{font-size:18px;font-weight:600;color:var(--text-primary)}.time-range{font-size:15px;color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--surface-hover);border-radius:var(--radius-sm);display:inline-block;width:fit-content}.report-actions{margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:2px solid var(--border-light);display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.action-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);border-radius:var(--radius-md);background-color:var(--surface-color);border:1px solid var(--border-light)}.action-section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.action-section-title svg{color:var(--primary-color)}.action-section-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.6}.revision-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);border-radius:var(--radius-md);background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.revision-input-wrapper{width:100%}.revision-input{width:100%;padding:var(--spacing-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:inherit;color:var(--text-primary);background-color:#fff;resize:vertical;min-height:120px;transition:all var(--transition-fast);box-sizing:border-box}.revision-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a}.revision-input::placeholder{color:var(--text-tertiary)}.btn-approve,.btn-revision{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-size:16px;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-base);box-shadow:0 2px 8px #0000001a}.btn-approve{background:linear-gradient(135deg,#10b981,#34d399);color:#fff;border:none}.btn-approve:hover:not(:disabled){background:linear-gradient(135deg,#059669,#10b981);transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-approve:disabled{opacity:.6;cursor:not-allowed}.btn-revision{background-color:#fff;color:#92400e;border:2px solid #f59e0b}.btn-revision:hover:not(:disabled){background-color:#fef3c7;border-color:#d97706;transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b33}.btn-revision:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.report-detail-container{padding:0 var(--spacing-md)}.report-detail-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.report-detail-header h1{font-size:24px}.back-link{width:100%;justify-content:center}.report-card{padding:var(--spacing-lg)}.report-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.report-guide-info{width:100%}.report-header h2{font-size:20px}.report-actions{grid-template-columns:1fr;gap:var(--spacing-lg)}.action-section,.revision-section{padding:var(--spacing-md)}.action-section-title{font-size:16px}.btn-approve,.btn-revision{width:100%;min-height:44px}}@media (max-width: 480px){.report-detail-container{padding:0 var(--spacing-sm)}.report-detail-header h1{font-size:20px}.report-card,.report-section{padding:var(--spacing-md)}.report-section-header h3{font-size:16px}.report-section-content p{font-size:14px}.date-value{font-size:16px}.time-range{font-size:13px}.action-section-title{font-size:15px}.action-section-description{font-size:13px}.btn-approve,.btn-revision{font-size:14px;padding:var(--spacing-sm) var(--spacing-md)}}.announcements-page{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}@media (max-width: 768px){.announcements-page{padding:var(--spacing-md)}}.announcements-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl)}.announcements-header h1{font-size:32px;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-xs)}@media (max-width: 768px){.announcements-header{flex-direction:column;gap:var(--spacing-md)}.announcements-header h1{font-size:24px}}.announcements-subtitle{font-size:16px;color:var(--text-secondary)}.unread-count-badge{padding:.5rem 1rem;background-color:var(--error-color);color:var(--text-on-primary);border-radius:var(--radius-full);font-size:14px;font-weight:500}.announcements-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-light)}@media (max-width: 768px){.announcements-filters{flex-wrap:wrap}}.filter-btn{padding:.5rem 1rem;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-xs)}.filter-btn:hover{background-color:var(--surface-hover);border-color:var(--primary-color)}.filter-btn.active{background-color:var(--primary-color);color:var(--text-on-primary);border-color:var(--primary-color)}.filter-btn:focus{outline:none}.filter-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.filter-count{padding:.125rem .5rem;background-color:#ffffff4d;border-radius:var(--radius-full);font-size:12px}.announcements-list{display:flex;flex-direction:column}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.empty-state svg{margin-bottom:var(--spacing-lg);color:var(--text-tertiary)}.empty-state h3{font-size:20px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.empty-state p{font-size:14px;color:var(--text-secondary)}.announcement-card{background-color:var(--surface-color);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.announcement-card.unread{border-left:4px solid var(--primary-color);background-color:var(--primary-light)}.announcement-card.read{opacity:.8}.announcement-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.announcement-card:focus{outline:none}.announcement-card:focus-visible{box-shadow:var(--shadow-md),0 0 0 2px var(--primary-color);outline:2px solid var(--primary-color);outline-offset:2px}@media (max-width: 768px){.announcement-card{padding:var(--spacing-md)}}.announcement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}@media (max-width: 768px){.announcement-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}.announcement-meta{display:flex;gap:var(--spacing-md);align-items:center}.announcement-footer{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);padding-top:var(--spacing-sm);border-top:1px solid var(--border-light)}.announcement-date{font-size:14px;color:var(--text-secondary)}.btn-unread{padding:.35rem .75rem;font-size:13px;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.btn-unread:hover{border-color:var(--primary-color);color:var(--primary-color)}.btn-unread:focus{outline:none}.btn-unread:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.announcement-target{font-size:12px;padding:.25rem .5rem;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary)}.unread-badge{font-size:12px;padding:.25rem .75rem;background-color:var(--error-color);color:var(--text-on-primary);border-radius:var(--radius-full);font-weight:500}.announcement-content{margin-bottom:var(--spacing-md)}.announcement-title{font-size:18px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-sm)}@media (max-width: 768px){.announcement-title{font-size:16px}}.announcement-body{font-size:14px;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}.announcement-actions{display:flex;justify-content:flex-end;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.btn-read{padding:.5rem 1.5rem;font-size:14px}.announcement-management{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.management-header h1{font-size:32px;font-weight:400;color:var(--text-primary)}.announcement-form-container{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-2xl);box-shadow:var(--shadow-sm)}.announcement-form-container h2{font-size:24px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.announcement-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-family:inherit;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 1px #1a73e81a}.form-group textarea{resize:vertical;min-height:150px}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.announcements-table-container{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.announcements-table{width:100%;border-collapse:collapse}.announcements-table thead{background-color:#f8fafc}.announcements-table thead tr th{background-color:#f8fafc;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px solid var(--border-color)}.announcements-table tbody tr{min-height:64px;transition:background-color var(--transition-fast)}.announcements-table tbody tr:hover{background-color:#3b82f608}.announcements-table tbody tr td{padding:16px var(--spacing-lg);vertical-align:middle;border-bottom:1px solid var(--border-light)}.announcements-table tbody tr:last-child td{border-bottom:none;text-align:center}.title-cell{max-width:400px}.target-cell{text-align:center}.title-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.announcement-title-bold{color:#0f172a;font-weight:700;font-size:15px}.content-preview{font-size:12px;color:var(--text-tertiary)}.datetime-cell-vertical{display:flex;flex-direction:column;gap:2px}.datetime-date{color:#0f172a;font-size:14px;font-weight:500}.datetime-time{color:#64748b;font-size:12px}.target-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:12px;font-weight:500}.target-badge.all{background-color:var(--primary-light);color:var(--primary-color)}.target-badge.user{background-color:#e0f2fe;color:#0369a1}.target-badge.guide{background-color:#fef3c7;color:#92400e}.action-buttons{display:flex;gap:8px;align-items:center}.btn-edit-announcement{background-color:#f1f5f9;color:#475569;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center}.btn-edit-announcement:hover:not(:disabled){background-color:#e2e8f0}.btn-edit-announcement:active:not(:disabled){transform:translateY(1px)}.btn-edit-announcement:disabled{opacity:.6;cursor:not-allowed}.btn-edit-announcement:focus-visible{outline:2px solid #475569;outline-offset:2px}.btn-delete-announcement{background-color:#fff;color:#ef4444;border:1px solid #fecaca;height:32px;padding:0 12px;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center}.btn-delete-announcement:hover:not(:disabled){background-color:#fef2f2;border-color:#fca5a5}.btn-delete-announcement:active:not(:disabled){background-color:#fee2e2;transform:translateY(1px)}.btn-delete-announcement:disabled{opacity:.6;cursor:not-allowed}.btn-delete-announcement:focus-visible{outline:2px solid #ef4444;outline-offset:2px}.announcement-creator-name{color:#0f172a;font-weight:600;font-size:14px}.btn-form-action{font-weight:700;font-size:14px;height:36px;padding:0 16px;border-radius:6px}.btn-new-announcement{font-weight:700;font-size:14px;padding:0 16px;height:36px;border-radius:6px}.btn-read-status{padding:.35rem .75rem;font-size:13px;background-color:#f1f5f9;color:#475569;border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.btn-read-status:hover{background-color:#e2e8f0;border-color:var(--primary-color);color:var(--primary-color)}.read-status-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;min-width:100vw;min-height:100vh;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2147483647;padding:var(--spacing-md);box-sizing:border-box}.read-status-modal-content{background:var(--surface-color);border-radius:var(--radius-lg);max-width:480px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.read-status-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.read-status-modal-header h2{margin:0;font-size:18px}.read-status-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);line-height:1;padding:0 4px}.read-status-modal-close:hover{color:var(--text-primary)}.read-status-modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.read-status-modal-body .read-status-title{font-weight:600;margin-bottom:var(--spacing-sm)}.read-status-summaries{margin-bottom:var(--spacing-md)}.read-status-modal-body .read-status-summary{margin:0 0 var(--spacing-xs) 0;font-size:14px;color:var(--text-secondary)}.read-status-modal-body .read-status-summary:last-child{margin-bottom:0}.read-status-modal-body .read-status-unread{margin-top:0}.read-status-modal-body .read-status-section{margin-top:var(--spacing-lg)}.read-status-modal-body .read-status-section-title{font-size:13px;font-weight:600;margin-bottom:var(--spacing-xs)}.read-status-list-scroll{max-height:200px;overflow-y:auto;border:1px solid var(--border-light);border-radius:var(--radius-md)}.read-status-modal-body .read-status-list{list-style:none;margin:0;padding:var(--spacing-sm)}.read-status-modal-body .read-status-list li{display:flex;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--border-light);font-size:14px}.read-status-modal-body .read-status-list li:last-child{border-bottom:none}.read-status-modal-body .read-at{font-size:12px;color:var(--text-tertiary)}.read-status-modal-body .read-status-non-readers li{justify-content:flex-start}.read-status-modal-body .read-status-empty{color:var(--text-secondary);font-size:14px;margin:0}.announcement-management .modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.announcement-management .read-status-modal{background:var(--surface-color);border-radius:var(--radius-lg);max-width:480px;width:90%;max-height:80vh;overflow:auto;box-shadow:var(--shadow-lg)}.announcement-management .read-status-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.announcement-management .read-status-modal .modal-header h2{margin:0;font-size:18px}.announcement-management .read-status-modal .modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);line-height:1;padding:0 4px}.announcement-management .read-status-modal .modal-body{padding:var(--spacing-lg)}.announcement-management .read-status-modal .read-status-title{font-weight:600;margin-bottom:var(--spacing-sm)}.announcement-management .read-status-modal .read-status-summary{margin-bottom:var(--spacing-md);font-size:14px;color:var(--text-secondary)}.announcement-management .read-status-modal .read-status-list{list-style:none;margin:0;padding:0}.announcement-management .read-status-modal .read-status-list li{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light);font-size:14px}.announcement-management .read-status-modal .read-at{font-size:12px;color:var(--text-tertiary)}.announcement-management .read-status-modal .read-status-empty{color:var(--text-secondary);font-size:14px;margin:0}.empty-message{text-align:center;color:var(--text-tertiary);padding:var(--spacing-2xl)!important}@media (max-width: 768px){.announcement-management{padding:var(--spacing-md)}.management-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.announcements-table-container{overflow-x:auto}.announcements-table{min-width:800px}}.toast{position:relative;background-color:var(--surface-color);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);min-width:300px;max-width:400px;animation:slideInRight .3s ease-out;transition:all var(--transition-base)}.toast.toast-success{border-left:4px solid var(--success-color)}.toast.toast-success .toast-icon{color:var(--success-color)}.toast.toast-error{border-left:4px solid var(--error-color)}.toast.toast-error .toast-icon{color:var(--error-color)}@media (max-width: 768px){.toast{min-width:auto;max-width:none;width:100%}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.toast-icon{flex-shrink:0;stroke:currentColor}.toast-message{font-size:14px;color:var(--text-primary);line-height:1.5}.toast-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0;width:24px;height:24px}.toast-close:hover{background-color:var(--surface-hover);color:var(--text-primary)}.toast-close svg{width:16px;height:16px}.toast-container{position:fixed;top:80px;right:var(--spacing-lg);z-index:10000;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none;max-width:400px}.toast-container>*{pointer-events:auto}@media (max-width: 768px){.toast-container{top:70px;right:var(--spacing-md);left:var(--spacing-md);max-width:none}}
