@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.layout-container{display:flex;height:100vh;background-color:var(--bg-main);overflow-x:hidden;position:relative}.sidebar{width:260px;background-color:var(--bg-surface);border-right:1px solid var(--border-main);display:flex;flex-direction:column;box-shadow:2px 0 8px #00000008;transition:background-color .3s ease,border-color .3s ease}.sidebar-header{padding:24px 20px;display:flex;flex-direction:column;align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border-main)}.logo-wrapper{padding:12px;background:var(--white);border-radius:16px;box-shadow:0 4px 20px #9b7bea14;display:flex;align-items:center;justify-content:center;margin-bottom:16px;border:1px solid var(--border-alt);transition:all .3s ease}body.dark .logo-wrapper{background:var(--bg-surface-alt);border-color:var(--border-main);box-shadow:0 4px 20px #0006}.role-badge{font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;background:var(--purple-light);color:var(--purple-primary);padding:3px 10px;border-radius:var(--radius-full);margin-top:10px;display:inline-block}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--gray-text);text-decoration:none;transition:all .2s ease;border-radius:var(--radius-md);font-weight:500;font-size:.95rem}.nav-item:hover{background-color:var(--purple-lighter);color:var(--purple-primary)}.nav-item.active{background-color:var(--purple-lighter);color:var(--purple-primary);font-weight:600;position:relative}.nav-item.active:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;background-color:var(--purple-primary);border-radius:0 4px 4px 0}.sidebar-footer{padding:16px;border-top:1px solid var(--border-main)}.sidebar-user{display:flex;align-items:center;gap:12px;padding:8px 0;margin-bottom:12px}.sidebar-user .user-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--purple-primary)}.sidebar-user .user-info{display:flex;flex-direction:column}.sidebar-user .user-name{font-weight:600;font-size:.9rem;color:var(--text-main)}.sidebar-user .user-role{font-size:.75rem;color:var(--gray-text)}.logout-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:transparent;border:1px solid var(--border-main);color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;transition:.2s ease;font-size:.9rem;font-weight:500}.logout-btn:hover{background-color:#ef44441a;border-color:#fca5a5;color:#ef4444}.main-content{flex:1;display:flex;flex-direction:column;overflow-x:hidden;position:relative}.topbar{height:64px;background-color:var(--bg-surface);border-bottom:1px solid var(--border-main);display:flex;justify-content:space-between;align-items:center;padding:0 28px;box-shadow:var(--shadow-sm)}.topbar-search input{padding:10px 20px;border:1px solid var(--gray-border);border-radius:var(--radius-full);width:280px;outline:none;font-size:.9rem;background:var(--gray-light);transition:.2s ease}.topbar-search input:focus{border-color:var(--purple-primary);box-shadow:0 0 0 3px var(--purple-glow);background:var(--white)}.topbar-profile{display:flex;align-items:center;gap:12px;font-weight:500;font-size:.9rem;color:var(--gray-text)}.avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--purple-light)}.page-content{flex:1;padding:28px;overflow-y:auto;background:var(--bg-main)}@media (max-width: 1024px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:10px 0 30px #0000001a}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;animation:fadeIn .3s ease}.mobile-menu-btn{display:flex!important;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border-main);color:var(--text-muted);cursor:pointer;padding:6px;margin-right:14px;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:none}.mobile-menu-btn:hover{background-color:var(--bg-surface-alt);color:var(--purple-primary)}.topbar{padding:0 16px;gap:8px}.topbar-profile span{display:none}.page-content{padding:16px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 640px){.topbar-profile{gap:8px}.avatar{width:32px;height:32px}}.sidebar-unread-badge{position:absolute;top:-8px;right:-8px;background-color:#ef4444;color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-surface);box-shadow:0 2px 4px #ef44444d;animation:pulse-badge-admin 2s infinite}@keyframes pulse-badge-admin{0%{transform:scale(1);box-shadow:0 0 #ef444466}70%{transform:scale(1.1);box-shadow:0 0 0 6px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.dashboard-container{padding-bottom:40px}.dashboard-stats-grid{display:grid;gap:20px;margin-bottom:30px}.dashboard-stats-grid.main-stats{grid-template-columns:repeat(3,1fr)}.dashboard-stats-grid.sub-stats{grid-template-columns:repeat(4,1fr)}.dashboard-charts-grid{display:grid;grid-template-columns:3fr 2fr;gap:24px;margin-bottom:30px}.dashboard-middle-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:30px}.dashboard-bottom-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}.activity-feed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 1200px){.dashboard-stats-grid.main-stats,.dashboard-stats-grid.sub-stats{grid-template-columns:repeat(2,1fr)}.dashboard-charts-grid,.dashboard-middle-grid,.dashboard-bottom-grid{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-stats-grid.main-stats,.dashboard-stats-grid.sub-stats{grid-template-columns:1fr;gap:12px}.dashboard-charts-grid,.dashboard-middle-grid,.dashboard-bottom-grid{grid-template-columns:1fr;gap:16px}.activity-feed-grid{grid-template-columns:1fr;gap:12px}.dashboard-header h1{font-size:1.5rem!important;margin-bottom:8px!important}.dashboard-header p{font-size:.85rem!important}.stat-card{padding:16px!important}.recharts-responsive-container{min-height:180px}}.nutrition-planner-container{height:calc(100vh - 120px);display:flex;flex-direction:column;position:relative}.planner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.planner-main-layout{display:flex;gap:24px;flex:1;overflow:hidden}.planner-sidebar-templates{width:280px;background:var(--bg-surface);border-radius:20px;padding:20px;border:1px solid var(--border-main);overflow-y:auto;transition:all .3s ease;position:relative}.planner-catalog-bank{width:300px;background:var(--bg-surface);border:1px solid var(--border-main);border-radius:14px;display:flex;flex-direction:column;transition:all .3s ease;position:relative}.planner-editor{flex:1;overflow-y:auto;background:var(--bg-surface-alt);border-radius:16px;padding:24px}.planner-mobile-tabs{display:none;gap:8px;margin-bottom:16px;overflow-x:auto;padding-bottom:8px}.planner-mobile-tab-btn{padding:8px 16px;border-radius:10px;border:1px solid var(--border-main);background:var(--bg-surface);color:var(--text-muted);font-weight:700;font-size:.85rem;white-space:nowrap;cursor:pointer}.planner-mobile-tab-btn.active{background:var(--purple-primary);color:#fff;border-color:var(--purple-primary)}@media (max-width: 1100px){.nutrition-planner-container{height:auto;padding-bottom:40px}.planner-header{flex-direction:column;align-items:flex-start;gap:16px}.planner-mobile-tabs{display:flex}.planner-main-layout{flex-direction:column}.planner-main-layout>div{display:none!important;width:100%!important}.planner-main-layout>div.mobile-visible{display:flex!important}.planner-main-layout .planner-editor.mobile-visible{display:block!important}.add-food-btn-mobile{display:flex!important}.planner-sidebar-templates,.planner-catalog-bank{height:auto;max-height:500px}.day-selector{overflow-x:auto;padding-bottom:8px;margin-bottom:16px}.planner-editor{padding:16px}}@media (max-width: 640px){.planner-header h1{font-size:1.4rem!important}.planner-header>div{width:100%;flex-direction:column}.planner-header button{width:100%}}body.dark .planner-sidebar-templates,body.dark .planner-catalog-bank,body.dark .planner-editor{box-shadow:0 4px 20px #0006}body.dark input,body.dark select,body.dark textarea{background-color:var(--bg-surface-alt);color:var(--text-main);border-color:var(--border-main)}body.dark .food-item-row:hover{background-color:var(--bg-surface-alt)}body.dark .meal-card{background-color:var(--bg-surface);border-color:var(--border-main);box-shadow:var(--shadow-md)}body.dark .day-btn:not(.active){background-color:var(--bg-surface-alt);color:var(--text-muted)}body.dark .nutrition-modal-content{background-color:var(--bg-surface);border-color:var(--border-main);box-shadow:var(--shadow-lg)}body.dark .empty-state-card{background-color:var(--bg-surface);border:2px dashed var(--border-main)}.meal-reorder-btn{background:var(--bg-surface)!important;border:1px solid var(--border-main)!important;color:var(--purple-primary)!important;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.meal-reorder-btn:hover:not(:disabled){background:var(--bg-surface-alt)!important;border-color:var(--purple-primary)!important;transform:translateY(-1px);box-shadow:0 4px 12px #9b7bea26}.meal-reorder-btn:active:not(:disabled){transform:translateY(0)}.meal-reorder-btn:disabled{opacity:.2!important;cursor:default;color:var(--text-muted)!important}.workout-builder-container{height:calc(100vh - 120px);display:flex;flex-direction:column;position:relative}.builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.builder-main-layout{display:flex;gap:24px;flex:1;overflow:hidden}.builder-sidebar-templates{width:280px;background:var(--bg-surface);border-radius:20px;padding:20px;border:1px solid var(--border-main);overflow-y:auto;transition:all .3s ease;position:relative}.builder-exercises-bank{width:300px;background:var(--bg-surface);border:1px solid var(--border-main);border-radius:14px;display:flex;flex-direction:column;transition:all .3s ease;position:relative}.builder-editor{flex:1;overflow-y:auto;background:var(--bg-surface-alt);border-radius:16px;padding:24px}.builder-mobile-tabs{display:none;gap:8px;margin-bottom:16px;overflow-x:auto;padding-bottom:8px}.builder-mobile-tab-btn{padding:8px 16px;border-radius:10px;border:1px solid var(--border-main);background:var(--bg-surface);color:var(--text-muted);font-weight:700;font-size:.85rem;white-space:nowrap;cursor:pointer}.builder-mobile-tab-btn.active{background:var(--purple-primary);color:#fff;border-color:var(--purple-primary)}@media (max-width: 1100px){.workout-builder-container{height:auto;padding-bottom:40px}.builder-header{flex-direction:column;align-items:flex-start;gap:16px}.builder-mobile-tabs{display:flex}.builder-main-layout{flex-direction:column}.builder-main-layout>div{display:none!important;width:100%!important}.builder-main-layout>div.mobile-visible{display:flex!important}.builder-main-layout .builder-editor.mobile-visible{display:block!important}.builder-sidebar-templates,.builder-exercises-bank{height:auto;max-height:500px}.day-selector{overflow-x:auto;padding-bottom:8px;margin-bottom:16px}.builder-table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.exercise-table{min-width:650px}}.exercise-thumbnail{width:32px;height:32px;border-radius:6px;object-fit:cover;background:var(--bg-surface-alt);border:1px solid var(--border-main)}.exercise-gallery-preview{display:flex;gap:4px;flex-wrap:wrap;max-width:120px}.modal-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px;margin-top:12px}.modal-photo-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:2px solid var(--border-main)}.modal-photo-item img{width:100%;height:100%;object-fit:cover}.modal-photo-remove{position:absolute;top:4px;right:4px;background:#00000080;color:#fff;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px}.upload-dropzone{border:2px dashed var(--border-main);border-radius:16px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-surface-alt)}.upload-dropzone:hover{border-color:var(--purple-primary);background:var(--purple-lighter)}.exercise-bank-item{transition:transform .2s,box-shadow .2s}.exercise-bank-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.description-preview{font-size:.75rem;color:var(--text-muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agenda-container{padding:0 8px}.agenda-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.agenda-header-actions{display:flex;gap:12px;flex-wrap:wrap}.agenda-nav-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}.calendar-grid-month{display:grid;grid-template-columns:repeat(7,1fr);background:var(--bg-surface-alt);border-radius:24px;overflow:hidden;border:1px solid var(--border-main);box-shadow:var(--shadow-sm)}.calendar-grid-week{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:32px}@media (max-width: 1024px){.calendar-grid-week{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.agenda-header{flex-direction:column;align-items:flex-start}.agenda-header-actions{width:100%}.agenda-header-actions button{flex:1;padding:10px!important;font-size:.8rem!important}.calendar-grid-week{grid-template-columns:repeat(2,1fr)}.calendar-grid-month{grid-template-columns:repeat(7,1fr);overflow-x:auto}.calendar-grid-month>div{min-width:80px}}@media (max-width: 480px){.calendar-grid-week{grid-template-columns:1fr}.agenda-nav-bar h3{font-size:1rem!important;order:-1;width:100%;text-align:center}.agenda-nav-bar{justify-content:center}}.agenda-modal-content{background:var(--bg-surface);border-radius:24px;padding:24px;width:95%;max-width:500px;box-shadow:var(--shadow-lg);border:1px solid var(--border-main);max-height:90vh;overflow-y:auto}body.dark .calendar-grid-month{background:var(--border-main)}body.dark .calendar-grid-month>div{background:var(--bg-surface-alt);border-color:var(--border-main)}body.dark .calendar-grid-month>div:hover{background:var(--bg-surface)!important}body.dark .calendar-grid-week>div{box-shadow:0 4px 20px #0006}body.dark .agenda-modal-content{background:var(--bg-surface);border-color:var(--border-main)}body.dark input[type=datetime-local],body.dark input[type=time],body.dark input[type=date],body.dark select,body.dark textarea{background:var(--bg-surface-alt);color:var(--text-main);border-color:var(--border-main)}body.dark input:focus,body.dark select:focus,body.dark textarea:focus{border-color:var(--purple-primary);box-shadow:0 0 0 2px var(--purple-lighter)}.chats-container{display:flex;height:calc(100vh - 100px);background:var(--bg-surface);border-radius:20px;box-shadow:0 4px 30px #0000000d;overflow:hidden;margin:10px;border:1px solid var(--border-main)}.chats-sidebar{width:350px;border-right:1px solid var(--border-main);display:flex;flex-direction:column;background:var(--bg-surface-alt)}.sidebar-search{padding:24px;display:flex;align-items:center;gap:12px;background:var(--bg-surface);border-bottom:1px solid var(--border-main)}.sidebar-search input{border:none;background:none;font-size:.95rem;color:var(--text-main);width:100%;outline:none}.conversations-list{flex:1;overflow-y:auto}.convo-item{padding:16px 24px;display:flex;gap:16px;cursor:pointer;transition:all .2s;border-bottom:1px solid var(--border-main);align-items:center}.convo-item:hover{background:var(--bg-main)}.convo-item.active{background:var(--bg-main);border-left:4px solid var(--purple-primary)}.avatar-wrapper{position:relative;flex-shrink:0}.avatar-wrapper img{width:50px;height:50px;border-radius:16px;object-fit:cover}.unread-badge{position:absolute;top:-5px;right:-5px;background:var(--purple-primary);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:8px;border:2px solid var(--bg-surface)}.convo-info{flex:1;min-width:0}.convo-header{display:flex;justify-content:space-between;margin-bottom:4px}.convo-name{font-weight:700;color:var(--text-main);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.convo-time{font-size:.75rem;color:var(--text-muted)}.convo-last-msg{font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.chat-main{flex:1;display:flex;flex-direction:column;background:var(--bg-main);position:relative}.chat-header{padding:16px 32px;background:var(--bg-surface);border-bottom:1px solid var(--border-main);display:flex;justify-content:space-between;align-items:center}.header-user{display:flex;align-items:center;gap:16px}.header-user img{width:44px;height:44px;border-radius:14px;object-fit:cover}.header-user h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-main)}.status-online{font-size:.75rem;color:var(--success);font-weight:600;display:flex;align-items:center;gap:4px}.status-online:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success)}.chat-messages{flex:1;padding:32px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;background:var(--bg-main);position:relative;z-index:1}.chat-messages:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url(https://user-images.githubusercontent.com/15075759/28719144-86dc0f70-73b1-11e7-911d-60d70fcded21.png);background-repeat:repeat;opacity:.05;z-index:-1;pointer-events:none}.message-row{display:flex;width:100%}.message-row.sent{justify-content:flex-end}.message-bubble{max-width:65%;padding:12px 18px;border-radius:18px;position:relative;box-shadow:var(--shadow-sm)}.message-row.sent .message-bubble{background:var(--purple-primary);color:#fff;border-bottom-right-radius:4px}.message-row.received .message-bubble{background:var(--bg-surface);color:var(--text-main);border-bottom-left-radius:4px}.message-bubble p{margin:0;font-size:.95rem;line-height:1.5}.message-time{font-size:.7rem;opacity:.7;display:block;margin-top:4px;text-align:right}.chat-input-wrapper{position:relative;background:var(--bg-surface);border-top:1px solid var(--border-main)}.emoji-picker-modal{position:absolute;bottom:100%;left:20px;background:var(--bg-surface);border:1px solid var(--border-main);border-radius:12px;box-shadow:var(--shadow-lg);padding:12px;margin-bottom:8px;z-index:100}.emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.emoji-item{background:none;border:none;font-size:1.4rem;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.emoji-item:hover{background:var(--bg-main);transform:scale(1.2)}.chat-input{padding:16px 32px 24px;display:flex;align-items:center;gap:16px}.icon-btn.active{color:var(--purple-primary)}.chat-input input{flex:1;border:1px solid var(--border-main);background:var(--bg-main);padding:12px 20px;border-radius:14px;outline:none;color:var(--text-main);font-size:.95rem;transition:all .2s}.chat-input input:focus{border-color:var(--purple-primary);box-shadow:0 0 0 4px var(--purple-glow)}.icon-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;transition:color .2s}.icon-btn:hover{color:var(--purple-primary)}.send-btn{background:var(--purple-primary);color:#fff;border:none;width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.send-btn:hover{transform:scale(1.05);background:var(--purple-dark)}.send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;padding:40px}.welcome-icon{width:100px;height:100px;background:var(--bg-surface-alt);border-radius:30px;display:flex;align-items:center;justify-content:center;color:var(--purple-primary);margin-bottom:24px}.chat-welcome h2{color:var(--text-main);margin-bottom:12px}.empty-state,.loading-state{padding:40px;text-align:center;color:var(--text-muted)}body.dark .chats-container{background:var(--bg-surface);border-color:var(--border-main);box-shadow:0 4px 30px #0000004d}body.dark .chats-sidebar{background:var(--bg-surface-alt);border-right-color:var(--border-main)}body.dark .sidebar-search{background:var(--bg-surface);border-bottom-color:var(--border-main)}body.dark .convo-item{border-bottom-color:var(--border-main)}body.dark .convo-item:hover{background:#ffffff08}body.dark .convo-item.active{background:#9b7bea1a}body.dark .chat-main{background:var(--bg-main)}body.dark .chat-header{background:var(--bg-surface);border-bottom-color:var(--border-main)}body.dark .chat-messages{background-color:var(--bg-main)}body.dark .chat-messages:before{opacity:.03;filter:invert(1)}body.dark .message-row.received .message-bubble{background:var(--bg-surface-alt);border-color:var(--border-main);color:var(--text-main)}body.dark .chat-input-wrapper{background:var(--bg-surface);border-top-color:var(--border-main)}body.dark .chat-input input{background:var(--bg-surface-alt)!important;border-color:var(--border-main)!important;color:var(--text-main)!important}body.dark .icon-btn{background:transparent!important;color:var(--text-muted)}body.dark .icon-btn:hover,body.dark .icon-btn.active{color:var(--purple-primary)}body.dark .send-btn{background:var(--purple-primary)!important;color:#fff!important;box-shadow:0 4px 12px #9b7bea4d}body.dark .send-btn:hover{background:var(--purple-hover)!important;transform:scale(1.05)}body.dark .send-btn:disabled{background:var(--bg-surface-alt)!important;color:var(--text-muted)!important;opacity:.4;cursor:not-allowed}body.dark .emoji-picker-modal{background:var(--bg-surface);border-color:var(--border-main);box-shadow:var(--shadow-lg)}body.dark .emoji-item:hover{background:var(--bg-surface-alt)}body.dark .chat-welcome{background:var(--bg-main)}@media (max-width: 768px){.chats-container{height:calc(100vh - 80px);margin:0;border-radius:0;border-right:none;border-left:none}.chats-sidebar{width:100%;border-right:none}.sidebar-search{padding:16px}.convo-item{padding:12px 16px}.chat-main{width:100%}.chat-header{padding:12px 16px}.chat-messages{padding:16px;gap:12px}.message-bubble{max-width:85%;padding:10px 14px}.chat-input{padding:12px 16px 16px;gap:10px}.send-btn{width:40px;height:40px;flex-shrink:0}.mobile-hidden{display:none!important}.chats-container.is-mobile{background:var(--bg-main)}}.assignments-manager{padding:24px;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:32px;display:flex;justify-content:space-between;align-items:flex-end}.header-info h1{font-size:2.2rem;font-weight:800;margin:0;background:linear-gradient(135deg,var(--text-main),var(--purple-primary));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-info p{color:var(--text-muted, #94a3b8);margin:8px 0 0;font-weight:500}.search-box{display:flex;align-items:center;gap:12px;background:var(--bg-surface);padding:12px 20px;border-radius:16px;border:1px solid var(--border-main);box-shadow:var(--shadow-main);width:320px}.search-box input{border:none;outline:none;width:100%;font-weight:600;color:var(--text-main);background:transparent}.planning-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;background:var(--bg-surface);padding:16px 24px;border-radius:20px;border:1px solid var(--border-main);box-shadow:var(--shadow-main)}.month-navigation{display:flex;align-items:center;gap:16px}.month-navigation button{background:var(--bg-surface-alt);border:1px solid var(--border-main);width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--text-muted)}.month-navigation button:hover{background:var(--purple-primary);color:#fff;border-color:var(--purple-primary)}.current-month-label{font-size:1.1rem;font-weight:800;color:var(--text-main);min-width:180px;text-align:center}.legend{display:flex;gap:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:700;color:var(--text-muted)}.badge-d,.badge-w{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem}.badge-d{background:var(--purple-primary)}.badge-w{background:var(--bg-surface-alt);border:1px solid var(--border-main);color:var(--text-main)}.planning-table-container{background:var(--bg-surface);border-radius:24px;border:1px solid var(--border-main);box-shadow:var(--shadow-main);overflow:hidden}.planning-table{width:100%;border-collapse:collapse}.planning-table th{padding:20px;text-align:left;background:var(--bg-surface-alt);color:var(--text-muted);font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-main)}.planning-table td{padding:16px 20px;border-bottom:1px solid var(--border-alt)}.client-col{width:250px;position:sticky;left:0;background:var(--bg-surface-alt);z-index:10}.client-cell{position:sticky;left:0;background:var(--bg-surface);z-index:5}.client-info-box{display:flex;align-items:center;gap:12px}.client-initials{width:44px;height:44px;background:linear-gradient(135deg,var(--purple-primary),var(--purple-light));color:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:800;box-shadow:0 4px 10px #9b7bea4d}.client-name{font-weight:700;color:var(--text-main);font-size:.95rem}.client-plan-name{font-size:.75rem;color:#94a3b8;font-weight:600;margin-top:2px}.month-cell-item{min-width:180px}.cell-slots{display:flex;flex-direction:column;gap:10px}.assignment-slot-container{padding:10px;border-radius:18px;border:1px dashed var(--border-main);background:var(--bg-surface-alt);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:48px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.assignment-slot-container:hover{border-color:var(--purple-light);background:var(--bg-surface);box-shadow:var(--shadow-main)}.assignment-slot-container.can-drop{border-color:var(--purple-primary);background:var(--bg-surface-alt);animation:borderPulse 1.5s infinite}.assignment-slot-container.plan-restricted{background:var(--bg-surface-alt);opacity:.6}.slot-header{display:flex;align-items:center;gap:6px;font-size:.7rem;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.assignment-slot-container.diet .slot-header{color:#9b7bea99}.assignment-slot-container.workout .slot-header{color:#475569}.upsell-badge{background:#1e293b;color:gold;padding:1px 5px;border-radius:4px;font-size:.55rem;margin-left:auto}.stacked-items{display:flex;flex-direction:column;gap:6px}.assigned-item-card{background:var(--bg-surface);border:1px solid var(--border-main);padding:8px 10px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-main);transition:all .2s;animation:slideIn .3s ease-out}.assigned-item-card:hover{transform:scale(1.02);border-color:#9b7bea33}.item-info{display:flex;flex-direction:column;min-width:0}.item-title{font-size:.8rem;font-weight:800;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-meta{font-size:.65rem;color:#94a3b8;font-weight:600}.item-remove{background:var(--error-light);color:var(--error);border:none;width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.6;transition:all .2s}.item-remove:hover{opacity:1;background:#ef4444;color:#fff}.empty-slot-text{font-size:.9rem;color:#cbd5e1;text-align:center;font-weight:500}@keyframes slideIn{0%{opacity:0;transform:translate(-5px)}to{opacity:1;transform:translate(0)}}@keyframes borderPulse{0%{border-color:#9b7bea66}50%{border-color:#9b7bea}to{border-color:#9b7bea66}}.templates-library{background:var(--bg-surface);border-radius:24px;padding:24px;margin-bottom:32px;border:1px solid var(--border-main);box-shadow:var(--shadow-lg)}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.library-title{display:flex;align-items:center;gap:12px}.glow-icon{color:#9b7bea;filter:drop-shadow(0 0 8px rgba(155,123,234,.5))}.library-title h2{margin:0;font-size:1.2rem;font-weight:800;color:var(--text-main)}.active-selection-badge{background:#9b7bea;color:#fff;padding:8px 16px;border-radius:12px;display:flex;align-items:center;gap:12px;font-size:.9rem;font-weight:700;cursor:pointer;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #9b7bea66}70%{box-shadow:0 0 0 10px #9b7bea00}to{box-shadow:0 0 #9b7bea00}}.clear-selection{background:#fff3;border:none;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px}.library-tabs{display:flex;flex-direction:column;gap:16px}.library-column{display:flex;align-items:center;gap:16px;min-height:0}.library-column h3{font-size:.8rem;font-weight:800;color:#64748b;margin:0;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;min-width:170px}.library-scroll{display:flex;gap:10px;overflow-x:auto;padding:4px 4px 8px;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent;flex:1;min-width:0}.library-scroll::-webkit-scrollbar{height:5px}.library-scroll::-webkit-scrollbar-thumb{background:#d4d4d8;border-radius:10px}.library-scroll::-webkit-scrollbar-track{background:transparent}.lib-card{min-width:160px;background:var(--bg-surface-alt);border:1px solid var(--border-main);padding:10px 14px;border-radius:14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-main);flex-shrink:0}.lib-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #0000000d}.lib-card.selected{border-color:#9b7bea;background:#f7f3fe;box-shadow:0 8px 16px #9b7bea26}.lib-card.diet:hover{border-color:#9b7bea66}.lib-card.workout:hover{border-color:#1a1a1a44}.lib-card-info{display:flex;flex-direction:column;gap:2px}.lib-card-title{font-size:.85rem;font-weight:800;color:var(--text-main);white-space:nowrap}.lib-card-meta{font-size:.75rem;font-weight:700;color:#9b7bea}.lib-card.workout .lib-card-meta{color:#64748b}.assignment-slot.can-drop{border-color:var(--purple-primary);background:var(--purple-lighter);border-style:solid;animation:borderPulse 1.5s infinite}@keyframes borderPulse{0%{border-color:#9b7bea44}50%{border-color:#9b7bea}to{border-color:#9b7bea44}}.assignment-slot.locked{opacity:.4;cursor:not-allowed;background:var(--bg-surface-alt);filter:grayscale(1);border-style:solid}.assignment-slot.locked:after{content:"🔒";position:absolute;right:8px;top:8px;font-size:10px}.global-loader{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;background:var(--bg-surface);padding:40px;border-radius:32px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;border:1px solid var(--border-main)}.spin{animation:rotate 1s linear infinite;color:#9b7bea}@keyframes rotate{to{transform:rotate(360deg)}}.global-loader p{font-weight:800;color:#9b7bea;margin-top:16px;letter-spacing:1px}.assignment-toast{position:absolute;top:100%;left:0;margin-top:12px;display:flex;align-items:center;gap:10px;padding:10px 20px;border-radius:12px;font-size:.95rem;font-weight:600;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.1);animation:slideDownIn .3s cubic-bezier(.4,0,.2,1);z-index:100;box-shadow:0 10px 25px #0006;pointer-events:none;white-space:nowrap}.assignment-toast.info{background:#3b82f640;color:#60a5fa;border-color:#3b82f666}.assignment-toast.success{background:#10b98140;color:#34d399;border-color:#10b98166}.status-dot{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;margin-left:8px;font-size:11px;transition:all .2s ease}.status-dot.success{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.status-dot.warning{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}@keyframes slideDownIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}:root{--purple-primary: #9B7BEA;--purple-hover: #8A6AD9;--purple-dark: #6E55C7;--purple-glow: rgba(155, 123, 234, .4);--purple-gradient: linear-gradient(135deg, #9B7BEA 0%, #BFA7F5 100%);--purple-light: rgba(155, 123, 234, .15);--purple-lighter: rgba(155, 123, 234, .08);--bg-main: #f7f8fa;--bg-surface: #ffffff;--bg-surface-alt: #f1f5f9;--text-main: #1a1a1a;--text-muted: #64748b;--text-inverse: #ffffff;--border-main: #e8eaed;--border-alt: #f1f5f9;--shadow-main: 0 4px 14px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .1);--shadow-purple: 0 8px 20px rgba(155, 123, 234, .2);--success: #10b981;--success-light: rgba(16, 185, 129, .1);--success-bg: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-light: rgba(245, 158, 11, .1);--error: #ef4444;--error-light: rgba(239, 68, 68, .1);--error-bg: rgba(239, 68, 68, .1);--info: #3b82f6;--info-light: rgba(59, 130, 246, .1);--white: #ffffff;--black: #0f172a;--gray-light: #f7f8fa;--gray-text: #64748b;--gray-border: #e8eaed;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 24px;--radius-full: 9999px}:root body.dark{--bg-main: #020617;--bg-surface: #0f172a;--bg-surface-alt: #1e293b;--text-main: #f8fafc;--text-muted: #94a3b8;--text-inverse: #000000;--border-main: rgba(255, 255, 255, .08);--border-alt: rgba(255, 255, 255, .04);--shadow-main: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .6);--shadow-purple: 0 10px 30px rgba(155, 123, 234, .3);--success: #10b981;--success-light: rgba(16, 185, 129, .15);--success-bg: rgba(16, 185, 129, .15);--warning: #fbbf24;--warning-light: rgba(251, 191, 36, .15);--error: #f87171;--error-light: rgba(248, 113, 113, .15);--error-bg: rgba(248, 113, 113, .15);--info: #60a5fa;--info-light: rgba(96, 165, 250, .15);--white: #0f172a;--black: #ffffff;--gray-light: #000000;--gray-text: #94a3b8;--gray-border: rgba(255, 255, 255, .1);--purple-lighter: rgba(155, 123, 234, .15);background-color:var(--bg-main);color:var(--text-main)}body.dark .layout-container,body.dark .main-content,body.dark .page-content{background-color:var(--bg-main)}body.dark .sidebar{background-color:var(--bg-surface);border-right-color:var(--border-main)}body.dark .sidebar-header,body.dark .topbar{background-color:var(--bg-surface)!important;border-bottom-color:var(--border-main)}body.dark .nav-item{color:var(--text-muted)}body.dark .nav-item:hover,body.dark .nav-item.active{background-color:#9b7bea33;color:#c4b5fd}body.dark .card,body.dark div[style*="background: white"],body.dark div[style*="background: #fff"],body.dark div[style*="background:white"]{background:var(--bg-surface)!important;border-color:var(--border-main)!important;color:var(--text-main)!important;box-shadow:var(--shadow-main)!important}body.dark input,body.dark select,body.dark textarea{background:var(--bg-surface-alt)!important;color:var(--text-main)!important;border-color:var(--border-main)!important}body.dark .glass-card{background:#0f172acc!important;-webkit-backdrop-filter:blur(12px)!important;backdrop-filter:blur(12px)!important;border:1px solid var(--border-main)!important}body.dark table{background:var(--bg-surface)}body.dark thead tr{background:#050505!important}body.dark th{color:var(--text-muted)!important;border-bottom-color:var(--border-main)!important}body.dark td{color:var(--text-main)!important;border-bottom-color:var(--border-main)!important}body.dark button[style*="background: #f1f5f9"],body.dark button[style*="background: #f8fafc"],body.dark button[style*="background: white"],body.dark button[style*="background: #fff"],body.dark button[style*="background:white"]{background:#334155!important;color:#e2e8f0!important;border-color:#475569!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}body.dark .modal-overlay{background:#000000b3}.modal-content{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-main);box-shadow:var(--shadow-lg);position:relative;max-height:90vh;overflow-y:auto;color:var(--text-main)}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--gray-light);color:var(--black)}code{font-family:JetBrains Mono,source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c4c4c4;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}@keyframes pulse-yellow{0%{box-shadow:0 0 #ffd70066;background-color:#ffd7000d}70%{box-shadow:0 0 0 10px #ffd70000;background-color:#ffd70033}to{box-shadow:0 0 #ffd70000;background-color:#ffd7000d}}.pulse-yellow-bg{animation:pulse-yellow 2s infinite}.btn-template-edit{padding:6px;background:var(--bg-surface);border:1px solid var(--border-main);border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;outline:none}.btn-template-edit:hover{border-color:var(--purple-primary);color:var(--purple-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}body.dark .btn-template-edit{background:#fff!important;color:#0f172a!important;border:none;box-shadow:0 4px 12px #ffffff26}body.dark .btn-template-edit:hover{background:#f8fafc!important;transform:translateY(-2px);box-shadow:0 6px 15px #ffffff40}
