:root{font-family:Pretendard,Noto Sans KR,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;font-weight:400;font-size:16px;color:#0f172a;background-color:#f8fafc;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;background:#f1f5f9}a{text-decoration:none;color:inherit}.app-layout{display:flex;height:100vh;overflow:hidden;overflow-x:hidden;background:#f1f5f9;width:100%;max-width:100vw}@media(max-width:767px){.app-layout{flex-direction:column;height:100vh}}.app-content-wrapper{flex:1;width:100%;display:flex;flex-direction:column;min-width:0;overflow:hidden;overflow-x:hidden;margin:0!important;padding:0;position:relative;z-index:0;max-width:none!important;box-sizing:border-box}@media(max-width:767px){.app-content-wrapper{margin-left:0}}.sidebar{width:250px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;box-shadow:1px 0 3px #0000000d;z-index:1;overflow-y:auto;position:relative}@media(max-width:767px){.sidebar{display:none}}.sidebar__content{display:flex;flex-direction:column;height:100%;overflow-y:auto}.sidebar__nav{flex:1;padding:16px 0;overflow-y:auto}.sidebar__section{margin-bottom:8px}.sidebar__section-title{padding:8px 20px;font-size:.7rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.sidebar__menu-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#475569;text-decoration:none;font-size:15px;font-weight:500;transition:all .2s ease;border-left:3px solid transparent}.sidebar__menu-item:hover{background:#f8fafc;color:#0f172a}.sidebar__menu-item--active{background:#eff6ff;color:#1d4ed8;border-left-color:#3b82f6;font-weight:600}.sidebar__menu-icon{font-size:1.2rem;width:24px;text-align:center;flex-shrink:0}.sidebar__menu-label{flex:1;white-space:nowrap}.sidebar__divider{height:1px;background:#e2e8f0;margin:12px 20px}.sidebar__footer{padding:16px 20px;border-top:1px solid #e2e8f0;background:#f8fafc}.sidebar__logout-button{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:transparent;color:#64748b;font-size:15px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease}.sidebar__logout-button:hover{background:#f1f5f9;color:#ef4444}.sidebar__logout-icon{font-size:1.2rem;width:24px;text-align:center;flex-shrink:0}.sidebar__logout-label{flex:1;text-align:left}@media(max-width:767px){.sidebar{display:none!important}.app-main{margin-left:0!important}}@media(min-width:768px){.app-main{margin-left:250px}}.header{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding:0 24px;height:64px;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;flex-shrink:0;z-index:10;position:relative}.header__breadcrumbs{display:flex;align-items:center;gap:8px;font-size:.875rem;color:#64748b;min-width:0;overflow:hidden}.header__logo-mobile{display:none}.header__logo-mobile h1{margin:0;font-size:1.1rem;font-weight:700;color:#1d4ed8;white-space:nowrap}.header__breadcrumbs-desktop{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden}.header__breadcrumb{display:flex;align-items:center;gap:8px}.header__breadcrumb-separator{color:#cbd5e1}.header__breadcrumb-label{color:#0f172a;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.header__search{flex:1;max-width:600px;margin:0 auto}.header__search-container{position:relative;display:flex;align-items:center;background:#f8fafc;border:2px solid transparent;border-radius:8px;padding:8px 12px;transition:all .2s ease}.header__search-container--focused{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.header__search-icon{font-size:1.1rem;color:#64748b;margin-right:8px}.header__search-input{flex:1;border:none;background:transparent;outline:none;font-size:.9rem;color:#0f172a;padding:4px 0}.header__search-input::placeholder{color:#94a3b8}.header__search-clear{border:none;background:transparent;color:#64748b;cursor:pointer;padding:4px;margin:0 8px;font-size:.875rem;transition:color .2s ease}.header__search-clear:hover{color:#0f172a}.header__search-shortcut{display:inline-flex;align-items:center;padding:2px 6px;background:#e2e8f0;border:1px solid #cbd5e1;border-radius:4px;font-size:.75rem;font-family:monospace;color:#64748b;margin-left:8px}.header__utilities{display:flex;align-items:center;gap:12px}.header__utility-item{display:flex;align-items:center}.header__utility-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#64748b}.header__utility-button:hover{background:#f8fafc;color:#0f172a}.header__utility-icon{font-size:1.25rem}.header__utility-badge{position:absolute;top:4px;right:4px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border-radius:50%;font-size:.7rem;font-weight:600}.header__profile{position:relative}.header__profile-button{display:flex;align-items:center;gap:12px;padding:6px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease}.header__profile-button:hover{background:#f8fafc}.header__profile-avatar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#3b82f6;color:#fff;border-radius:50%;font-size:.875rem;font-weight:600}.header__profile-info{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.header__profile-role{font-size:.8rem;font-weight:600;color:#0f172a;display:flex;align-items:center;gap:6px}.header__profile-badge{padding:2px 6px;background:#fde68a;color:#92400e;border-radius:4px;font-size:.7rem;font-weight:700}.header__profile-email,.header__profile-arrow{font-size:.75rem;color:#64748b}.header__utility-button--logout-mobile{display:none}@media(max-width:767px){.header{grid-template-columns:auto 1fr auto;gap:12px;padding:0 16px;height:56px}.header__breadcrumbs-desktop{display:none}.header__logo-mobile{display:block}.header__search,.header__profile-info,.header__profile-arrow{display:none}.header__utility-button--logout-mobile{display:flex;width:auto;padding:8px 16px;font-size:.875rem;color:#ef4444;background:transparent}.header__utility-button--logout-mobile:hover{background:#fef2f2}}.fab{position:fixed;bottom:90px;right:20px;z-index:1000;display:none}@media(max-width:767px){.fab{display:block}}.fab__button{width:56px;height:56px;border-radius:50%;border:none;background:#3b82f6;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 12px #3b82f666;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.fab__button:hover{background:#2563eb;box-shadow:0 6px 16px #3b82f680;transform:scale(1.05)}.fab__button--open{background:#ef4444;transform:rotate(45deg)}.fab__button--open:hover{background:#dc2626}.fab__button-icon{display:block;transition:transform .3s ease}.fab__menu{position:absolute;bottom:70px;right:0;display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.fab__menu-item{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fff;border:none;border-radius:28px;box-shadow:0 4px 12px #00000026;cursor:pointer;transition:all .2s ease;white-space:nowrap;animation:fabMenuSlideUp .3s ease backwards;color:#0f172a;font-size:.9rem;font-weight:500}.fab__menu-item:hover{background:#f8fafc;transform:translate(-4px);box-shadow:0 6px 16px #0003}.fab__menu-icon{font-size:1.2rem}.fab__menu-label{flex:1}@keyframes fabMenuSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.topbar__logo{display:flex;align-items:center;flex-shrink:0}.topbar__logo h1{margin:0;font-size:1.25rem;font-weight:700;color:#1d4ed8;white-space:nowrap}.topbar__nav--desktop{display:flex;align-items:center;gap:8px;flex:1;justify-content:center;white-space:nowrap}.topbar__nav-link{padding:8px 16px;color:#64748b;font-weight:500;font-size:.95rem;text-decoration:none;border-radius:6px;transition:all .2s ease;position:relative;white-space:nowrap}.topbar__nav-link:hover{color:#1d4ed8;background:#f8fafc}.topbar__nav-link--active{color:#1d4ed8;font-weight:600}.topbar__nav-link--active:after{content:"";position:absolute;bottom:-1px;left:16px;right:16px;height:2px;background:#1d4ed8;border-radius:2px 2px 0 0}.topbar__user{display:flex;align-items:center;gap:16px;flex-shrink:0}.topbar__user-desktop{display:flex;align-items:center;gap:16px}.topbar__info{text-align:right;font-size:.9rem}.topbar__info .role{display:block;color:#0f172a;font-weight:600;font-size:.9rem}.topbar__info .user{color:#64748b;font-size:.85rem}.topbar__mobile-toggle{display:none;border:none;background:transparent;font-size:1.5rem;color:#64748b;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease}.topbar__mobile-toggle:hover{background:#f8fafc;color:#1d4ed8}.hamburger-icon{display:block;font-size:1.5rem;line-height:1}.mobile-menu-overlay{display:none;position:fixed;inset:64px 0 0;background:#00000080;z-index:99;animation:fadeIn .2s ease}.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:#fff;box-shadow:0 4px 6px #0000001a;z-index:100;max-height:calc(100vh - 64px);overflow-y:auto;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.mobile-menu__header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e2e8f0}.mobile-menu__header h3{margin:0;font-size:1.1rem;font-weight:600;color:#0f172a}.mobile-menu__close{border:none;background:transparent;font-size:1.5rem;color:#64748b;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.mobile-menu__close:hover{background:#f8fafc;color:#1d4ed8}.mobile-menu__nav{display:flex;flex-direction:column;padding:8px 0}.mobile-menu__link{display:block;padding:14px 24px;color:#64748b;font-weight:500;font-size:1rem;text-decoration:none;transition:all .2s ease;border-left:3px solid transparent}.mobile-menu__link:hover{background:#f8fafc;color:#1d4ed8}.mobile-menu__link--active{color:#1d4ed8;font-weight:600;background:#eef2ff;border-left-color:#1d4ed8}.mobile-menu__footer{padding:16px 24px;border-top:1px solid #e2e8f0;background:#f8fafc}.mobile-menu__user-info{margin-bottom:16px}.mobile-menu__role{display:block;color:#0f172a;font-weight:600;font-size:.9rem;margin-bottom:4px}.mobile-menu__email{display:block;color:#64748b;font-size:.85rem}.mobile-menu__actions{display:flex;flex-direction:column;gap:12px}.mobile-menu__logout{width:100%;border:none;padding:12px 16px;border-radius:6px;background:#e11d48;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease}.mobile-menu__logout:hover{background:#be123c}@media(max-width:767px){.topbar{padding:0 16px}.topbar__logo h1{font-size:1rem}.topbar__nav--desktop,.topbar__user-desktop{display:none!important}.topbar__user-mobile{display:flex!important}.mobile-menu-overlay,.mobile-menu{display:block}}@media(min-width:768px){.topbar__user-mobile{display:none!important}.topbar__nav--desktop,.topbar__user-desktop{display:flex!important}}@media(max-width:767px){.app-container{padding:0 16px}}.role-preview-toggle{display:inline-flex;border:1px solid #cbd5f5;border-radius:999px;overflow:hidden;background:#eef2ff}.role-preview-toggle__button{border:none;background:transparent;padding:6px 14px;font-size:.95rem;font-weight:600;color:#475569;cursor:pointer;transition:background .2s ease,color .2s ease}.role-preview-toggle__button--active{background:#1d4ed8;color:#fff}.role-preview-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;background:#fde68a;color:#92400e;font-size:.85rem;font-weight:700}.logout-btn{border:none;padding:8px 16px;border-radius:6px;background:#e11d48;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease}.logout-btn:hover{background:#be123c}.app-main{flex:1;width:100%;max-width:100%;overflow-y:auto;overflow-x:hidden;background:#f1f5f9;padding:0;margin:0;min-width:0;position:relative;z-index:0;box-sizing:border-box}@media(max-width:767px){.app-main{padding-bottom:86px}}.page-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 8px #0f172a0f;border:1px solid #e2e8f0;margin-bottom:16px}.page-card h2{color:#0f172a;font-size:2rem;font-weight:700;margin:0 0 12px;padding-bottom:12px;border-bottom:2px solid #f1f5f9}.page-card p{color:#64748b;margin:0 0 14px;font-size:1.15rem;line-height:1.7}.widget-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:24px}.widget{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0}.widget h3{font-size:1.4rem;font-weight:700;color:#0f172a;margin:0 0 18px}.error-text{color:#ef4444;font-weight:600;font-size:1.1rem;margin:12px 0}.helper-text{color:#1d4ed8;font-weight:600;font-size:1.1rem;margin:12px 0}.bottom-nav{grid-area:bottomnav;display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -2px 8px #0000000d;z-index:100;height:70px;padding:8px 0}@media(min-width:768px){.bottom-nav{display:none!important}}.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;border:none;background:transparent;color:#64748b;font-size:.75rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;position:relative}.bottom-nav__item:hover{color:#1d4ed8;background:#f8fafc}.bottom-nav__item--active{color:#1d4ed8;font-weight:600}.bottom-nav__item--active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:3px;background:#1d4ed8;border-radius:0 0 3px 3px}.bottom-nav__icon{font-size:1.5rem;line-height:1}.bottom-nav__label{font-size:.7rem;line-height:1;white-space:nowrap}.bottom-nav-overlay{position:fixed;inset:0;background:#00000080;z-index:101;animation:fadeIn .2s ease}.bottom-nav-menu{position:fixed;bottom:70px;left:0;right:0;background:#fff;box-shadow:0 -4px 6px #0000001a;z-index:102;max-height:calc(100vh - 70px);overflow-y:auto;animation:slideUp .3s ease;border-top-left-radius:16px;border-top-right-radius:16px}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.bottom-nav-menu__header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e2e8f0}.bottom-nav-menu__header h3{margin:0;font-size:1.1rem;font-weight:600;color:#0f172a}.bottom-nav-menu__close{border:none;background:transparent;font-size:1.5rem;color:#64748b;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.bottom-nav-menu__close:hover{background:#f8fafc;color:#1d4ed8}.bottom-nav-menu__content{display:flex;flex-direction:column;padding:8px 0}.bottom-nav-menu__link{display:block;padding:14px 24px;color:#64748b;font-weight:500;font-size:1rem;text-decoration:none;transition:all .2s ease;border-left:3px solid transparent}.bottom-nav-menu__link:hover{background:#f8fafc;color:#1d4ed8}.bottom-nav-menu__link.active{color:#1d4ed8;font-weight:600;background:#eef2ff;border-left-color:#1d4ed8}.hidden{display:none!important}.flex{display:flex!important}.items-center{align-items:center!important}.gap-2{gap:.5rem!important}@media(min-width:768px){.md\:flex{display:flex!important}.md\:hidden{display:none!important}}.logout-btn-mobile{border:none;padding:8px 16px;border-radius:6px;background:#e11d48;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s ease}.logout-btn-mobile:hover{background:#be123c}.dashboard-modern{padding:24px;width:100%;max-width:none!important;background:#f8fafc;min-height:100vh;box-sizing:border-box;margin:0!important}.goal-mini-card{background:#fff;padding:1rem;border-radius:8px;border:1px solid #e5e7eb;text-align:center}.goal-quest-widget{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb}.goal-quest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}.goal-quest-item{padding:14px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;transition:all .3s ease}.goal-quest-item:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626}.goal-quest-header{display:flex;align-items:center;gap:6px;margin-bottom:10px}.goal-quest-icon{font-size:1.1rem}.goal-quest-label{font-size:.875rem;font-weight:600;color:#1f2937;flex:1}.goal-quest-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:700;animation:pulse 2s infinite;box-shadow:0 2px 8px #fbbf2466}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.goal-quest-stats{display:flex;align-items:baseline;gap:6px;margin-bottom:8px}.goal-quest-current{font-size:1.1rem;font-weight:700;color:#1f2937}.goal-quest-separator{color:#9ca3af;font-weight:500;font-size:.875rem}.goal-quest-goal{font-size:.875rem;color:#6b7280;font-weight:500}.goal-quest-progress{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:6px;position:relative}.goal-quest-progress--gold{background:#fef3c7;box-shadow:0 0 8px #fbbf244d}.goal-quest-progress-bar{height:100%;border-radius:6px;transition:width .6s ease;position:relative;overflow:hidden}.goal-quest-progress--gold .goal-quest-progress-bar{background:linear-gradient(90deg,#fbbf24,#f59e0b,#fbbf24);background-size:200% 100%;animation:shimmer 2s infinite;box-shadow:0 0 12px #fbbf2499}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.goal-quest-percentage{font-size:.875rem;font-weight:700;color:#3b82f6;text-align:center}.goal-quest-percentage--gold{color:#f59e0b;text-shadow:0 0 8px rgba(251,191,36,.4)}.dashboard-header{margin-bottom:20px}.dashboard-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 4px}.dashboard-subtitle{font-size:.875rem;color:#64748b;margin:0}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.kpi-card{background:#fff;border-radius:8px;padding:14px 16px;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb;transition:all .2s ease}.kpi-card:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.kpi-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.kpi-card-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.kpi-card-icon{font-size:1.1rem}.kpi-card-value{font-size:1.5rem;font-weight:700;color:#0f172a;margin-bottom:4px;line-height:1.2}.kpi-card-description{font-size:.75rem;color:#94a3b8;line-height:1.3}.kpi-card--zero{opacity:.6;padding:10px 14px}.kpi-card--zero .kpi-card-value{font-size:1.25rem}.kpi-card--zero .kpi-card-description{font-size:.7rem}.kpi-card--primary{border-left:4px solid #3b82f6}.kpi-card--primary .kpi-card-value{color:#3b82f6}.kpi-card--success{border-left:4px solid #10b981}.kpi-card--success .kpi-card-value{color:#10b981}.kpi-card--info{border-left:4px solid #06b6d4}.kpi-card--info .kpi-card-value{color:#06b6d4}.kpi-card--warning{border-left:4px solid #f59e0b}.kpi-card--warning .kpi-card-value{color:#f59e0b}.kpi-card--purple{border-left:4px solid #8b5cf6}.kpi-card--purple .kpi-card-value{color:#8b5cf6}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px;margin-bottom:20px;width:100%;box-sizing:border-box}.dashboard-widget{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb;width:100%;box-sizing:border-box;min-width:0}.dashboard-widget--large{grid-column:span 2}.dashboard-widget--fullwidth{grid-column:1 / -1}.widget-header{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.widget-title{font-size:.9375rem;font-weight:600;color:#0f172a;margin:0}.widget-content{min-height:150px}.province-list-modern{display:flex;flex-direction:column;gap:16px}.province-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:8px;transition:background .2s ease}.province-item:hover{background:#f1f5f9}.province-rank{font-size:.875rem;font-weight:700;color:#64748b;min-width:32px;text-align:center}.province-info{flex:1;display:flex;justify-content:space-between;align-items:center;gap:12px}.province-name{font-size:.9375rem;font-weight:600;color:#0f172a}.province-count{font-size:.875rem;font-weight:600;color:#3b82f6}.province-bar{width:100px;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.province-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:3px;transition:width .3s ease}.partner-list-modern{display:flex;flex-direction:column;gap:12px}.partner-item{padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.partner-item:hover{background:#f1f5f9;border-color:#cbd5e1}.partner-name{font-size:.9375rem;font-weight:600;color:#0f172a;margin-bottom:12px}.partner-stats{display:flex;gap:12px;flex-wrap:wrap}.partner-stat{font-size:.8125rem;font-weight:600;padding:4px 10px;border-radius:6px}.partner-stat--upload{background:#dbeafe;color:#1e40af}.partner-stat--assigned{background:#d1fae5;color:#065f46}.partner-stat--unassigned{background:#fee2e2;color:#991b1b}.distribution-feed{display:flex;flex-direction:column;gap:12px}.distribution-item{padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.distribution-item:hover{background:#f1f5f9;border-color:#cbd5e1}.distribution-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 14px}.distribution-user{display:flex;align-items:center;gap:12px;flex:1}.distribution-user-name{font-size:.9375rem;font-weight:600;color:#0f172a}.distribution-count{font-size:.8125rem;font-weight:600;padding:4px 10px;background:#dbeafe;color:#1e40af;border-radius:6px}.distribution-date{font-size:.8125rem;color:#64748b;white-space:nowrap}.quick-actions-grid{display:flex;flex-direction:column;gap:8px}.quick-action-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;text-decoration:none;color:#0f172a;transition:all .2s ease}.quick-action-item:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translate(2px)}.quick-action-icon{font-size:1.2rem;flex-shrink:0}.quick-action-label{flex:1;font-size:.875rem;font-weight:600;color:#0f172a}.quick-action-arrow{font-size:.875rem;color:#64748b;flex-shrink:0}.dashboard-notice-banner{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.dashboard-widget--large{grid-column:span 1}.dashboard-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-modern{padding:12px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}.goal-quest-grid{grid-template-columns:1fr;gap:8px}.dashboard-grid{grid-template-columns:1fr;gap:12px}.dashboard-title,.kpi-card-value{font-size:1.25rem}.kpi-card{padding:12px}}.distribution-status-page{max-width:100%;margin:0}.db-summary-card-grid{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.db-summary-card{padding:8px 12px;border-radius:8px;border:1px solid;border-left:3px solid;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;gap:8px;flex:0 0 auto}.db-summary-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.db-summary-card--blue{background-color:#eff6ff;border-color:#bfdbfe;border-left-color:#3b82f6}.db-summary-card--orange{background-color:#fffbeb;border-color:#fde68a;border-left-color:#f59e0b}.db-summary-card--green{background-color:#ecfdf5;border-color:#a7f3d0;border-left-color:#10b981}.db-summary-card--gray{background-color:#f3f4f6;border-color:#d1d5db;border-left-color:#6b7280}.db-summary-card--red{background-color:#fef2f2;border-color:#fecaca;border-left-color:#ef4444}.db-summary-card .icon{font-size:1rem;margin:0;flex-shrink:0}.db-summary-card .label{font-size:.75rem;color:#64748b;margin:0;white-space:nowrap}.db-summary-card .value{font-size:1rem;font-weight:700;margin:0;white-space:nowrap}.db-summary-card--blue .value{color:#1d4ed8}.db-summary-card--orange .value{color:#d97706}.db-summary-card--green .value{color:#059669}.db-summary-card--gray .value{color:#374151}.db-summary-card--red .value{color:#dc2626}.db-controls{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.db-search-input{flex:1;min-width:200px;padding:10px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;outline:none;transition:border-color .2s}.db-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.db-sort-controls{display:flex;gap:8px;align-items:center}.db-select{padding:10px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;background-color:#fff;cursor:pointer;outline:none;transition:border-color .2s}.db-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.db-sort-button{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;background-color:#fff;cursor:pointer;font-size:.875rem;display:flex;align-items:center;gap:4px;transition:all .2s}.db-sort-button:hover{background-color:#f3f4f6;border-color:#9ca3af}.tel-link{color:#3b82f6;text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:all .2s;cursor:pointer}.tel-link:hover{background-color:#eff6ff;transform:scale(1.02)}.distribution-accordion{display:flex;flex-direction:column;gap:12px}.distribution-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:box-shadow .2s;box-shadow:0 1px 3px #0000001a}.distribution-item:hover{box-shadow:0 2px 8px #0000001f}.distribution-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb;transition:background-color .2s}.distribution-header:hover{background:#f3f4f6}.distribution-content{padding:16px;background:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.db-page .table-wrapper{overflow-x:auto!important;overflow-y:auto!important;width:100%!important;max-width:100%!important;margin-top:0!important;border-radius:8px!important;border:1px solid #e5e7eb!important;box-sizing:border-box!important;scrollbar-width:thin!important;scrollbar-color:#cbd5e1 #f1f5f9!important}.db-page .table-wrapper::-webkit-scrollbar{height:8px!important;width:8px!important}.db-page .table-wrapper::-webkit-scrollbar-track{background:#f1f5f9!important;border-radius:4px!important}.db-page .table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1!important;border-radius:4px!important}.db-page .table-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8!important}.db-page .table-wrapper>table.distribution-table,.db-page .table-wrapper>table.distribution-table-narrow{width:100%!important;border-collapse:collapse!important;font-size:.8125rem!important;table-layout:auto!important;position:relative!important}.db-page .table-wrapper>table.distribution-table{min-width:100%!important}.db-page .table-wrapper>table.distribution-table-narrow{min-width:750px!important}.db-page .table-wrapper>table.distribution-table>thead,.db-page .table-wrapper>table.distribution-table-narrow>thead{position:sticky!important;top:0!important;background-color:#f9fafb!important;z-index:10!important}.db-page .table-wrapper>table.distribution-table>thead>tr>th,.db-page .table-wrapper>table.distribution-table-narrow>thead>tr>th{background:#f9fafb!important;color:#1f2937!important;font-weight:600!important;padding:6px 4px!important;text-align:left!important;border-bottom:1px solid #e5e7eb!important;font-size:.75rem!important;text-transform:uppercase!important;letter-spacing:.05em!important;white-space:nowrap!important}.db-page .table-wrapper>table.distribution-table>tbody>tr>td,.db-page .table-wrapper>table.distribution-table-narrow>tbody>tr>td{border-bottom:1px solid #f3f4f6!important;padding:6px 4px!important;text-align:left!important;color:#374151!important;font-size:.8125rem!important;vertical-align:middle!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.db-page .table-wrapper>table.distribution-leads-table,.db-page .table-wrapper>table.distribution-leads-table-narrow{width:100%!important;border-collapse:collapse!important;font-size:.8125rem!important;table-layout:auto!important}.db-page .table-wrapper>table.distribution-leads-table{min-width:100%!important}.db-page .table-wrapper>table.distribution-leads-table-narrow{min-width:900px!important}.db-page .table-wrapper>table.distribution-leads-table>thead>tr>th,.db-page .table-wrapper>table.distribution-leads-table-narrow>thead>tr>th{background:#f9fafb!important;color:#1f2937!important;font-weight:600!important;padding:6px 8px!important;text-align:left!important;border-bottom:1px solid #e5e7eb!important;font-size:.75rem!important;text-transform:uppercase!important;letter-spacing:.05em!important;white-space:nowrap!important}.db-page .table-wrapper>table.distribution-leads-table>tbody>tr>td,.db-page .table-wrapper>table.distribution-leads-table-narrow>tbody>tr>td{border-bottom:1px solid #f3f4f6!important;padding:6px 8px!important;text-align:left!important;color:#374151!important;font-size:.8125rem!important;vertical-align:middle!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.db-page .table-wrapper>table>tbody>tr:hover{background:#f9fafb!important}.db-page .table-wrapper>table>tbody>tr:last-child>td{border-bottom:none!important}.status-cell{display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot--blue{background-color:#3b82f6}.status-dot--yellow{background-color:#fbbf24}.status-dot--orange{background-color:#f59e0b}.status-dot--green{background-color:#10b981}.status-dot--red{background-color:#ef4444}.status-dot--gray{background-color:#6b7280}.status-label{font-size:.875rem;color:#374151;font-weight:500}.note-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:500;white-space:nowrap}.note-badge--blue{background-color:#dbeafe;color:#1e40af}.note-badge--green{background-color:#d1fae5;color:#065f46}.note-badge--purple{background-color:#e9d5ff;color:#6b21a8}.note-badge--orange{background-color:#fed7aa;color:#9a3412}.note-badge--teal{background-color:#ccfbf1;color:#134e4a}.note-empty{color:#9ca3af;font-size:.875rem}@media(max-width:768px){.distribution-header{padding:10px 12px}.distribution-content{padding:12px;overflow-x:auto}.distribution-content .table-wrapper{min-width:800px}.distribution-content .table-wrapper th,.distribution-content .table-wrapper td{padding:6px 10px;font-size:.9rem}}.drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer-panel{position:fixed;top:0;right:0;bottom:0;width:500px;max-width:90vw;background:#fff;box-shadow:-4px 0 24px #00000026;z-index:1001;display:flex;flex-direction:column;animation:slideIn .3s ease;overflow-y:auto}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:2px solid #e2e8f0;background:#f8fafc;position:sticky;top:0;z-index:10}.drawer-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#0f172a}.drawer-close{border:none;background:transparent;font-size:1.5rem;color:#64748b;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.drawer-close:hover{background:#e2e8f0;color:#0f172a}.drawer-tabs{display:flex;border-bottom:2px solid #e2e8f0;background:#fff;position:sticky;top:80px;z-index:9}.drawer-tab{flex:1;border:none;background:transparent;padding:16px 20px;font-size:1rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.drawer-tab:hover{color:#1d4ed8;background:#f8fafc}.drawer-tab--active{color:#1d4ed8;border-bottom-color:#1d4ed8;background:#f8fafc}.drawer-content{flex:1;padding:24px;overflow-y:auto}.drawer-section{margin-bottom:32px}.drawer-section h3{margin:0 0 16px;font-size:1.2rem;font-weight:600;color:#0f172a;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item--full{grid-column:1 / -1}.info-label{font-size:.85rem;color:#64748b;font-weight:500}.info-value{font-size:1rem;color:#0f172a;font-weight:600}.log-form{display:flex;flex-direction:column;gap:16px}.log-form label{display:flex;flex-direction:column;gap:6px;font-size:.95rem;color:#0f172a;font-weight:500}.log-form input[type=text],.log-form input[type=number],.log-form input[type=date],.log-form select,.log-form textarea,.log-form input[type=datetime-local]{border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px;font-size:1rem;font-family:inherit;transition:border-color .2s ease}.log-form input[type=text]:focus,.log-form input[type=number]:focus,.log-form input[type=date]:focus,.log-form select:focus,.log-form textarea:focus,.log-form input[type=datetime-local]:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a}.log-form textarea{resize:vertical;min-height:100px}.log-form button{border:none;border-radius:8px;padding:12px 20px;background:#1d4ed8;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s ease}.log-form button:hover:not(:disabled){background:#1e40af}.log-form button:disabled{background:#94a3b8;cursor:not-allowed}.checkbox-label{flex-direction:row!important;align-items:center;gap:8px!important}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.log-timeline{display:flex;flex-direction:column;gap:16px}.log-item{padding:16px;background:#f8fafc;border-radius:8px;border-left:3px solid #1d4ed8}.log-item--important{background:#fef3c7;border-left-color:#f59e0b}.log-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.log-type{padding:4px 10px;border-radius:999px;background:#1d4ed8;color:#fff;font-size:.85rem;font-weight:600}.important-badge{padding:4px 10px;border-radius:999px;background:#f59e0b;color:#fff;font-size:.85rem;font-weight:600}.log-date{font-size:.85rem;color:#64748b}.log-user{font-size:.85rem;color:#64748b;margin-left:auto}.memo-title{font-size:1.1rem;font-weight:600;color:#0f172a;margin-bottom:8px}.log-content{color:#0f172a;line-height:1.6;margin-bottom:8px;white-space:pre-wrap}.log-schedule{font-size:.9rem;color:#059669;font-weight:500;margin-top:8px;padding-top:8px;border-top:1px solid #e2e8f0}.empty-message{text-align:center;color:#64748b;padding:40px 20px;font-size:1rem}.contracts-list{display:flex;flex-direction:column;gap:16px}.contract-item{padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.contract-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.contract-product{font-size:1.1rem;font-weight:700;color:#0f172a}.contract-status{padding:4px 12px;border-radius:999px;font-size:.85rem;font-weight:600}.contract-status--pending{background:#e2e8f0;color:#475569}.contract-status--active{background:#dcfce7;color:#166534}.contract-status--cancelled{background:#fee2e2;color:#991b1b}.contract-status--expired{background:#fef3c7;color:#92400e}.contract-details{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.contract-detail-item{display:flex;gap:8px;font-size:.95rem}.contract-detail-item--full{flex-direction:column;gap:4px}.contract-label{color:#64748b;font-weight:500;min-width:80px}.contract-value{color:#0f172a;font-weight:600}.contract-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #e2e8f0;font-size:.85rem;color:#64748b}.contract-date,.contract-user{color:#64748b}.error-text{color:#dc2626;background:#fee2e2;padding:12px;border-radius:8px;margin-bottom:16px}.files-list{display:flex;flex-direction:column;gap:12px}.file-item{padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px}.file-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.file-name{font-weight:600;color:#0f172a;font-size:.95rem}.file-category{padding:4px 10px;border-radius:999px;font-size:.85rem;font-weight:600}.file-category--recording{background:#dbeafe;color:#1e40af}.file-category--general{background:#f1f5f9;color:#475569}.file-details{display:flex;gap:12px;font-size:.85rem;color:#64748b;margin-bottom:8px}.file-size,.file-date{color:#64748b}.file-uploader{color:#64748b;margin-left:auto}.db-page{display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%;padding:16px;box-sizing:border-box;overflow-x:hidden}.db-management-top-grid{display:grid;grid-template-columns:1fr;gap:24px;width:100%;min-width:0;overflow:visible;grid-auto-rows:auto}.db-management-top-grid>.db-card{min-width:0;width:100%;max-width:100%;overflow:visible;display:block!important;visibility:visible!important;opacity:1!important;grid-column:auto;grid-row:auto}.db-card--assignment,.db-card--upload{display:block!important;visibility:visible!important;opacity:1!important}@media(min-width:1024px){.db-management-top-grid{grid-template-columns:1fr 1fr;gap:24px}}@media(min-width:768px)and (max-width:1023px){.db-management-top-grid{grid-template-columns:1fr}}.db-card{background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:18px;margin-bottom:16px;min-width:0;width:100%;box-sizing:border-box;display:block!important;visibility:visible!important;opacity:1!important}.db-card h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 10px;padding-bottom:10px;border-bottom:1px solid #f3f4f6}.db-card p{color:#6b7280;font-size:.95rem;margin:0 0 16px;line-height:1.6}.db-form,.filter-form{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}.assign-form{display:flex;flex-direction:column;gap:10px;width:100%}.db-form input[type=file]{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;background:#fff;cursor:pointer;transition:border-color .2s ease}.db-form input[type=file]:hover{border-color:#9ca3af}.db-form input[type=file]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.db-form button,.filter-form button,.assign-form button{border:none;border-radius:8px;padding:10px 20px;background:#4f46e5;color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.db-form button:hover,.filter-form button:hover,.assign-form button:hover{background:#4338ca;transform:translateY(-1px)}.db-form button:active,.filter-form button:active,.assign-form button:active{transform:translateY(0)}.filter-form label,.assign-form label{display:flex;flex-direction:column;gap:6px;font-size:.95rem;color:#374151;font-weight:500}.filter-form input,.filter-form select,.assign-form input,.assign-form select,.assign-form textarea{border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.filter-form input:focus,.filter-form select:focus,.assign-form input:focus,.assign-form select:focus,.assign-form textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.assign-form__group{display:flex;flex-direction:column;gap:8px}.assign-form__group--row{flex-direction:row;gap:12px;align-items:flex-end;flex-wrap:wrap;width:100%}.assign-form--inline{display:flex;flex-direction:column;gap:12px}.assign-form__row{display:flex;flex-direction:column;gap:12px;width:100%}@media(min-width:768px){.assign-form__row{flex-direction:row;align-items:flex-end;gap:12px}}.assign-form__field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.assign-form__field--user{flex:2;min-width:180px}.assign-form__field--quota{flex:1;min-width:100px;max-width:120px}.assign-form__field--note{flex:2;min-width:150px}.assign-form__field--button{flex:1;min-width:140px;display:flex;align-items:flex-end}.assign-form__field--button button{width:100%;white-space:nowrap;min-width:120px;padding:10px 16px!important;font-size:.875rem!important}@media(max-width:767px){.assign-form__field--button{min-width:100%;width:100%}.assign-form__field--button button{width:100%;min-width:100%}}.assign-form__button--primary{background:#4f46e5!important;color:#fff!important;border:none!important;padding:10px 20px!important;border-radius:6px!important;font-weight:600!important;cursor:pointer;transition:background .2s ease}.assign-form__button--primary:hover:not(:disabled){background:#4338ca!important}.assign-form__button--primary:disabled{background:#9ca3af!important;cursor:not-allowed;opacity:.6}.assign-form__field{flex:1;display:flex;flex-direction:column;gap:6px}.assign-form__field--narrow{flex:0 0 140px}.assign-form textarea{min-height:80px;resize:vertical}.assign-form__actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.assign-form__button{width:100%;justify-content:center;text-align:center;padding:12px 20px}.assign-form__button--outline{background:#fff;color:#4f46e5;border:1px solid #c7d2fe}.assign-form__button--outline:hover{background:#eef2ff}.table-wrapper{overflow-x:auto!important;width:100%!important;max-width:100%!important;margin-top:16px!important;border-radius:8px!important;border:1px solid #e5e7eb!important;box-sizing:border-box!important;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}.table-wrapper::-webkit-scrollbar{height:8px}.table-wrapper::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.table-wrapper table{width:100%!important;min-width:1000px!important;border-collapse:collapse!important;font-size:.875rem!important;table-layout:auto!important}.table-wrapper th{background:#f9fafb!important;color:#1f2937!important;font-weight:600!important;padding:6px 8px!important;text-align:left!important;border-bottom:1px solid #e5e7eb!important;font-size:.8125rem!important;text-transform:uppercase!important;letter-spacing:.05em!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.table-wrapper td{border-bottom:1px solid #f3f4f6!important;padding:6px 8px!important;text-align:left!important;color:#374151!important;font-size:.8125rem!important;vertical-align:middle!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.table-wrapper tbody tr:hover{background:#f9fafb!important}.helper-text{margin-top:12px;color:#4f46e5;font-weight:500;font-size:.9rem;padding:12px;background:#eef2ff;border-radius:6px;border-left:3px solid #4f46e5}.error-text{margin-top:12px;color:#dc2626;font-weight:500;font-size:.9rem;padding:12px;background:#fef2f2;border-radius:6px;border-left:3px solid #dc2626}.status-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.85rem;font-weight:600;text-align:center}.status-badge--uploaded{background:#e9d5ff;color:#6b21a8}.status-badge--assigned{background:#dbeafe;color:#1e40af}.status-badge--consulting{background:#fef3c7;color:#92400e}.status-badge--contract_success{background:#d1fae5;color:#065f46}.status-badge--contract_failed{background:#fee2e2;color:#991b1b}.status-badge--completed{background:#f3f4f6;color:#374151}.status-select{border:1px solid #cbd5e1;border-radius:6px;padding:6px 10px;font-size:.9rem;background:#fff;color:#0f172a;cursor:pointer;min-width:120px}.status-select:hover{border-color:#94a3b8}.status-select:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px #1d4ed81a}.upload-info{margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:8px;border-left:4px solid #1d4ed8}.upload-guide{margin:0 0 8px;font-size:1rem;color:#0f172a;line-height:1.6}.upload-guide strong{color:#1d4ed8}.upload-guide-sub{margin:0 0 12px;font-size:.9rem;color:#64748b;line-height:1.5}.btn-download-template{border:1px solid #1d4ed8;border-radius:6px;padding:8px 16px;background:#fff;color:#1d4ed8;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease}.btn-download-template:hover{background:#1d4ed8;color:#fff}.filter-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:0;-webkit-user-select:none;user-select:none;margin-bottom:16px}.filter-header:hover{opacity:.8}.filter-header h2{margin:0;padding:0;border:none}.filter-toggle{font-size:1.2rem;color:#6b7280;transition:transform .2s ease}.btn-accept{border:none;border-radius:6px;padding:8px 16px;background:#10b981;color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s ease}.btn-accept:hover{background:#059669}.btn-consult{border:none;border-radius:6px;padding:8px 16px;background:#4f46e5;color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.btn-consult:hover{background:#4338ca;transform:translateY(-1px)}.link-button{border:none;background:transparent;color:#1d4ed8;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.link-button:hover{color:#1e40af}.status-badge--in_progress{background:#fef3c7;color:#92400e}.note-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.note-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:600;white-space:nowrap}.note-badge--blue{background:#dbeafe;color:#1e40af}.note-badge--green{background:#d1fae5;color:#065f46}.note-badge--gray{background:#f3f4f6;color:#374151}.note-badge--yellow{background:#fef3c7;color:#92400e}.note-badge--purple{background:#e9d5ff;color:#6b21a8}.note-empty{color:#94a3b8;font-size:.9rem}.attachment-cell{text-align:center}.attachment-icon{font-size:1.2rem;cursor:pointer}.status-cell{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot--blue{background:#3b82f6}.status-dot--gray{background:#94a3b8}.status-dot--yellow{background:#f59e0b}.status-dot--orange{background:#f97316}.status-dot--green{background:#10b981}.status-dot--red{background:#ef4444}.status-label{font-size:.9rem;font-weight:600;color:#0f172a}.goals-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}.goals-section{background:#f9fafb;padding:1.5rem;border-radius:8px;border:1px solid #e5e7eb}.goals-section h3{margin-top:0;margin-bottom:1rem;color:#111827;font-size:1.25rem}.goal-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#374151;font-size:.875rem}.form-input{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.goal-achievement{display:flex;flex-direction:column;gap:1.5rem}.goal-progress-item{display:flex;flex-direction:column;gap:.5rem}.goal-progress-header{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.goal-emoji{font-size:1.25rem}.goal-label{flex:1;font-weight:500;color:#374151}.goal-count{color:#6b7280;font-size:.875rem}.goal-rate{font-weight:600;font-size:1rem;min-width:50px;text-align:right}.goal-progress-bar{width:100%;height:24px;background-color:#e5e7eb;border-radius:12px;overflow:hidden}.goal-progress-fill{height:100%;transition:width .3s ease;border-radius:12px}.goal-overall{margin-top:1rem;padding-top:1rem;border-top:2px solid #e5e7eb;text-align:center}.goal-overall-label{font-size:.875rem;color:#6b7280;margin-bottom:.5rem}.goal-overall-rate{font-size:2rem;font-weight:700;color:#3b82f6}.error-message{padding:.75rem;background-color:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b}.loading-spinner{text-align:center;padding:2rem;color:#6b7280}@media(max-width:768px){.goals-container{grid-template-columns:1fr}}.goal-setting-page{padding:24px;max-width:800px;margin:0 auto}.goal-setting-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 4px 6px #0000000d;padding:32px}.goal-setting-title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 32px;text-align:center}.goal-setting-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:.95rem}.goal-setting-success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:.95rem}.goal-setting-form{display:flex;flex-direction:column;gap:24px}.goal-form-group{display:flex;flex-direction:column;gap:8px}.goal-form-label{font-size:1.1rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:8px}.goal-input-wrapper{position:relative;display:flex;align-items:center}.goal-form-input{width:100%;padding:14px 60px 14px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:1.05rem;background:#fff;transition:all .2s ease}.goal-form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.goal-form-input::placeholder{color:#9ca3af}.goal-input-suffix{position:absolute;right:16px;color:#6b7280;font-size:.95rem;font-weight:500;pointer-events:none}.goal-form-hint{font-size:.875rem;color:#6b7280;margin:0}.goal-save-button{margin-top:16px;padding:16px 32px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:12px;font-size:1.15rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #4f46e533}.goal-save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #4f46e54d}.goal-save-button:active:not(:disabled){transform:translateY(0)}.goal-save-button:disabled{opacity:.6;cursor:not-allowed}.loading-spinner{text-align:center;padding:48px;color:#6b7280;font-size:1.1rem}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1d4ed8,#0f172a)}.login__panel{width:360px;background:#fff;border-radius:20px;padding:32px;box-shadow:0 20px 60px #0f172a33}.login__title{margin-top:0;margin-bottom:8px;font-size:1.75rem;font-weight:700;color:#0f172a}.login__title--gradient{background:linear-gradient(90deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login__subtext{color:#94a3b8;margin-top:0;margin-bottom:24px;line-height:1.5;font-weight:500;font-size:1.05rem}.login__panel p{color:#64748b;margin-top:0;margin-bottom:24px}.login__form{display:flex;flex-direction:column;gap:16px}.login__form label{color:#0f172a;font-weight:600;font-size:1rem;display:flex;flex-direction:column;gap:8px}.login__form input{border-radius:10px;border:1px solid #cbd5f5;padding:12px;font-size:1.05rem;background:#f8fafc}.login__form select{border-radius:10px;border:1px solid #cbd5f5;padding:12px;font-size:1.05rem;background:#f8fafc;appearance:none}.login__form button{border:none;border-radius:12px;padding:12px;background:#1d4ed8;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer}.login__form button:hover{background:#1c3fbf}.login__helper{margin-top:16px;color:#0f172a;text-align:center}.login__helper a{color:#1d4ed8;font-weight:600}.login__error{color:#ef4444;font-weight:600;font-size:1.05rem}.login__success{color:#10b981;font-weight:600;font-size:1.05rem}
