@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&display=swap";.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2)}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0}.login-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:blob-animation 20s infinite}.blob-1{width:500px;height:500px;background:linear-gradient(135deg,#667eea,#764ba2);top:-200px;left:-200px;animation-delay:0s}.blob-2{width:400px;height:400px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:-150px;right:-150px;animation-delay:7s}.blob-3{width:350px;height:350px;background:linear-gradient(135deg,#4facfe,#00f2fe);top:50%;right:-100px;animation-delay:14s}@keyframes blob-animation{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.login-box{position:relative;z-index:1;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;box-shadow:0 8px 32px #0000001a,0 2px 8px #0000000d,inset 0 1px #fff9;border:1px solid rgba(255,255,255,.3);padding:48px 40px;width:100%;max-width:440px;animation:slide-up .5s ease-out}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (prefers-color-scheme: dark){.login-container{background:linear-gradient(135deg,#1a1a2e,#16213e)}.login-box{background:#1e1e2ef2;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d,0 2px 8px #0003,inset 0 1px #ffffff1a}}.login-header{text-align:center;margin-bottom:40px}.login-logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:20px;animation:logo-float 3s ease-in-out infinite}@keyframes logo-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{font-size:36px;font-weight:900;color:#1e293b;margin:0 0 8px;letter-spacing:-1px}.login-header h1 span{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 10px rgba(99,102,241,.4))}@media (prefers-color-scheme: dark){.login-header h1{color:#fff}}.login-header p{font-size:15px;color:#6b7280;margin:0;font-weight:400}@media (prefers-color-scheme: dark){.login-header p{color:#9ca3af}}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px;transition:all .3s ease}.form-group label{font-size:14px;font-weight:600;color:#374151;margin-bottom:4px;transition:color .2s}@media (prefers-color-scheme: dark){.form-group label{color:#d1d5db}}.form-group.focused label{color:#667eea}.input-icon{position:absolute;left:16px;color:#9ca3af;pointer-events:none;transition:color .2s;z-index:1}.form-group.focused .input-icon{color:#667eea}.form-group input{width:100%;padding:14px 16px 14px 48px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;background:#fff;color:#111827;transition:all .2s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.form-group input::placeholder{color:#9ca3af}@media (prefers-color-scheme: dark){.form-group input{background:#ffffff0d;border-color:#ffffff1a;color:#f9fafb}.form-group input:focus{background:#ffffff14;border-color:#667eea}.form-group input::placeholder{color:#6b7280}}.password-toggle{position:absolute;right:16px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s;z-index:1}.password-toggle:hover{color:#667eea}.password-toggle:focus{outline:none;color:#667eea}.error-message{display:flex;align-items:center;gap:10px;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:14px 16px;border-radius:12px;font-size:14px;animation:shake .4s ease}.error-message svg{flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@media (prefers-color-scheme: dark){.error-message{background:#dc26261a;border-color:#dc26264d;color:#fca5a5}}.btn-login{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px;box-shadow:0 4px 12px #667eea66;position:relative;overflow:hidden}.btn-login:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-login:hover:before{left:100%}.btn-login:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-login:disabled:before{display:none}.btn-login svg{flex-shrink:0}.spinner{animation:spin 1s linear infinite}@media (max-width: 480px){.login-box{padding:36px 28px;border-radius:20px}.login-header h1{font-size:28px}.login-header p{font-size:14px}.form-group input{padding:12px 14px 12px 44px;font-size:16px}.btn-login{padding:14px 20px;font-size:15px}}@media (prefers-reduced-motion: reduce){.login-blob,.login-logo,.btn-login:before,.spinner{animation:none}.login-box{animation:none}}.btn-login:focus-visible,.password-toggle:focus-visible,.form-group input:focus-visible{outline:2px solid #667eea;outline-offset:2px}.filter-header{position:relative;white-space:nowrap}.filter-header .header-content{display:flex;align-items:center;gap:4px;justify-content:center}.filter-header .filter-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:22px;line-height:1;padding:4px 6px;min-width:32px;min-height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;transition:all .2s}.filter-header .filter-btn:hover{background:var(--border);color:#64748b}.filter-header .filter-btn.active{background:var(--primary-dark);color:#fff}.filter-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:180px;max-width:280px}.filter-dropdown.multi-select{padding:0}.filter-search-row{padding:8px 12px;border-bottom:1px solid var(--border);background:#f8fafc}.filter-search-input{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:4px;font-size:13px;color:var(--text-primary);background:var(--bg-card);outline:none;transition:border-color .2s}.filter-search-input:focus{border-color:var(--primary-dark);box-shadow:0 0 0 3px #3b82f61a}.filter-search-input::placeholder{color:var(--text-muted)}.filter-header-row{display:flex;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);background:#f8fafc;border-radius:8px 8px 0 0}.filter-header-row button{flex:1;padding:6px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-card);cursor:pointer;font-size:12px;color:#64748b;transition:all .2s}.filter-header-row button:hover{background:var(--bg-hover);border-color:var(--border)}.filter-options-list{max-height:200px;overflow-y:auto;padding:4px 0}.filter-options-list::-webkit-scrollbar{width:6px}.filter-options-list::-webkit-scrollbar-track{background:var(--bg-hover)}.filter-options-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.filter-option{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .15s}.filter-option:hover{background:var(--bg-hover)}.filter-option.selected{background:var(--success-bg)}.filter-option.select-all-option{font-weight:500;border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:8px}.filter-option.select-all-option.selected{background:var(--success-bg)}.filter-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-dark);cursor:pointer;flex-shrink:0}.filter-option span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-no-results{padding:12px;text-align:center;color:var(--text-muted);font-size:13px}.filter-footer-row{display:flex;gap:8px;padding:8px 12px;border-top:1px solid var(--border);background:#f8fafc;border-radius:0 0 8px 8px}.filter-footer-row button{flex:1;padding:8px 12px;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.filter-cancel-btn{background:var(--bg-hover);color:#64748b}.filter-cancel-btn:hover{background:var(--border)}.filter-apply-btn{background:var(--primary-dark);color:#fff}.filter-apply-btn:hover{background:var(--primary)}.editable-cell{cursor:pointer;transition:background .15s;position:relative}.editable-cell:hover:not(.disabled):not(.editing){background:var(--bg-main)}.editable-cell.disabled{cursor:default}.editable-cell.editing{padding:0}.editable-cell.editing input{width:100%;height:100%;padding:8px 10px;border:2px solid var(--border-focus);border-radius:4px;font-size:inherit;font-family:inherit;background:#fff;box-sizing:border-box}.editable-cell.editing input:focus{outline:none}.editable-cell.name-cell{font-weight:500;color:var(--text-primary)}.editable-cell.mono{font-family:Consolas,Monaco,monospace;font-size:12px;letter-spacing:.5px}.editable-cell.address-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-menu-wrapper{position:relative;display:inline-block}.action-menu-wrapper .btn-menu{width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);cursor:pointer;font-size:16px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s}.action-menu-wrapper .btn-menu:hover{background:var(--bg-main);border-color:var(--border);color:var(--text-primary)}.action-menu-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;min-width:100px;overflow:hidden}.action-menu-dropdown button{width:100%;padding:10px 16px;border:none;background:none;text-align:left;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .15s}.action-menu-dropdown button:hover{background:var(--bg-main)}.action-menu-dropdown button.delete,.action-menu-dropdown button.danger{color:#ef4444}.action-menu-dropdown button.delete:hover,.action-menu-dropdown button.danger:hover{background:var(--error-bg)}.toggle-cell{cursor:pointer;text-align:center}.toggle-cell:hover{background:var(--bg-main)}.toggle-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;transition:all .2s}.toggle-badge.yes{background:#e8f5f0;color:#3a7d5e;border:1px solid #c5dfd0}.toggle-badge.no{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.toggle-cell:hover .toggle-badge.yes{background:#d5ebde}.toggle-cell:hover .toggle-badge.no{background:#e2e8f0}.slide-notification-container{position:fixed;bottom:24px;right:24px;z-index:10000;pointer-events:none}.slide-notification{display:flex;align-items:flex-start;gap:14px;min-width:340px;max-width:420px;padding:18px 20px;background:var(--bg-card);border-radius:16px;box-shadow:var(--shadow);animation:slideInUp .4s cubic-bezier(.16,1,.3,1);pointer-events:auto;border:1px solid var(--border);position:absolute;right:0;overflow:hidden}.slide-notification:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#3b82f6,#2563eb)}.slide-notification-success:before{background:linear-gradient(180deg,#10b981,#059669)}.slide-notification-error:before{background:linear-gradient(180deg,#ef4444,#dc2626)}.slide-notification-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;flex-shrink:0;box-shadow:0 2px 8px #0000001a}.slide-notification-success .slide-notification-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.slide-notification-error .slide-notification-icon{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.slide-notification-content{flex:1;min-width:0;padding-top:2px}.slide-notification-message{font-size:15px;font-weight:600;color:var(--text-primary);line-height:1.5;word-wrap:break-word;letter-spacing:-.01em}.slide-notification-message strong{color:var(--text-primary);font-weight:700}@keyframes slideInUp{0%{transform:translateY(20px) translate(100%);opacity:0}to{transform:translateY(0) translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(120%);opacity:0}}.slide-notification.removing{animation:slideOutRight .35s cubic-bezier(.4,0,1,1) forwards}.address-input-wrapper{width:100%}.address-input-row{display:flex;gap:8px;margin-bottom:8px}.address-base-input{flex:1;padding:10px;border:1px solid var(--border);border-radius:6px;font-size:.95rem;background:var(--bg-main, #f8fafc);color:var(--text-secondary);cursor:not-allowed}.address-base-input:focus{outline:none;border-color:var(--primary, #3b82f6)}.btn-address-search{padding:10px 20px;background:var(--bg-hover, #f1f5f9);color:var(--text-primary, #1e293b);border:1px solid var(--border, #e2e8f0);border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-address-search:hover{background:var(--bg-card, #fff);border-color:var(--text-secondary, #64748b)}.btn-address-search:active{background:var(--bg-hover, #f1f5f9)}.address-detail-row{display:flex;flex-direction:column;gap:4px}.address-detail-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.address-detail-input{padding:10px;border:1px solid var(--border);border-radius:6px;font-size:.95rem;width:100%;background:var(--bg-main, #f8fafc);color:var(--text-primary)}.address-detail-input:focus{outline:none;border-color:var(--primary, #3b82f6)}.address-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.address-modal-content{background:var(--bg-card);border-radius:16px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:0 20px 40px #00000026}.address-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.address-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.btn-close-modal{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-close-modal:hover{background:var(--bg-hover);color:var(--text-primary)}#address-search-container{padding:20px;position:relative}#address-search-container iframe{border:none;width:100%!important;height:100%!important}.loading-overlay{display:flex;align-items:center;justify-content:center;background:#ffffffb8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:loadingOverlayFadeIn .35s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .loading-overlay{background:#1e1e23d1}.loading-overlay--full{min-height:min(400px,60vh);border-radius:12px}.loading-overlay--fullpage{min-height:100vh;border-radius:0}.loading-overlay--overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;border-radius:12px}@keyframes loadingOverlayFadeIn{0%{opacity:0}to{opacity:1}}.loading-overlay__content{display:flex;flex-direction:column;align-items:center;gap:16px;animation:loadingContentPop .4s cubic-bezier(.34,1.56,.64,1) .1s both}@keyframes loadingContentPop{0%{opacity:0;transform:scale(.9) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.loading-overlay__spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:#ef4444;border-radius:50%;animation:loadingSpinnerSpin .8s cubic-bezier(.5,0,.5,1) infinite}@keyframes loadingSpinnerSpin{to{transform:rotate(360deg)}}.loading-overlay__text{font-size:14px;font-weight:500;color:var(--text-secondary);letter-spacing:-.02em}@media (prefers-reduced-motion: reduce){.loading-overlay,.loading-overlay__content,.loading-overlay__spinner{animation:none}}.ccm{background:var(--bg-main);border:1px solid var(--border);border-radius:7px;box-shadow:0 6px 20px #0000002e;padding:4px 0;min-width:140px;-webkit-user-select:none;user-select:none}.ccm-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 14px;text-align:left;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-primary);white-space:nowrap;box-sizing:border-box;gap:6px}.ccm-item:hover,.ccm-item.ccm-has-sub:hover{background:var(--bg-hover)}.ccm-item.active{color:var(--primary, #3b82f6);font-weight:500}.ccm-item.danger{color:#ef4444}.ccm-item.danger:hover{background:#ef444414}.ccm-item.disabled{opacity:.4;cursor:default}.ccm-has-sub{position:relative}.ccm-submenu{position:absolute;top:-4px;left:calc(100% + 2px);background:var(--bg-main);border:1px solid var(--border);border-radius:7px;box-shadow:0 6px 20px #0000002e;padding:4px 0;min-width:130px;z-index:1}.ccm-submenu.fly-left{left:auto;right:calc(100% + 2px)}.ccm-divider{height:1px;background:var(--border);margin:4px 0}.field-required-error,.field-required-error:focus{border-color:#ef4444!important;box-shadow:0 0 0 3px #ef444433!important;animation:fieldShake .35s ease}@keyframes fieldShake{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@media (prefers-color-scheme: light){.modal-overlay{background:#0006}}.modal-content,.modal-box{position:relative;background:#fff;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;box-shadow:0 20px 60px #00000026,0 8px 24px #0000001a,inset 0 1px #fffc;border:1px solid rgba(229,231,235,.8);padding:40px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.modal-content.wide{max-width:900px}.modal-content.large{max-width:1200px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (prefers-color-scheme: dark){.modal-content,.modal-box{background:#1e1e2efa;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0006,0 8px 24px #0000004d,inset 0 1px #ffffff1a}}.modal-content h2{font-size:28px;font-weight:800;color:var(--text-primary);margin:0 0 32px;letter-spacing:-.5px}.modal-header-with-close{display:flex;justify-content:space-between;align-items:flex-start;position:relative;margin-bottom:32px}.modal-header-with-close h2{margin:0;flex:1}.modal-header-with-close .btn-close-header{position:absolute;top:0;right:0;width:40px;height:40px;border:none;background:#f3f4f6;color:#6b7280;font-size:20px;border-radius:12px;cursor:pointer;line-height:1;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-header-with-close .btn-close-header:hover{background:#e5e7eb;color:#111827}@media (prefers-color-scheme: dark){.modal-header-with-close .btn-close-header{background:#ffffff0d;color:#9ca3af}.modal-header-with-close .btn-close-header:hover{background:#ffffff1a;color:#f9fafb}}.form-sections{display:flex;flex-direction:column;gap:32px}.form-section{display:flex;flex-direction:column;gap:24px}.form-section h2{font-size:20px;font-weight:700;color:#1f2937;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid #d1d5db;letter-spacing:-.3px}@media (prefers-color-scheme: dark){.form-section h2{color:#d1d5db;border-bottom-color:#ffffff1a}}.form-grid-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.form-row{display:flex;flex-direction:column;gap:8px;transition:all .3s ease}.form-row label{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:4px;transition:color .2s}.form-row.focused label{color:#667eea}@media (prefers-color-scheme: dark){.form-row label{color:#d1d5db}.form-row.focused label{color:#667eea}}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;color:#6b7280;pointer-events:none;transition:color .2s;z-index:1}.form-row.focused .input-icon{color:#667eea}.form-row input[type=text],.form-row input[type=number],.form-row input[type=date],.form-row input[type=email],.form-row input[type=tel],.form-row textarea{width:100%;padding:14px 16px;border:2px solid #d1d5db;border-radius:12px;font-size:15px;background:#fff;color:#111827;transition:all .2s ease;font-family:inherit;box-sizing:border-box}.form-row input[type=text]:hover,.form-row input[type=number]:hover,.form-row input[type=date]:hover,.form-row input[type=email]:hover,.form-row input[type=tel]:hover,.form-row textarea:hover{border-color:#9ca3af}.form-row input[type=text]:focus,.form-row input[type=number]:focus,.form-row input[type=date]:focus,.form-row input[type=email]:focus,.form-row input[type=tel]:focus,.form-row textarea:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.form-row input[type=text]::placeholder,.form-row input[type=number]::placeholder,.form-row input[type=date]::placeholder,.form-row input[type=email]::placeholder,.form-row input[type=tel]::placeholder,.form-row textarea::placeholder{color:#6b7280;opacity:.8}.form-row input[type=text]:has(+.input-icon),.form-row input[type=number]:has(+.input-icon),.form-row input[type=email]:has(+.input-icon),.form-row input[type=tel]:has(+.input-icon){padding-left:48px}@media (prefers-color-scheme: dark){.form-row input[type=text],.form-row input[type=number],.form-row input[type=date],.form-row input[type=email],.form-row input[type=tel],.form-row textarea{background:#ffffff0d;border-color:#ffffff1a;color:#f9fafb}.form-row input[type=text]:focus,.form-row input[type=number]:focus,.form-row input[type=date]:focus,.form-row input[type=email]:focus,.form-row input[type=tel]:focus,.form-row textarea:focus{background:#ffffff14;border-color:#667eea}.form-row input[type=text]::placeholder,.form-row input[type=number]::placeholder,.form-row input[type=date]::placeholder,.form-row input[type=email]::placeholder,.form-row input[type=tel]::placeholder,.form-row textarea::placeholder{color:#6b7280}}.form-row select{width:100%;padding:14px 48px 14px 16px;border:2px solid #d1d5db;border-radius:12px;font-size:15px;background:#fff;color:#111827;transition:all .2s ease;font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-color:#fff}.form-row select:hover{border-color:#9ca3af;background-color:#fff}.form-row select:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 4px #667eea1a}@media (prefers-color-scheme: dark){.form-row select{background:#ffffff0d;border-color:#ffffff1a;color:#f9fafb;background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%9ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}.form-row select option{background:#1f2937;color:#f9fafb}.form-row select:focus{background-color:#ffffff14;border-color:#667eea}}[data-theme=dark] .form-row select{background:#ffffff0d;border-color:#ffffff1a;color:#f9fafb;background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%9ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}[data-theme=dark] .form-row select option{background:#1f2937;color:#f9fafb}[data-theme=dark] .form-row select:focus{background-color:#ffffff14;border-color:#667eea}[data-theme=dark] .form-row select:hover{border-color:#fff3;background-color:#ffffff0f}[data-theme=dark] .modal-content,[data-theme=dark] .modal-box{background:#282c32a6;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0006,0 8px 24px #0000004d,inset 0 1px #ffffff1a}[data-theme=dark] .form-section h2{color:#d1d5db;border-bottom-color:#ffffff1a}[data-theme=dark] .form-row label{color:#d1d5db}[data-theme=dark] .form-row.focused label{color:#667eea}[data-theme=dark] .form-row input[type=text],[data-theme=dark] .form-row input[type=number],[data-theme=dark] .form-row input[type=date],[data-theme=dark] .form-row input[type=email],[data-theme=dark] .form-row input[type=tel],[data-theme=dark] .form-row textarea{background:#ffffff0d;border-color:#ffffff1a;color:#f9fafb}[data-theme=dark] .form-row input[type=text]:focus,[data-theme=dark] .form-row input[type=number]:focus,[data-theme=dark] .form-row input[type=date]:focus,[data-theme=dark] .form-row input[type=email]:focus,[data-theme=dark] .form-row input[type=tel]:focus,[data-theme=dark] .form-row textarea:focus{background:#ffffff14;border-color:#667eea}[data-theme=dark] .form-row input[type=text]::placeholder,[data-theme=dark] .form-row input[type=number]::placeholder,[data-theme=dark] .form-row input[type=date]::placeholder,[data-theme=dark] .form-row input[type=email]::placeholder,[data-theme=dark] .form-row input[type=tel]::placeholder,[data-theme=dark] .form-row textarea::placeholder{color:#6b7280}[data-theme=dark] .form-actions{border-top-color:#ffffff1a}[data-theme=dark] .btn-secondary{background:#ffffff0d;color:#d1d5db;border-color:#ffffff1a}[data-theme=dark] .btn-secondary:hover{background:#ffffff1a;border-color:#fff3}[data-theme=dark] .autocomplete-dropdown{background:#1e1e2efa;border-color:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}[data-theme=dark] .autocomplete-option{border-bottom-color:#ffffff0d;color:#f9fafb}[data-theme=dark] .autocomplete-option:hover{background:#ffffff1a}[data-theme=dark] .autocomplete-option:active{background:#ffffff26}.form-row textarea{min-height:120px;resize:vertical;font-family:inherit}.form-row input[type=checkbox]{width:20px;height:20px;accent-color:#667eea;cursor:pointer}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:2px solid #e5e7eb}@media (prefers-color-scheme: dark){.form-actions{border-top-color:#ffffff1a}}.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:#334155;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea66;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-primary:hover:before{left:100%}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-primary:disabled:before{display:none}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:#fff;color:#374151;border:2px solid #d1d5db;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af;box-shadow:0 2px 4px #0000001a}.btn-secondary:active{background:#f3f4f6;box-shadow:0 1px 2px #0000000d}@media (prefers-color-scheme: dark){.btn-secondary{background:#ffffff0d;color:#d1d5db;border-color:#ffffff1a}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #d1d5db;border-radius:12px;box-shadow:0 8px 24px #00000026,0 4px 12px #0000001a;max-height:300px;overflow-y:auto;z-index:1000;margin-top:4px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.autocomplete-option{padding:12px 16px;cursor:pointer;transition:background .2s;border-bottom:1px solid #e5e7eb;color:#111827}.autocomplete-option:last-child{border-bottom:none}.autocomplete-option:hover{background:#f9fafb}.autocomplete-option:active{background:#f3f4f6}@media (prefers-color-scheme: dark){.autocomplete-dropdown{background:#1e1e2efa;border-color:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.autocomplete-option{border-bottom-color:#ffffff0d;color:#f9fafb}.autocomplete-option:hover{background:#ffffff1a}.autocomplete-option:active{background:#ffffff26}}@media (max-width: 768px){.modal-content{padding:28px 24px;border-radius:20px}.modal-content h2{font-size:24px}.form-grid-modern{grid-template-columns:1fr;gap:20px}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}@media (prefers-reduced-motion: reduce){.modal-overlay,.modal-content,.autocomplete-dropdown,.btn-primary:before{animation:none}}.btn-primary:focus-visible,.btn-secondary:focus-visible,.form-row input:focus-visible,.form-row select:focus-visible,.form-row textarea:focus-visible{outline:2px solid #667eea;outline-offset:2px}@media (prefers-color-scheme: light){.form-row input:focus-visible,.form-row select:focus-visible,.form-row textarea:focus-visible{outline:3px solid #667eea;outline-offset:2px}.btn-primary:focus-visible{outline:3px solid rgba(102,126,234,.5);outline-offset:2px}.btn-secondary:focus-visible{outline:3px solid #667eea;outline-offset:2px}}[data-theme=light] .modal-content,[data-theme=light] .modal-box{background:#fff!important;border:1px solid rgba(229,231,235,.8)!important;box-shadow:0 20px 60px #00000026,0 8px 24px #0000001a,inset 0 1px #fffc!important}[data-theme=light] .form-section h2{color:#1f2937!important;border-bottom-color:#d1d5db!important}[data-theme=light] .form-row label{color:#1f2937!important}[data-theme=light] .form-row.focused label{color:var(--text-primary)!important}[data-theme=light] .form-row input[type=text],[data-theme=light] .form-row input[type=number],[data-theme=light] .form-row input[type=date],[data-theme=light] .form-row input[type=email],[data-theme=light] .form-row input[type=tel],[data-theme=light] .form-row textarea{background:#fff!important;border-color:#d1d5db!important;color:#111827!important}[data-theme=light] .form-row input[type=text]:focus,[data-theme=light] .form-row input[type=number]:focus,[data-theme=light] .form-row input[type=date]:focus,[data-theme=light] .form-row input[type=email]:focus,[data-theme=light] .form-row input[type=tel]:focus,[data-theme=light] .form-row textarea:focus{background:#fff!important;border-color:#667eea!important}[data-theme=light] .form-row input[type=text]::placeholder,[data-theme=light] .form-row input[type=number]::placeholder,[data-theme=light] .form-row input[type=date]::placeholder,[data-theme=light] .form-row input[type=email]::placeholder,[data-theme=light] .form-row input[type=tel]::placeholder,[data-theme=light] .form-row textarea::placeholder{color:#6b7280!important;opacity:.8!important}[data-theme=light] .form-row select{background:#fff!important;border-color:#d1d5db!important;color:#111827!important;background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right 16px center!important;background-color:#fff!important}[data-theme=light] .form-row select option{background:#fff!important;color:#111827!important}[data-theme=light] .form-row select:focus{background-color:#fff!important;border-color:#667eea!important}[data-theme=light] .form-row select:hover{border-color:#9ca3af!important;background-color:#fff!important}[data-theme=light] .form-actions{border-top-color:#e5e7eb!important}[data-theme=light] .btn-secondary{background:#fff!important;color:#374151!important;border-color:#d1d5db!important}[data-theme=light] .btn-secondary:hover{background:#f9fafb!important;border-color:#9ca3af!important}[data-theme=light] .autocomplete-dropdown{background:#fff!important;border-color:#d1d5db!important}[data-theme=light] .autocomplete-option{border-bottom-color:#e5e7eb!important;color:#111827!important}[data-theme=light] .autocomplete-option:hover{background:#f9fafb!important}[data-theme=light] .autocomplete-option:active{background:#f3f4f6!important}.excel-token-modal .modal-desc{margin-bottom:20px;color:var(--text-secondary, #6b7280);font-size:14px;line-height:1.5}.excel-token-modal .generated-token-box{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-sub, #f9fafb);border:2px solid var(--border, #e5e7eb);border-radius:12px;margin-bottom:20px}.excel-token-modal .token-display{flex:1;font-family:JetBrains Mono,Consolas,monospace;font-size:20px;font-weight:700;letter-spacing:4px;color:var(--text-primary, #111827)}[data-theme=dark] .excel-token-modal .generated-token-box{background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .excel-token-modal .token-display{color:#f1f5f9}.excel-token-modal .modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.form-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:1000;animation:fadeIn .2s ease-out}.form-drawer{position:fixed;top:0;right:0;bottom:0;width:640px;background:var(--bg-card);border-left:1px solid var(--border);box-shadow:-12px 0 48px #0000001f;display:flex;flex-direction:column;z-index:1001;animation:drawerSlideIn .22s ease-out}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.form-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.form-drawer-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0}.form-drawer-close{width:30px;height:30px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:background .15s,color .15s;flex-shrink:0}.form-drawer-close:hover{background:var(--bg-hover);color:var(--text-primary)}.form-drawer-notice{display:flex;align-items:center;gap:8px;padding:10px 24px;background:#f59e0b14;border-bottom:1px solid rgba(245,158,11,.2);font-size:12px;color:#92400e;flex-shrink:0}[data-theme=dark] .form-drawer-notice{color:#fcd34d;background:#f59e0b1f}.form-drawer-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:22px}.form-drawer-section-title{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted, #94a3b8);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.form-drawer-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}.form-drawer-field{display:flex;flex-direction:column;gap:5px}.form-drawer-field.full{grid-column:span 2}.form-drawer-field label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-drawer-field input,.form-drawer-field select,.form-drawer-field textarea{padding:8px 11px;border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text-primary);background:var(--bg-main);transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box;font-family:inherit}.form-drawer-field input:focus,.form-drawer-field select:focus,.form-drawer-field textarea:focus{outline:none;border-color:var(--primary, #4e7a99);box-shadow:0 0 0 3px #6366f11f}.form-drawer-field textarea{resize:vertical;min-height:76px}.form-drawer-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:24px;border:2px dashed var(--border);border-radius:10px;cursor:pointer;background:var(--bg-main);transition:border-color .15s,background .15s;position:relative;text-align:center}.form-drawer-upload:hover{border-color:var(--primary);background:#6366f10a}.form-drawer-upload input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.form-drawer-upload-title{font-size:13px;font-weight:600;color:var(--text-primary)}.form-drawer-upload-sub{font-size:11px;color:var(--text-muted)}.form-drawer-upload-preview{display:flex;align-items:center;gap:16px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--bg-main)}.form-drawer-upload-preview img{width:80px;height:56px;object-fit:cover;border-radius:6px;border:1px solid var(--border);cursor:zoom-in}.form-drawer-upload-actions{display:flex;gap:8px;margin-top:4px}.form-drawer-upload-btn-change,.form-drawer-upload-btn-delete{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s;position:relative}.form-drawer-upload-btn-change{background:#475569;color:#fff;border:none}.form-drawer-upload-btn-delete{background:transparent;color:#dc2626;border:1px solid #dc2626}.form-drawer-upload-btn-change input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.form-drawer-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0}.form-drawer-btn-cancel{padding:9px 18px;border:1px solid var(--border);background:var(--bg-main);color:var(--text-primary);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.form-drawer-btn-cancel:hover{background:var(--bg-hover)}.form-drawer-btn-submit{padding:9px 22px;border:none;background:#334155;color:#fff;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s}.form-drawer-btn-submit:hover:not(:disabled){background:#1e293b}.form-drawer-btn-submit:disabled{opacity:.5;cursor:not-allowed}.photo-crop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.photo-crop-modal{background:#fff;border-radius:16px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.photo-crop-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:0;border-bottom:none}.photo-crop-header-content{display:flex;align-items:center;justify-content:space-between;padding:20px 24px}.photo-crop-title-section{flex:1}.photo-crop-title{margin:0 0 4px;font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.02em}.photo-crop-subtitle{margin:0;font-size:.875rem;color:#ffffffe6;font-weight:500}.btn-close-crop{background:#fff3;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.btn-close-crop:hover{background:#ffffff4d;transform:rotate(90deg)}.photo-crop-body{padding:24px;overflow:auto;background:#f8fafc}.photo-crop-error{margin:0 0 16px;padding:12px 16px;font-size:.875rem;color:#dc2626;background:#fef2f2;border-radius:10px;border:1px solid #fecaca;display:flex;align-items:center;gap:8px}.photo-crop-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:16px}.photo-crop-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.photo-crop-loading p{margin:0;color:#64748b;font-size:.9rem}.photo-crop-instruction{display:flex;align-items:center;gap:8px;margin:0 0 16px;padding:12px 16px;background:#fff;border-radius:10px;border:1px solid #e2e8f0;font-size:.875rem;color:#475569;font-weight:500}.photo-crop-instruction svg{color:#667eea;flex-shrink:0}.photo-crop-rotate-btns{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.btn-rotate{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;cursor:pointer;color:#475569;transition:all .15s}.btn-rotate:hover{background:#f1f5f9;border-color:#cbd5e1;color:#1e293b}.photo-crop-wrap{display:flex;justify-content:center;align-items:center;min-height:200px}.photo-crop-wrap .ReactCrop{max-width:100%}.photo-crop-wrap .ReactCrop__child-wrapper{max-height:60vh}.photo-crop-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 24px;border-top:1px solid #e2e8f0;background:#fff}.photo-crop-footer-actions{display:flex;gap:12px;margin-left:auto}.btn-cancel{padding:12px 24px;border:2px solid #e2e8f0;background:#fff;color:#64748b;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.btn-cancel:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569;transform:translateY(-1px)}.btn-revert-original{padding:12px 20px;border:2px solid #e2e8f0;background:#fff;color:#475569;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s}.btn-revert-original:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b;transform:translateY(-1px)}.btn-apply{padding:12px 24px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:8px;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.btn-apply:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-apply:active:not(:disabled){transform:translateY(0)}.btn-apply:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}*{box-sizing:border-box}:root{--ci-primary: #2c3e50;--ci-primary-light: #f0f2f4;--ci-bg: #f4f4f5;--ci-card: #ffffff;--ci-border: #e4e4e7;--ci-text: #18181b;--ci-text-sub: #71717a;--ci-text-muted: #a1a1aa;--ci-green: #2d6a4f;--ci-green-bg: #f0f4f2;--ci-green-border: #c3d9ce;--ci-orange: #92400e;--ci-orange-bg: #fdf4e7;--ci-red: #9f1239;--ci-red-bg: #fff1f3;--ci-radius: 12px}.ci-wrap{min-height:100vh;background:var(--ci-bg);display:flex;align-items:center;justify-content:center;font-family:Noto Sans KR,-apple-system,sans-serif;padding:24px 16px}.ci-wrap.app{align-items:flex-start;flex-direction:column;padding:0;background:var(--ci-bg)}.ci-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.ci-icon svg{width:20px;height:20px}.ci-icon.sm svg{width:16px;height:16px}.ci-icon.xs svg{width:13px;height:13px}.ci-icon.md svg{width:24px;height:24px}.ci-icon.lg svg{width:36px;height:36px}.ci-app-icon{width:64px;height:64px;background:var(--ci-primary);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 14px}.ci-app-icon svg{width:28px;height:28px}.ci-card{width:100%;max-width:400px;background:var(--ci-card);border-radius:16px;padding:36px 28px 30px;border:1px solid var(--ci-border)}.ci-logo{font-size:12px;font-weight:700;color:var(--ci-text-muted);margin-bottom:8px;text-align:center;letter-spacing:.1em;text-transform:uppercase}.ci-org-name{text-align:center;font-size:13px;color:var(--ci-text-sub);margin:0 0 16px;font-weight:500}.ci-device-notice{display:flex;align-items:flex-start;justify-content:center;gap:5px;text-align:center;font-size:11px;color:var(--ci-text-sub);margin:16px 0 0;line-height:1.5;opacity:.7}.ci-device-notice-icon{flex-shrink:0;width:13px;height:13px;margin-top:1px}.ci-device-notice-icon svg{width:13px;height:13px}.ci-title{font-size:20px;font-weight:700;color:var(--ci-text);margin:0 0 6px;text-align:center}.ci-desc{font-size:13px;color:var(--ci-text-muted);text-align:center;margin:0 0 22px;line-height:1.6}.ci-input{width:100%;padding:12px 14px;border:1.5px solid var(--ci-border);border-radius:8px;font-size:15px;color:var(--ci-text);background:#fafafa;margin-bottom:10px;outline:none;transition:border-color .15s;font-family:inherit}.ci-input:focus{border-color:#94a3b8;background:#fff}.ci-error{font-size:13px;color:var(--ci-red);margin:0 0 12px;text-align:center}.ci-error-box{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ci-red);background:var(--ci-red-bg);border:1px solid #fecdd3;border-radius:8px;padding:10px 14px;margin-bottom:12px}.ci-btn{width:100%;padding:13px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s,background .15s;margin-top:6px;font-family:inherit}.ci-btn.primary{background:var(--ci-primary);color:#fff}.ci-btn.primary:hover{opacity:.88}.ci-btn.primary:disabled{opacity:.4;cursor:not-allowed}.ci-btn.secondary{background:#f4f4f5;color:var(--ci-text-sub);border:1px solid var(--ci-border)}.ci-btn.secondary:hover{background:#ececed}.ci-btn.checkin{background:var(--ci-green);color:#fff;font-size:17px;padding:17px;border-radius:10px}.ci-btn.checkin:hover{opacity:.88}.ci-btn.checkin:disabled{opacity:.4;cursor:not-allowed}.ci-btn.checkout{background:#334155;color:#fff;font-size:17px;padding:17px;border-radius:10px}.ci-btn.checkout:hover{opacity:.88}.ci-btn.checkout:disabled{opacity:.4;cursor:not-allowed}.ci-btn.checkout-only{background:transparent;color:#64748b;border:1px solid #cbd5e1;font-size:14px;padding:12px}.ci-btn.checkout-only:hover{background:#f1f5f9}.ci-loading{font-size:14px;color:var(--ci-text-muted)}.ci-header{width:100%;background:#fff;padding:13px 18px;display:flex;align-items:center;gap:8px;justify-content:space-between;position:sticky;top:0;z-index:10;border-bottom:1px solid var(--ci-border)}.ci-header-left{display:flex;flex-direction:column;gap:2px;flex:1}.ci-header-btns{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.ci-header-name{font-size:14px;font-weight:700;color:var(--ci-text)}.ci-header-org{font-size:11px;color:var(--ci-text-muted)}.ci-logout-btn{background:none;border:1px solid var(--ci-border);border-radius:7px;padding:6px 10px;gap:6px;font-size:13px;color:var(--ci-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.ci-logout-btn:hover{background:#f4f4f5}.ci-edit-info-btn{background:none;border:1px solid var(--ci-border);border-radius:7px;padding:6px 10px;gap:6px;font-size:13px;color:var(--ci-text-muted);cursor:pointer;display:flex;align-items:center;transition:background .15s}.ci-edit-info-btn:hover{background:#f4f4f5}.ci-tabs{width:100%;display:flex;background:#fff;border-bottom:1px solid var(--ci-border)}.ci-tab{flex:1;padding:12px;border:none;background:none;font-size:14px;font-weight:500;color:var(--ci-text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;font-family:inherit}.ci-tab.active{color:var(--ci-text);border-bottom-color:var(--ci-primary);font-weight:700}.ci-body{width:100%;padding:18px 16px 32px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.ci-date{font-size:13px;color:var(--ci-text-muted);text-align:center;font-weight:500}.ci-night-mode-row{display:flex;justify-content:center;margin:6px 0 2px}.ci-night-toggle{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;border:1px solid var(--ci-border);background:transparent;color:var(--ci-text-muted);font-size:12px;cursor:pointer}.ci-night-toggle.active{border-color:#6366f1;background:#6366f115;color:#6366f1}.ci-today-card{background:var(--ci-card);border-radius:var(--ci-radius);padding:22px 18px;border:1px solid var(--ci-border);display:flex;flex-direction:column;align-items:center;gap:12px}.ci-today-card.night-shift{border-color:#6366f1;background:#6366f108}.ci-night-label{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#6366f1}.ci-btn.night{background:#6366f1;display:flex;align-items:center;justify-content:center;gap:6px}.ci-time-row{display:flex;align-items:center;justify-content:center;gap:10px;width:100%}.ci-time-block{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1}.ci-time-label{font-size:11px;color:var(--ci-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:3px}.ci-time-value{font-size:26px;font-weight:700;color:#d4d4d8;letter-spacing:-.5px;font-variant-numeric:tabular-nums}.ci-time-value.done{color:var(--ci-text)}.ci-time-arrow{display:flex;align-items:center;color:#d4d4d8;margin-top:16px;flex-shrink:0}.ci-time-arrow svg{width:16px;height:16px}.ci-work-hours{font-size:12px;color:var(--ci-text-muted);font-weight:500}.ci-site-section{background:var(--ci-card);border:1px dashed #d4d4d8;border-radius:var(--ci-radius);padding:18px}.ci-site-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--ci-text);margin-bottom:6px}.ci-site-desc{font-size:12px;color:var(--ci-text-muted);line-height:1.65;margin:0 0 12px}.ci-site-form{display:flex;flex-direction:column;gap:6px}.ci-site-input{text-transform:uppercase;letter-spacing:.12em;font-weight:700;font-size:18px!important;text-align:center;margin-bottom:0}.ci-site-badge{display:flex;align-items:center;gap:8px;background:#f4f4f5;border:1px solid var(--ci-border);border-radius:8px;padding:9px 13px;color:var(--ci-text-muted)}.ci-site-name{flex:1;font-size:13px;font-weight:600;color:var(--ci-text-sub)}.ci-realtime-clock{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--ci-card);border:1px solid var(--ci-border);border-radius:12px;padding:14px 16px;margin:8px 0 4px}.ci-clock-block{display:flex;flex-direction:column;align-items:center;background:var(--ci-primary-light);border-radius:8px;padding:8px 14px;min-width:56px}.ci-clock-num{font-size:26px;font-weight:700;color:var(--ci-text);font-variant-numeric:tabular-nums;line-height:1}.ci-clock-label{font-size:11px;color:var(--ci-text-muted);margin-top:3px}.ci-clock-sep{font-size:22px;font-weight:700;color:var(--ci-text-muted);margin-bottom:12px}.ci-clock-ampm{font-size:12px;font-weight:600;color:var(--ci-text-muted);align-self:flex-end;margin-bottom:14px}.ci-site-change{font-size:12px;color:var(--ci-text-muted);background:#fff;border:1px solid var(--ci-border);border-radius:5px;padding:3px 9px;cursor:pointer;font-family:inherit;transition:background .15s}.ci-site-change:hover{background:#f4f4f5}.ci-btn-group{display:flex;flex-direction:column;gap:8px}.ci-done-msg{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;color:var(--ci-green);padding:18px;background:var(--ci-green-bg);border:1px solid var(--ci-green-border);border-radius:var(--ci-radius)}.ci-edit-section{display:flex;flex-direction:column;gap:6px}.ci-edit-row{display:flex;align-items:center;gap:10px;background:var(--ci-card);border:1px solid var(--ci-border);border-radius:8px;padding:10px 13px}.ci-edit-type-btn{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--ci-text-sub);background:#f4f4f5;border:none;border-radius:6px;padding:6px 12px;cursor:pointer;font-family:inherit;flex-shrink:0;transition:background .15s}.ci-edit-type-btn:hover{background:#ececed}.ci-countdown{font-size:12px;font-weight:600;color:var(--ci-text-muted);font-variant-numeric:tabular-nums;flex:1;text-align:right}.ci-edit-expired{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--ci-text-muted)}.ci-month-nav{display:flex;align-items:center;justify-content:center;gap:14px;font-size:14px;font-weight:700;color:var(--ci-text)}.ci-month-nav button{background:var(--ci-card);border:1px solid var(--ci-border);border-radius:7px;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.ci-month-nav button:hover{background:#f4f4f5}.ci-month-nav button svg{width:14px;height:14px}.ci-summary{display:flex;gap:6px}.ci-summary-item{flex:1;background:var(--ci-card);border:1px solid var(--ci-border);border-radius:10px;padding:12px 6px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px}.ci-summary-label{font-size:11px;color:var(--ci-text-muted);font-weight:500}.ci-summary-value{font-size:20px;font-weight:700;color:var(--ci-text)}.ci-summary-value.green{color:var(--ci-green)}.ci-summary-value.orange{color:var(--ci-orange)}.ci-summary-value.red{color:var(--ci-red)}.ci-records-list{display:flex;flex-direction:column;gap:5px}.ci-record-row{background:var(--ci-card);border:1px solid var(--ci-border);border-radius:8px;padding:12px 14px;display:flex;align-items:center;gap:10px}.ci-record-date{font-size:13px;font-weight:600;color:var(--ci-text-sub);min-width:76px;flex-shrink:0}.ci-record-center{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.ci-record-times{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--ci-text);flex-wrap:wrap}.ci-record-sep{color:var(--ci-border)}.ci-record-hours{font-size:11px;color:var(--ci-text-muted);margin-left:2px}.ci-record-workplace{font-size:11px;color:var(--ci-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ci-status-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:5px;flex-shrink:0}.ci-status-badge.green{background:var(--ci-green-bg);color:var(--ci-green);border:1px solid var(--ci-green-border)}.ci-status-badge.orange{background:var(--ci-orange-bg);color:var(--ci-orange);border:1px solid #e8cfa0}.ci-status-badge.red{background:var(--ci-red-bg);color:var(--ci-red);border:1px solid #fecdd3}.ci-status-badge.gray{background:#f4f4f5;color:var(--ci-text-muted);border:1px solid var(--ci-border)}.ci-empty{text-align:center;color:var(--ci-text-muted);font-size:14px;padding:40px 0}.ci-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:flex-end;justify-content:center;z-index:100}.ci-modal{background:var(--ci-card);width:100%;max-width:480px;border-radius:16px 16px 0 0;overflow:hidden;border-top:1px solid var(--ci-border)}.ci-modal-small{border-radius:14px;margin:auto auto 0;max-width:320px;width:calc(100% - 32px)}.ci-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;font-size:14px;font-weight:700;color:var(--ci-text);border-bottom:1px solid var(--ci-border)}.ci-modal-close{background:none;border:none;color:var(--ci-text-muted);cursor:pointer;display:flex;align-items:center;padding:4px;border-radius:5px;transition:background .15s}.ci-modal-close:hover{background:#f4f4f5}.ci-modal-body{padding:18px;display:flex;flex-direction:column}.ci-cancel-confirm-msg{font-size:14px;color:var(--ci-text);text-align:center;padding:8px 0 4px}.ci-modal-label{font-size:12px;font-weight:600;color:var(--ci-text-sub);margin-bottom:6px}.ci-modal-footer{display:flex;gap:8px;padding:12px 18px 18px;border-top:1px solid var(--ci-border)}.ci-modal-footer .ci-btn{flex:1;margin-top:0}.ci-modal-title{font-size:16px;font-weight:700;color:var(--ci-text);padding:18px 18px 12px;border-bottom:1px solid var(--ci-border)}.ci-confirm-info{background:var(--ci-primary-light);border-radius:8px;padding:12px 14px;margin-bottom:14px}.ci-confirm-row{display:flex;gap:12px;padding:5px 0;font-size:14px}.ci-confirm-label{color:var(--ci-text-muted);min-width:60px}.ci-confirm-value{font-weight:600;color:var(--ci-text)}.ci-confirm-warn{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:#92400e;background:#fdf4e7;border:1px solid #f6d860;border-radius:8px;padding:10px 12px;margin:0;line-height:1.5}.ci-gps-checking{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 24px;gap:10px}.ci-gps-checking-title{font-size:14px;font-weight:700;color:var(--ci-text);margin:0}.ci-gps-checking-sub{font-size:13px;color:var(--ci-text-muted);margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ci-spin{animation:spin 1s linear infinite;color:var(--ci-text-muted)}.ci-photo-guide{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;padding:14px 0;color:var(--ci-text-sub);font-size:14px;font-weight:600;margin-bottom:14px}.ci-photo-guide p{margin:0}.ci-photo-guide-sub{font-size:12px;font-weight:400;color:var(--ci-text-muted);line-height:1.6}.ci-gps-retry-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px;background:var(--ci-green-bg);color:var(--ci-green);border:1px solid var(--ci-green-border);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;margin-bottom:4px;transition:background .15s}.ci-gps-retry-btn:hover{background:#e3ede8}.ci-gps-retry-btn:disabled{opacity:.45;cursor:not-allowed}.ci-gps-retry-hint{text-align:center;font-size:12px;color:var(--ci-text-muted);margin:4px 0 8px}.ci-gps-faq-wrap{margin-top:12px;width:100%}.ci-gps-faq-toggle{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;background:none;border:none;padding:6px 0;font-size:13px;color:var(--ci-text-muted);cursor:pointer;font-family:inherit}.ci-gps-faq-toggle:hover{color:var(--ci-text)}.ci-gps-faq{width:100%;margin-top:8px}.ci-gps-faq-title{font-size:12px;font-weight:600;color:var(--ci-text-muted);margin:0 0 6px}.ci-gps-faq-item{border:1px solid var(--ci-border);border-radius:8px;margin-bottom:6px;overflow:hidden}.ci-gps-faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--ci-primary-light);border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--ci-text);font-family:inherit}.ci-gps-faq-arrow{font-size:10px;color:var(--ci-text-muted)}.ci-gps-faq-steps{margin:0;padding:10px 12px 10px 28px;background:#fff}.ci-gps-faq-steps li{font-size:13px;color:var(--ci-text);line-height:1.6;margin-bottom:4px}.ci-photo-divider{display:flex;align-items:center;gap:10px;color:var(--ci-text-muted);font-size:12px;margin:10px 0}.ci-photo-divider:before,.ci-photo-divider:after{content:"";flex:1;height:1px;background:var(--ci-border)}.ci-photo-upload-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:var(--ci-primary);color:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.ci-photo-upload-btn:hover{opacity:.88}.ci-photo-upload-btn.loading{background:#a1a1aa;cursor:not-allowed}.ci-verify-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:7px 12px;border-radius:6px;margin-bottom:12px}.ci-verify-badge.gps{background:var(--ci-green-bg);color:var(--ci-green);border:1px solid var(--ci-green-border)}.ci-verify-badge.photo{background:#f4f4f5;color:var(--ci-text-sub);border:1px solid var(--ci-border)}@media (max-width: 480px){.ci-time-value{font-size:22px}.ci-btn.checkin,.ci-btn.checkout{font-size:16px;padding:16px}.ci-summary-value{font-size:18px}.ci-card{padding:28px 20px 24px}}.ci-install-banner{display:flex;align-items:center;gap:8px;background:#eef2ff;border-bottom:1px solid #c7d2fe;padding:10px 16px;font-size:13px;color:#3730a3}.ci-install-text{flex:1;line-height:1.4}.ci-install-btn{flex-shrink:0;background:#3730a3;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.ci-install-btn:active{opacity:.85}.ci-ios-guide{display:flex;flex-direction:column;gap:16px;margin:20px 0;text-align:left}.ci-ios-method-label{font-size:12px;font-weight:700;color:var(--ci-primary);margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--ci-border)}.ci-ios-step{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--ci-text);line-height:1.5}.ci-ios-num{flex-shrink:0;width:24px;height:24px;background:var(--ci-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.ci-ios-share-icon{display:inline-flex;vertical-align:middle;margin-left:4px}.ci-splash{min-height:100vh;background:#1a1a2e;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.ci-splash-logo{font-size:2rem;font-weight:800;letter-spacing:-1px}.ci-splash-force{color:#7c6af7}.ci-splash-sub{font-size:.85rem;color:#ffffff59;font-weight:500;letter-spacing:.5px}.ci-logo-work{color:#fff}.ci-logo-force{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ci-splash-work{color:#fff}.ci-splash-force{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ci-install-done{background:#f0fdf4;border-bottom-color:#bbf7d0;color:#166534}.ci-install-loading{background:#f8fafc;border-bottom-color:#e2e8f0;color:#475569}.ci-install-warn{background:#fffbeb;border-bottom-color:#fde68a;color:#92400e}@keyframes ci-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ci-spin svg{animation:ci-spin 1s linear infinite}.anb-wrap{position:relative}.anb-bell{position:relative;width:36px;height:36px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.anb-bell:hover{background:var(--bg-hover);color:var(--text-primary)}.anb-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;background:#ef4444;color:#fff;border-radius:8px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.anb-dropdown{position:fixed;left:180px;top:0;bottom:0;width:300px;background:var(--bg-card);border-right:1px solid var(--border);box-shadow:4px 0 24px #0000001f;z-index:2000;display:flex;flex-direction:column;overflow:hidden;animation:anb-slide-in .2s ease-out}@keyframes anb-slide-in{0%{transform:translate(-16px);opacity:0}to{transform:translate(0);opacity:1}}.anb-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border-color);flex-shrink:0}.anb-title{font-size:15px;font-weight:700;color:var(--text-primary)}.anb-mark-all{font-size:12px;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:3px 8px;border-radius:6px;transition:background .15s}.anb-mark-all:hover{background:var(--bg-hover);color:var(--text-primary)}.anb-list{overflow-y:auto;flex:1}.anb-empty{padding:32px 16px;text-align:center;font-size:13px;color:var(--text-secondary)}.anb-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border-color)}.anb-item:last-child{border-bottom:none}.anb-item:hover{background:var(--bg-hover)}.anb-item.unread{background:#3b82f60a}[data-theme=dark] .anb-item.unread{background:#ffffff0a}.anb-item-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center;margin-top:1px}.anb-item-body{flex:1;min-width:0}.anb-item-doc{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.anb-item-msg{font-size:12px;color:var(--text-secondary);margin-top:2px;line-height:1.4}.anb-item-time{font-size:11px;color:var(--text-secondary);margin-top:4px;opacity:.7}.anb-item-dot{width:7px;height:7px;border-radius:50%;background:#3b82f6;flex-shrink:0;margin-top:5px}.anb-header-actions{display:flex;align-items:center;gap:4px}.anb-view-all{font-size:12px;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:3px 8px;border-radius:6px;transition:background .15s}.anb-view-all:hover{background:var(--bg-hover);color:var(--text-primary)}.anb-section-label{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 4px;font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.anb-section-ack-all{font-size:11px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;font-weight:500;text-transform:none;letter-spacing:0;transition:background .15s}.anb-section-ack-all:hover{background:var(--bg-hover);color:var(--text-primary)}.anb-section-divider{height:1px;background:var(--border);margin:4px 0}.pd-card{position:fixed;bottom:28px;right:28px;width:340px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 2px 4px #0000000f,0 12px 40px #00000024;z-index:1800;overflow:hidden;animation:pd-slide-in .32s cubic-bezier(.34,1.56,.64,1)}.pd-card.closing{animation:pd-slide-out .28s cubic-bezier(.4,0,.6,1) forwards}@keyframes pd-slide-in{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pd-slide-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(16px) scale(.95)}}.pd-accent{height:3px;background:linear-gradient(90deg,var(--primary-dark),var(--primary))}.pd-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 0}.pd-header-left{display:flex;align-items:center;gap:8px}.pd-label{font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--primary-dark);background:var(--bg-main);border:1.5px solid var(--primary-dark);border-radius:5px;padding:2px 7px}[data-theme=dark] .pd-label{color:var(--primary-dark);border-color:var(--primary-dark);background:var(--bg-hover)}.pd-count{font-size:11px;color:var(--text-muted)}.pd-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;transition:background .15s,color .15s}.pd-close:hover{background:var(--bg-hover);color:var(--text-primary)}.pd-body{padding:10px 14px 14px}.pd-title{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 4px;line-height:1.4;word-break:keep-all}.pd-meta{font-size:11px;color:var(--text-muted);margin:0 0 8px}.pd-preview{font-size:12.5px;color:var(--text-secondary);line-height:1.6;margin:0;word-break:keep-all}.pd-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--border);background:var(--bg-main)}.pd-dismiss{font-size:11.5px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:0;transition:color .15s;text-decoration:none}.pd-dismiss:hover{color:var(--text-secondary);text-decoration:underline}.pd-btn-close{padding:6px 16px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:12.5px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.pd-btn-close:hover{background:var(--bg-hover);border-color:var(--primary-dark)}.activity-log-wrap{position:relative}.activity-log-trigger{padding:8px 14px;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.activity-log-trigger:hover{background:var(--border)}.activity-log-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.activity-log-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:420px;max-width:calc(100vw - 24px);max-height:70vh;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 40px #00000026;z-index:1000;display:flex;flex-direction:column}.activity-log-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.activity-log-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.activity-log-close{background:none;border:none;font-size:1.4rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:0 4px}.activity-log-close:hover{color:var(--text-primary)}.activity-log-body{overflow-y:auto;padding:8px 0}.activity-log-empty{padding:24px 16px;text-align:center;color:var(--text-secondary);font-size:.9rem;margin:0}.activity-log-list{list-style:none;margin:0;padding:0}.activity-log-item{padding:10px 16px;border-bottom:1px solid var(--border-subtle, #f1f5f9);display:flex;flex-direction:column;gap:4px}.activity-log-item:last-child{border-bottom:none}.activity-log-message{font-size:.9rem;color:var(--text-primary);line-height:1.4}.activity-log-meta{font-size:.78rem;color:var(--text-secondary)}[data-theme=dark] .activity-log-item{border-bottom-color:#ffffff0f}.activity-log-footer{padding:10px 16px;border-top:1px solid var(--border);display:flex;justify-content:center}.activity-log-view-all{background:none;border:1px solid var(--border);border-radius:6px;padding:6px 20px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;width:100%;transition:all .15s}.activity-log-view-all:hover{background:var(--bg-hover);color:var(--text-primary)}.activity-log-full-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:2000;display:flex;align-items:center;justify-content:center}.activity-log-full-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px #0003;width:640px;max-width:calc(100vw - 32px);max-height:85vh;display:flex;flex-direction:column}.activity-log-full-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}.activity-log-full-header h2{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-primary);flex:1}.activity-log-full-total{font-size:.85rem;color:var(--text-secondary)}.activity-log-full-body{overflow-y:auto;flex:1;padding:8px 0}.activity-log-full-footer{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 20px;border-top:1px solid var(--border)}.activity-log-page-btn{background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;padding:6px 14px;font-size:.85rem;color:var(--text-primary);cursor:pointer;transition:all .15s}.activity-log-page-btn:hover:not(:disabled){background:var(--border)}.activity-log-page-btn:disabled{opacity:.4;cursor:default}.activity-log-page-info{font-size:.85rem;color:var(--text-secondary);min-width:60px;text-align:center}.welcome-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1200;display:flex;align-items:center;justify-content:center;padding:20px;animation:welcomeFadeIn .2s ease-out}@keyframes welcomeFadeIn{0%{opacity:0}to{opacity:1}}.welcome-modal{position:relative;background:#fff;border-radius:18px;width:100%;max-width:440px;padding:48px 40px 28px;box-shadow:0 30px 60px -15px #0f172a47,0 0 0 1px #0f172a0a;text-align:center;font-family:-apple-system,BlinkMacSystemFont,Pretendard,Noto Sans KR,sans-serif;-webkit-font-smoothing:antialiased;animation:welcomeSlideUp .25s cubic-bezier(.34,1.56,.64,1)}@keyframes welcomeSlideUp{0%{transform:translateY(16px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.welcome-modal-close{position:absolute;top:12px;right:12px;width:30px;height:30px;border:none;background:transparent;color:#94a3b8;cursor:pointer;border-radius:8px;display:inline-flex;align-items:center;justify-content:center}.welcome-modal-close:hover{background:#f1f5f9;color:#1e293b}.welcome-modal-close:disabled{opacity:.4;cursor:not-allowed}.welcome-modal-eyebrow{display:inline-block;margin-bottom:16px;font-size:.68rem;font-weight:700;letter-spacing:.12em;color:#94a3b8;text-transform:uppercase}.welcome-modal-title{margin:0 0 22px;font-size:26px;font-weight:800;color:#0f172a;letter-spacing:-.025em;line-height:1.3}.welcome-modal-arrow{margin:0 auto 26px;width:28px;height:28px;color:#4e7a99;display:inline-flex;align-items:center;justify-content:center;opacity:.7;animation:welcomeArrowBounce 1.8s ease-in-out infinite}@keyframes welcomeArrowBounce{0%,to{transform:translateY(0);opacity:.7}50%{transform:translateY(3px);opacity:1}}.welcome-modal-actions{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.welcome-modal-btn{width:100%;padding:14px 16px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;border:1px solid transparent;letter-spacing:-.005em;transition:background .15s,transform .05s}.welcome-modal-btn:disabled{opacity:.6;cursor:not-allowed}.welcome-modal-btn-primary{background:#334155;color:#fff;font-weight:800}.welcome-modal-btn-primary:hover:not(:disabled){background:#1e293b;box-shadow:0 4px 14px #0f172a2e}.welcome-modal-btn-primary:active:not(:disabled){transform:translateY(1px)}.welcome-modal-text-btn{background:transparent;border:none;padding:12px 0 4px;color:#94a3b8;font-size:13px;font-weight:500;cursor:pointer}.welcome-modal-text-btn:hover:not(:disabled){color:#475569}.welcome-modal-dismiss-forever{display:block;margin:14px auto 0;padding:4px 10px;background:transparent;border:none;color:#cbd5e1;font-size:11.5px;font-weight:500;cursor:pointer;text-decoration:underline;text-decoration-color:#e2e8f0;text-underline-offset:3px}.welcome-modal-dismiss-forever:hover:not(:disabled){color:#94a3b8;text-decoration-color:#cbd5e1}.welcome-modal-text-btn:disabled{opacity:.5;cursor:not-allowed}.welcome-modal-foot{margin:0;padding-top:18px;border-top:1px solid #e2e8f0;font-size:12px;color:#94a3b8;line-height:1.5;text-align:center}.welcome-modal-inline-link{background:transparent;border:none;padding:0;font:inherit;font-weight:600;color:#2563eb;cursor:pointer}.welcome-modal-inline-link:hover:not(:disabled){color:#1d4ed8;text-decoration:underline}.welcome-modal-inline-link:disabled{opacity:.6;cursor:not-allowed}.welcome-modal-import{margin-top:18px;border-top:1px solid #f1f5f9;padding-top:14px;text-align:center}.welcome-modal-import-toggle{display:inline-flex;align-items:center;gap:5px;background:transparent;border:none;padding:0;font-size:12px;font-weight:500;color:#94a3b8;cursor:pointer;letter-spacing:.01em}.welcome-modal-import-toggle:hover{color:#64748b}.welcome-modal-import-body{margin-top:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;text-align:left}.welcome-modal-import-desc{margin:0 0 8px;font-size:12.5px;color:#475569;line-height:1.6}.welcome-modal-import-desc strong{color:#1e293b;font-weight:700}.welcome-modal-import-how{margin:0 0 10px;font-size:12px;color:#64748b}.welcome-modal-import-contacts{display:flex;flex-direction:column;gap:6px}.welcome-modal-import-contact{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:#334155;text-decoration:none}.welcome-modal-import-contact:hover{color:#2563eb;text-decoration:underline}@media (max-width: 480px){.welcome-modal{padding:30px 22px 20px}.welcome-modal-title{font-size:19px}}.app{height:100vh;display:flex;flex-direction:column;background:var(--bg-main);overflow:hidden}.header{background:var(--bg-card);padding:20px 40px;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center}.brand{display:flex;align-items:baseline;gap:12px;cursor:pointer;margin:0}.brand-name{font-size:1.6rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.brand-desc{font-size:.9rem;font-weight:400;color:var(--text-secondary)}.header-right{display:flex;align-items:center;gap:16px}.header-user-panel{display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:4px 4px 4px 12px;gap:0;box-shadow:0 1px 3px #0000000f}.header-user-info{display:flex;align-items:center;gap:8px;padding-right:12px}.header-user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.header-user-avatar-fallback{background:var(--primary, #2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.header-user-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap}.header-owner-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:999px;background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary);font-size:.68rem;font-weight:600;letter-spacing:.03em;flex-shrink:0}.header-user-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.header-user-actions{display:flex;align-items:center;gap:2px;padding-left:4px}.header-user-actions .user-menu-trigger,.header-user-actions .severance-notification-trigger,.header-user-actions .anb-bell{width:34px;height:34px;border:none;background:transparent;border-radius:8px;box-shadow:none;padding:0;flex-shrink:0}.header-user-actions .user-menu-trigger:hover,.header-user-actions .severance-notification-trigger:hover,.header-user-actions .anb-bell:hover{background:var(--bg-hover);border:none;box-shadow:none}.header-user-actions .anb-wrap{display:flex;align-items:center;flex-shrink:0}.theme-toggle{padding:8px 14px;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.theme-toggle:hover{background:var(--border)}.user-email,.user-name{font-size:.9rem;color:var(--text-secondary);transition:color .2s}.user-name:hover{color:var(--text-primary)}.btn-logout{padding:8px 16px;background:var(--bg-hover);color:var(--primary-dark);border:1px solid var(--border);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-logout:hover{background:var(--border);color:var(--text-primary)}.user-menu-wrapper{position:relative;display:inline-block}.user-menu-trigger{width:40px;height:40px;padding:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all .2s}.user-menu-trigger:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary)}.user-menu-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001f;min-width:220px;overflow:visible;z-index:10001;padding:6px 0}.user-menu-item{width:100%;padding:12px 16px;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .15s;text-align:left}.user-menu-item:hover{background:var(--bg-hover)}.user-menu-item svg{flex-shrink:0;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.user-menu-item-danger{color:#ef4444}.user-menu-item-danger:hover{background:var(--error-bg);color:#dc2626}.user-menu-divider{height:1px;background:var(--border);margin:6px 0}.user-menu-section-label{padding:8px 14px 4px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted, #94a3b8);-webkit-user-select:none;user-select:none}.user-menu-online{padding:10px 16px 8px}.user-menu-online-hover{position:relative;display:inline-flex;align-items:center}.user-menu-online-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:default}.user-menu-online-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.user-menu-online-tooltip{display:none;position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0000001f;padding:8px 0;min-width:140px;z-index:10010}.user-menu-online-hover:hover .user-menu-online-tooltip{display:block}.user-menu-online-tooltip-item{display:flex;align-items:center;gap:8px;padding:6px 14px;font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap}.app-body{flex:1;min-height:0;height:0;display:flex;overflow:hidden}.nav-sidebar{width:180px;flex-shrink:0;height:100%;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.nav-logo-row{display:flex;align-items:center;justify-content:space-between;padding:12px 8px 8px;gap:4px}.nav-org-card{display:flex;align-items:center;gap:10px;flex:1;min-width:0;padding:8px;border-radius:10px;cursor:pointer;transition:background .15s}.nav-org-card:hover{background:var(--bg-hover)}.nav-org-card-text{display:flex;flex-direction:column;align-items:flex-start;gap:1px;min-width:0}.nav-org-title{font-size:.85rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid #3b82f6;padding-left:8px}.nav-org-settings-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.nav-org-settings-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-org-dropdown-item{display:flex;align-items:center;width:100%;padding:9px 12px;background:none;border:none;cursor:pointer;text-align:left;transition:background .12s}.nav-org-dropdown-item:hover{background:var(--bg-hover)}.nav-logo-bell{flex-shrink:0}.nav-divider{height:1px;background:var(--border);margin:0 12px}.nav-admin-tools{display:flex;align-items:center;gap:4px;padding:6px 10px}.nav-admin-tool-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:none;border:none;border-radius:8px;cursor:pointer;color:var(--text-muted);font-size:.68rem;font-weight:500;transition:background .15s,color .15s;white-space:nowrap}.nav-admin-tool-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-user-chevron{flex-shrink:0;color:var(--text-muted)}.nav-logo-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.nav-logo-accent{background:linear-gradient(90deg,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-menu-scroll{flex:1;min-height:0;overflow-y:auto;padding:4px 8px 8px;display:flex;flex-direction:column;gap:2px}.nav-menu-scroll::-webkit-scrollbar{width:4px}.nav-menu-scroll::-webkit-scrollbar-track{background:transparent}.nav-menu-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sidebar-user{flex-shrink:0;border-top:1px solid var(--border);padding:8px;display:flex;flex-direction:column;gap:2px}.sidebar-org-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .15s}.sidebar-org-row:hover{background:var(--bg-hover)}.sidebar-org-icon{width:22px;height:22px;border-radius:6px;background:var(--primary-dark, #1e40af);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.sidebar-org-name{font-size:.78rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-info{flex:1;min-width:0;display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .15s}.sidebar-user-info:hover{background:var(--bg-hover)}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.sidebar-user-avatar-fallback{background:var(--primary, #2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.sidebar-user-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.sidebar-user-name{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.68rem;color:var(--text-muted)}.nav-group{display:flex;flex-direction:column;padding:6px 0 2px}.nav-group+.nav-group{border-top:1px solid var(--border);margin-top:4px;padding-top:10px}.nav-group-label{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:0 8px 4px}.nav-item{position:relative;background:transparent;border:none;width:100%;text-align:left;padding:6px 8px;font-size:.875rem;font-weight:400;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:background .15s,color .15s;display:flex;align-items:center;gap:7px}.nav-item-icon{display:flex;align-items:center;flex-shrink:0;opacity:.65;transition:opacity .15s}.nav-item:hover .nav-item-icon,.nav-item.active .nav-item-icon{opacity:1}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-hover);color:var(--text-primary);font-weight:600}.nav-item-label{display:inline-flex;align-items:center;gap:6px;flex:1}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:.75rem;font-weight:600;color:var(--bg-main);background:var(--border);border-radius:10px;line-height:1}.nav-item.active .nav-badge{background:var(--primary-dark);color:var(--bg-card)}.nav-indicator{position:absolute;top:4px;bottom:4px;left:0;width:3px;border-radius:0 2px 2px 0;background:var(--primary-dark);animation:indicatorSlide .15s ease-out}.nav-subparent{display:flex;align-items:center;gap:7px;padding:8px 8px 2px;font-size:.75rem;font-weight:600;color:var(--text-muted);margin-top:2px;opacity:.8}.nav-subparent .nav-item-icon{opacity:.5}.nav-subitem{padding-left:22px;font-size:.825rem}@keyframes indicatorSlide{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.main-content{flex:1;min-height:0;height:100%;overflow:hidden;position:relative;transition:margin-left .22s ease-out}.main-content.notif-open{margin-left:300px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-overlay.confirm-modal-overlay{z-index:10000}.modal-content{background:var(--bg-card);padding:32px;border-radius:16px;width:100%;max-width:500px;box-shadow:var(--shadow);margin:20px;border:1px solid var(--border)}.modal-content h2{margin:0 0 24px;font-size:20px;color:var(--text-primary)}.modal-content.author-info-modal,.modal-content.author-info-modal h2,.modal-content.author-info-modal .author-info-value{color:var(--text-primary)}.modal-content.author-info-modal .author-info-label{color:var(--text-secondary)}.modal-content.author-info-modal .btn-submit{color:var(--btn-primary-text);background:var(--primary-dark)}.add-rows-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;width:280px;box-shadow:0 8px 32px #0000002e;color:var(--text-primary)}.add-rows-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.add-rows-modal-title{font-size:15px;font-weight:600;color:var(--text-primary)}.add-rows-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex;align-items:center;border-radius:4px;transition:color .15s}.add-rows-modal-close:hover{color:var(--text-primary)}.add-rows-modal-desc{font-size:13px;color:var(--text-secondary);margin:0 0 18px;line-height:1.5}.add-rows-modal-desc strong{color:var(--text-primary);font-weight:600}.add-rows-input-row{display:flex;align-items:center;gap:8px;margin-bottom:20px}.add-rows-stepper{width:32px;height:32px;border:1px solid var(--border);background:var(--bg-hover);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:background .15s;flex-shrink:0}.add-rows-stepper:hover{background:var(--border)}.add-rows-input{flex:1;height:36px;border:1px solid var(--border);border-radius:6px;background:var(--bg-input, var(--bg-card));color:var(--text-primary);font-size:18px;font-weight:600;text-align:center;outline:none;transition:border-color .15s;-moz-appearance:textfield}.add-rows-input::-webkit-outer-spin-button,.add-rows-input::-webkit-inner-spin-button{-webkit-appearance:none}.add-rows-input:focus{border-color:var(--primary)}.add-rows-modal-actions{display:flex;gap:8px;justify-content:flex-end}.confirm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;width:340px;box-shadow:0 8px 32px #0000002e;color:var(--text-primary)}.confirm-modal-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.confirm-modal-icon--danger{color:#ef4444;display:flex;align-items:center;flex-shrink:0}.confirm-modal-icon--primary{color:var(--primary, #3b82f6);display:flex;align-items:center;flex-shrink:0}.prompt-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:22px 24px 20px;width:380px;box-shadow:0 8px 32px #0000002e;color:var(--text-primary)}.prompt-modal-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.prompt-modal-title{font-size:15px;font-weight:600;color:var(--text-primary);flex:1}.prompt-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex;align-items:center;border-radius:4px;transition:color .15s}.prompt-modal-close:hover{color:var(--text-primary)}.prompt-modal-message{font-size:13.5px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.prompt-modal-input,.prompt-modal-textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:13.5px;font-family:inherit;background:var(--bg-main);color:var(--text-primary);outline:none;box-sizing:border-box;transition:border-color .12s,box-shadow .12s}.prompt-modal-input:focus,.prompt-modal-textarea:focus{border-color:var(--primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61f}.prompt-modal-textarea{resize:vertical;min-height:80px;line-height:1.5}.prompt-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.confirm-modal-title{font-size:15px;font-weight:600;color:var(--text-primary);flex:1}.confirm-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;display:flex;align-items:center;border-radius:4px;transition:color .15s;flex-shrink:0}.confirm-modal-close:hover{color:var(--text-primary)}.confirm-modal-message{font-size:13.5px;color:var(--text-secondary);margin:0 0 20px;line-height:1.6;padding-left:30px}.confirm-modal-sections{margin:0 0 20px;padding-left:30px;display:flex;flex-direction:column;gap:8px}.cf-section{background:#f7f7f5;border-radius:6px;padding:9px 12px}.cf-section-label{font-size:10.5px;font-weight:700;color:#8a8a8a;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.cf-section-value{font-size:13px;color:var(--text-primary);line-height:1.5}.cf-section-value strong{font-weight:600}.cf-section--warn{background:#fff7e6;border-left:3px solid #f0b429}.cf-section--warn .cf-section-label{color:#b87a32}.cf-section--danger{background:#fef0f0;border-left:3px solid #c83232}.cf-section--danger .cf-section-label{color:#c83232}.cf-section--info{background:#eef4f9;border-left:3px solid #4e7a99}.cf-section--info .cf-section-label{color:#4e7a99}[data-theme=dark] .cf-section{background:#1a2535;color:var(--text-primary)}[data-theme=dark] .cf-section-label{color:var(--text-secondary)}[data-theme=dark] .cf-section-value{color:var(--text-primary)}[data-theme=dark] .cf-section--warn{background:#2a1f0a;border-left-color:#c8922a}[data-theme=dark] .cf-section--warn .cf-section-label{color:#c8922a}[data-theme=dark] .cf-section--danger{background:#2a1010;border-left-color:#e05252}[data-theme=dark] .cf-section--danger .cf-section-label{color:#e05252}[data-theme=dark] .cf-section--info{background:#0e2030;border-left-color:#4e7a99}[data-theme=dark] .cf-section--info .cf-section-label{color:#7aa8cc}.confirm-modal-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center}.onboarding-tip-banner{display:flex;align-items:center;gap:12px;margin:12px 20px 0;padding:12px 16px;background:#fff;border:1px solid #e2e8f0;border-left:3px solid #4e7a99;border-radius:10px;box-shadow:0 1px 2px #0f172a0a;font-family:-apple-system,BlinkMacSystemFont,Pretendard,Noto Sans KR,sans-serif}.onboarding-tip-banner--success{border-left-color:#16a34a}.onboarding-tip-icon{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:#e8eef4;color:#4e7a99;display:inline-flex;align-items:center;justify-content:center}.onboarding-tip-banner--success .onboarding-tip-icon{background:#dcfce7;color:#16a34a}.onboarding-tip-body{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.onboarding-tip-label{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#4e7a99}.onboarding-tip-banner--success .onboarding-tip-label{color:#16a34a}.onboarding-tip-text{font-size:13px;line-height:1.55;color:#334155}.onboarding-tip-text strong{color:#0f172a;font-weight:700}.onboarding-tip-close{flex:0 0 auto;width:28px;height:28px;border:none;background:transparent;color:#94a3b8;cursor:pointer;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.onboarding-tip-close:hover{background:#f1f5f9;color:#475569}.onboarding-tip-dismiss{flex:0 0 auto;padding:4px 10px;background:transparent;border:none;color:#94a3b8;cursor:pointer;font-size:12px;font-weight:500;text-decoration:underline;text-decoration-color:#e2e8f0;text-underline-offset:3px;white-space:nowrap}.onboarding-tip-dismiss:hover{color:#475569;text-decoration-color:#cbd5e1}.menu-tip-toggle{margin:12px 20px 0;font-family:-apple-system,BlinkMacSystemFont,Pretendard,Noto Sans KR,sans-serif}.menu-tip-toggle-bar{display:flex;justify-content:flex-end}.menu-tip-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:50%;color:#94a3b8;cursor:pointer;transition:background .15s,color .15s}.menu-tip-toggle-btn:hover{background:#f1f5f9;color:#475569}.menu-tip-toggle-btn.is-open{background:#e8eef4;color:#4e7a99}.menu-tip-toggle-chev{color:#94a3b8;transition:transform .2s}.menu-tip-toggle.is-open .menu-tip-toggle-chev{transform:rotate(180deg)}.menu-tip-toggle-panel{margin-top:8px;padding:16px 20px;background:#fff;border:1px solid #e2e8f0;border-left:3px solid #4e7a99;border-radius:10px;font-size:13px;line-height:1.65;color:#334155;box-shadow:0 1px 2px #0f172a0a;animation:menuTipExpand .2s ease-out}@keyframes menuTipExpand{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.menu-tip-toggle-panel strong{color:#0f172a;font-weight:700}.menu-tip-toggle-tour-link{display:flex;width:fit-content;align-items:center;gap:5px;margin-top:14px;padding:6px 12px 6px 10px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;font-size:12px;font-weight:600;color:#4e7a99;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.menu-tip-toggle-tour-link:hover{background:#e8eef4;border-color:#4e7a99;color:#1e293b}.menu-tip-toggle-tour-link svg{flex-shrink:0;fill:currentColor;opacity:.85}.confirm-modal-actions .btn-cancel{padding:9px 16px;background:transparent;border-color:transparent;color:var(--text-secondary);font-size:.88rem;font-weight:500}.confirm-modal-actions .btn-cancel:hover{background:var(--bg-hover)}.confirm-modal-actions .btn-confirm{padding:12px 24px;font-size:.95rem;font-weight:600;min-width:100px}.btn-confirm{padding:9px 20px;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--primary-dark);color:var(--bg-card)}.btn-confirm:hover{opacity:.88}.btn-confirm--danger{background:#ef4444;color:#fff}.btn-confirm--danger:hover{background:#dc2626}.btn-cancel{padding:10px 20px;background:var(--bg-hover);color:var(--primary-dark);border:1px solid var(--border);border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--border)}.btn-submit{padding:10px 20px;background:var(--primary-dark);color:var(--bg-card);border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-submit:hover{background:var(--primary)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.header{padding:16px 20px}.header .header-right{flex-direction:row;flex-wrap:nowrap;align-items:center}.brand{flex-direction:column;gap:4px}.brand-name{font-size:1.3rem}.brand-desc{font-size:.8rem}.nav-sidebar{width:120px}.nav-group-label{font-size:.65rem;padding:0 10px 4px}.nav-item{padding:6px 10px;font-size:.8rem}}.cal-notify-container{position:fixed;bottom:28px;right:28px;z-index:3000;display:flex;flex-direction:column;gap:10px;align-items:flex-end;pointer-events:none}.cal-notify-dismiss-all{pointer-events:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:5px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:background .15s}.cal-notify-dismiss-all:hover{background:var(--bg-hover)}.cal-notify-card{pointer-events:auto;display:flex;align-items:stretch;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 6px 28px #0000002e;overflow:hidden;min-width:320px;max-width:400px;animation:cal-notify-slide-in .25s ease}@keyframes cal-notify-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.cal-notify-accent{width:5px;flex-shrink:0}.cal-notify-body{flex:1;padding:13px 14px;display:flex;flex-direction:column;gap:5px;min-width:0}.cal-notify-header{display:flex;align-items:center;gap:5px;color:var(--text-secondary)}.cal-notify-cal{font-size:12px;color:var(--text-secondary)}.cal-notify-title{font-size:16px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-notify-meta{display:flex;flex-direction:column;gap:3px}.cal-notify-time,.cal-notify-location{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text-secondary)}.cal-notify-close{padding:10px 12px;background:none;border:none;cursor:pointer;color:var(--text-secondary);display:flex;align-items:flex-start;flex-shrink:0;transition:color .15s}table thead th{position:relative}.col-resize-handle{position:absolute;right:0;top:0;width:5px;height:100%;cursor:col-resize;z-index:2;-webkit-user-select:none;user-select:none}.col-resize-handle:hover,.col-resize-handle.dragging{background:#1a73e866}.cal-notify-close:hover{color:var(--text-primary)}:root{--bg-table-header: #f8fafc;--primary: #64748b;--primary-dark: #475569;--primary-light: #94a3b8;--bg-main: #f8fafc;--bg-card: #ffffff;--bg-hover: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--success: #0284c7;--success-bg: #e0f2fe;--warning: #d97706;--warning-bg: #fffbeb;--error: #dc2626;--error-bg: #fef2f2;--border: #e2e8f0;--border-focus: #94a3b8;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .05);--btn-primary-text: #ffffff;--bg-frozen: #eef2ff}[data-theme=dark]{--bg-table-header: #162032;--primary: #94a3b8;--primary-dark: #cbd5e1;--primary-light: #64748b;--bg-main: #0f172a;--bg-card: #1e293b;--bg-hover: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--success: #38bdf8;--success-bg: rgba(56, 189, 248, .15);--warning: #fbbf24;--warning-bg: rgba(251, 191, 36, .15);--error: #f87171;--error-bg: rgba(248, 113, 113, .15);--border: rgba(148, 163, 184, .2);--border-focus: #94a3b8;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--btn-primary-text: #0f172a;--bg-frozen: #1e2a45}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-main);color:var(--text-primary);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}input,select,textarea,button{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif}code,pre,.mono{font-family:Noto Sans KR,monospace}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::-webkit-scrollbar-corner{background:transparent}::selection{background:#94a3b8;color:#fff}[data-theme=dark] *::selection{background:#475569;color:#f1f5f9}:focus-visible{outline:2px solid var(--primary-dark);outline-offset:2px;border-radius:4px}::placeholder{color:var(--text-muted);opacity:1}input,textarea{caret-color:var(--primary-dark)}input[type=checkbox],input[type=radio]{accent-color:var(--primary-dark)}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,textarea:-webkit-autofill,select:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--bg-card) inset;-webkit-text-fill-color:var(--text-primary);caret-color:var(--text-primary);transition:background-color 9999s ease-in-out 0s}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=date]::-webkit-calendar-picker-indicator,input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:opacity(.5);cursor:pointer}input[type=date]::-webkit-calendar-picker-indicator:hover,input[type=datetime-local]::-webkit-calendar-picker-indicator:hover{filter:opacity(.9)}textarea{resize:vertical}.insert-col-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border-radius:10px;padding:24px;z-index:10101;min-width:300px;box-shadow:0 8px 32px #0000002e}.insert-col-modal-title{font-weight:700;font-size:15px;margin-bottom:12px;color:var(--text-primary)}.insert-col-modal-desc{font-size:13px;color:var(--text-secondary);margin-bottom:10px}.insert-col-modal-input{width:100%;border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px;outline:none;box-sizing:border-box;background:var(--bg-main);color:var(--text-primary)}.insert-col-modal-input:focus{border-color:var(--border-focus)}.insert-col-modal-footer{display:flex;gap:8px;margin-top:14px;justify-content:flex-end}.insert-col-modal-btn-cancel{padding:7px 16px;border-radius:6px;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-primary);cursor:pointer;font-size:13px}.insert-col-modal-btn-confirm{padding:7px 16px;border-radius:6px;border:none;background:#1a73e8;color:#fff;cursor:pointer;font-size:13px}.insert-col-modal-btn-confirm:disabled{opacity:.5;cursor:default}.export-dropdown-hint{padding:9px 12px;font-size:11px;color:#475569;background:#f8fafc;border-bottom:1px solid #e2e8f0;line-height:1.45}.export-dropdown-hint strong{display:block;font-size:12px;font-weight:700;color:#4e7a99;margin-bottom:2px}
