@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap";.dashboard-layout{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;height:100vh;background:var(--surface);display:flex;flex-direction:column;transition:width .3s ease,background-color .3s ease,border-color .3s ease;z-index:100}.sidebar.open{width:var(--sidebar-width)}.sidebar.closed{width:70px}.sidebar-header{height:100px;display:flex;align-items:center;justify-content:center;padding:0;position:relative;transition:all .3s ease}.logo-container{display:flex;align-items:center;width:100%;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar.open .logo-container{justify-content:flex-start;padding-left:2rem}.sidebar.closed .logo-container{justify-content:center;padding-left:0}.sidebar-logo{height:40px;width:auto;max-width:100%;object-fit:contain;transition:all .3s cubic-bezier(.4,0,.2,1)}.sidebar-toggle-floating{position:absolute;right:-15px;top:25px;width:30px;height:30px;background:var(--surface);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:101;box-shadow:0 2px 8px #00000026;transition:all .2s cubic-bezier(.4,0,.2,1)}.sidebar-toggle-floating:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:scale(1.1)}.sidebar.closed .sidebar-toggle-floating{right:-15px}.sidebar-nav{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1;justify-content:space-between}.nav-main,.nav-bottom{display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--text-secondary);text-decoration:none;border-radius:.5rem;transition:all .2s;font-size:.875rem;font-weight:500}.nav-item:hover{background-color:var(--background);color:var(--text-primary)}.nav-item.active{color:var(--primary-color);font-weight:600}.nav-group{display:flex;flex-direction:column;gap:.25rem}.nav-group-title{width:100%;border:none;background:transparent;text-align:left;cursor:pointer}.nav-group-chevron{margin-left:auto;color:var(--text-secondary);transition:transform .2s ease}.nav-group-chevron.open{transform:rotate(180deg)}.nav-submenu{position:relative;display:flex;flex-direction:column;gap:.25rem;margin-left:1rem;padding-left:1.75rem}.nav-submenu:before{content:"";position:absolute;left:.75rem;top:.1rem;bottom:.55rem;width:2px;background:var(--border-color)}.nav-sub-item{position:relative;text-decoration:none;color:var(--text-secondary);font-size:.8125rem;font-weight:500;border-radius:.5rem;padding:.45rem .75rem;transition:all .2s}.nav-sub-item:before{content:"";position:absolute;left:-1rem;top:50%;width:.85rem;height:2px;transform:translateY(-50%);background:var(--border-color)}.nav-sub-item:hover{background-color:var(--background);color:var(--text-primary)}.nav-sub-item.active{color:var(--primary-color);font-weight:600;background-color:var(--background)}.nav-item.logout-item{color:#ff6b6b}.nav-item.logout-item:hover{background-color:#ff6b6b1a;color:#ff5252}.sidebar.closed .nav-item{justify-content:center;padding:.75rem 0}.sidebar.closed .nav-item svg{width:24px;height:24px}.sidebar.closed .nav-item span,.sidebar.closed .nav-submenu{display:none}.main-content{flex:1;transition:margin-left .3s ease}.main-content.sidebar-open{margin-left:var(--sidebar-width)}.main-content.sidebar-closed{margin-left:70px}.header{height:var(--header-height);background:var(--surface);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:50;transition:background-color .3s ease,border-color .3s ease}.header-left,.header-right{display:flex;align-items:center;gap:1rem}.search-bar{display:flex;align-items:center;gap:.5rem;background:var(--background);padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--border-color);transition:background-color .3s ease,border-color .3s ease}.search-bar input{border:none;background:none;outline:none;width:250px;font-size:.875rem;color:var(--text-primary);transition:color .3s ease}.search-bar input::placeholder{color:var(--text-secondary)}.icon-button{position:relative;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-button:hover{background-color:var(--background);color:var(--text-primary)}.notification-badge{position:absolute;top:0;right:0;background:var(--danger);color:#fff;font-size:.625rem;font-weight:600;padding:.125rem .375rem;border-radius:9999px;min-width:18px;text-align:center}.user-menu{display:flex;align-items:center;gap:1rem;padding-left:.75rem}.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--border-color)}.user-info{display:flex;flex-direction:column}.greeting-text{font-size:.75rem;color:var(--text-secondary)}.user-name{font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.2}.logout-btn{color:#ef4444!important;transition:all .2s}.logout-btn:hover{background:#ef44441a!important;transform:scale(1.05)}.content{padding:2rem;min-height:calc(100vh - var(--header-height))}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0!important}.search-bar{display:none}}.dashboard{max-width:1400px}.page-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--surface);padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.stat-icon{width:56px;height:56px;border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1}.stat-title{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.stat-value{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.375rem}.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:.5rem;transition:background-color .2s}.activity-item:hover{background-color:var(--background)}.activity-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0;overflow:hidden}.activity-details{flex:1}.activity-user{font-weight:600;font-size:.875rem;color:var(--text-primary);margin-bottom:.125rem}.activity-action{font-size:.75rem;color:var(--text-secondary)}.activity-time{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.quick-stats{display:flex;flex-direction:column;gap:1.5rem}.quick-stat-item{display:flex;flex-direction:column;gap:.5rem}.quick-stat-label{font-size:.875rem;color:var(--text-secondary)}.quick-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.progress-bar{height:8px;background:var(--background);border-radius:9999px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-color);border-radius:9999px;transition:width .3s ease}@media (max-width: 768px){.stats-grid,.content-grid{grid-template-columns:1fr}}.vendors-page{padding:0;display:flex;flex-direction:column;min-height:calc(100vh - var(--header-height) - 2rem);margin-bottom:-2rem}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.page-header p{color:var(--text-secondary);font-size:.875rem}.page-actions{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:250px;padding:.625rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background:var(--surface);color:var(--text-primary);transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--primary-color)}.filter-group{display:flex;gap:.75rem;align-items:center}.filter-select{padding:.625rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.filter-select:focus{outline:none;border-color:var(--primary-color)}.vendors-table-container{background:var(--surface);border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a;flex:1;display:flex;flex-direction:column}.vendors-table{width:100%;border-collapse:collapse;flex:1}.vendors-table thead{background:var(--background)}.vendors-table th{text-align:left;padding:1rem 1.5rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.vendors-table td{padding:.75rem 1.5rem;font-size:.875rem;border-top:1px solid var(--border-color);color:var(--text-primary)}.vendors-table tbody tr{transition:background-color .2s}.vendors-table tbody tr:hover{background-color:var(--background)}.vendor-info{display:flex;align-items:center;gap:.75rem}.vendor-avatar{width:40px;height:40px;border-radius:.5rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;flex-shrink:0;overflow:hidden}.vendor-logo{width:100%;height:100%;object-fit:cover}.vendor-details{flex:1;min-width:0}.vendor-name{font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.vendor-location{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.vendor-type-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:var(--background);color:var(--text-primary)}.rating-display{display:flex;align-items:center;gap:.375rem}.rating-stars{display:flex;align-items:center;gap:.125rem;color:var(--warning)}.rating-value{font-weight:600;color:var(--text-primary)}.status-badge{display:inline-flex;align-items:center;padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-badge.shown{background-color:#d1fae5;color:#065f46}.status-badge.hidden{background-color:#fee2e2;color:#991b1b}.metric-value{font-weight:600;color:var(--text-primary)}.metric-label{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.table-actions{display:flex;gap:.5rem;align-items:center}.action-btn{padding:.5rem;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:.375rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:var(--background);color:var(--primary-color)}.action-btn.danger:hover{color:var(--danger)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.pagination-info{font-size:.875rem;color:var(--text-secondary)}.pagination-buttons{display:flex;gap:.5rem}.pagination-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--surface);color:var(--text-primary);border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--background);border-color:var(--primary-color);color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state-icon{width:64px;height:64px;margin:0 auto 1rem;opacity:.5}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-input,.form-textarea,.form-select{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background:var(--background);color:var(--text-primary);transition:border-color .2s}.form-textarea{resize:vertical;min-height:80px}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #02c0a71a}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.btn-secondary{padding:.625rem 1.25rem;border:1px solid var(--border-color);background:var(--surface);color:var(--text-primary);border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--background)}.btn-primary{padding:.625rem 1.25rem;border:none;background:var(--primary-color);color:#fff;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background:var(--primary-dark)}@media (max-width: 768px){.page-actions{flex-direction:column;align-items:stretch}.search-input{width:100%}.filter-group{width:100%;justify-content:space-between}.vendors-table-container{overflow-x:auto}.vendors-table{min-width:800px}.form-row{grid-template-columns:1fr}}.plans-page{padding:0}.page-actions{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1.5rem}.page-actions .btn-primary{display:inline-flex;align-items:center;gap:.4rem}.filter-group{display:flex;align-items:center;gap:.75rem}.toast{position:fixed;right:1.5rem;bottom:1.5rem;max-width:360px;padding:.75rem 1rem;border-radius:.75rem;box-shadow:0 10px 20px #0f172a40;font-size:.875rem;font-weight:500;color:#0f172a;background:#ecfdf3;border:1px solid #bbf7d0;z-index:9999;animation:toast-in .2s ease-out}.toast.error{background:#fef2f2;border-color:#fecaca;color:#7f1d1d}.loading-state{display:flex;align-items:center;gap:.75rem;padding:2rem;color:var(--text-secondary);font-size:.9rem}.loading-spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(148,163,184,.4);border-top-color:var(--primary-color);animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.plan-card{background:var(--surface);border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .3s;cursor:pointer;border:2px solid transparent;display:flex;flex-direction:column;position:relative}.plan-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.plan-card-header{padding:.9rem 1rem;border-bottom:1px solid var(--border-color)}.plan-card-thumbnail{width:100%;height:180px;overflow:hidden;background:var(--border-color);flex-shrink:0}.plan-card-thumbnail-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.plan-card:hover .plan-card-thumbnail-img{transform:scale(1.04)}.plan-card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.plan-card-category{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:var(--primary-color);color:#fff}.plan-card.status-draft .plan-card-category{background:#e5e7eb;color:#4b5563}.plan-card.status-draft .activity-number{background:#d1d5db;color:#374151}.plan-card.status-draft .toggle-switch input:checked+.toggle-slider{background-color:#d1d5db}.plan-card.status-draft .toggle-label{color:#6b7280}.plan-card-body{padding:.75rem 1rem}.plan-activities-row{display:flex;align-items:center;gap:.75rem}.stacked-avatars{display:flex;align-items:center}.stacked-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary-color);color:#fff;font-size:.7rem;font-weight:600;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);margin-left:-8px;flex-shrink:0}.stacked-avatars .stacked-avatar:first-child{margin-left:0}.stacked-avatar-overflow{background:var(--border-color);color:var(--text-secondary)}.activities-count-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.plan-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0;background:#0f766e0f}.placeholder-icon{width:56px;height:56px;border-radius:999px;background:#0f766e1a;display:flex;align-items:center;justify-content:center;font-size:28px}.placeholder-text{font-size:.9rem;font-weight:600;color:#0f172a}.plan-activity-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--background);border-radius:.5rem;font-size:.8125rem}.activity-number{width:20px;height:20px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.activity-vendor-name{color:var(--text-primary);font-weight:500;flex:1}.activity-duration{color:var(--text-secondary);font-size:.75rem}.activity-main{display:flex;flex-direction:column;flex:1;min-width:0}.activity-title-text{color:var(--text-primary);font-weight:500;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.activity-meta{color:var(--text-secondary);font-size:.7rem}.plan-card-footer{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;padding:.9rem 1rem 1rem;border-top:1px solid var(--border-color)}.plan-stat{text-align:center}.plan-stat-value{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.plan-stat-label{font-size:.6875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.plan-card-actions{display:flex;justify-content:space-between;align-items:center;padding:0 1.25rem 1.25rem}.plan-publish-toggle{display:flex;align-items:center;gap:.5rem}.toggle-switch{position:relative;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background-color:var(--border-color);transition:.3s;border-radius:24px}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary-color)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.plan-action-buttons{display:flex;gap:.5rem}.plan-modal{max-width:900px}.activities-editor{margin-top:1.5rem}.activities-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.activities-editor-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.add-activity-btn{padding:.5rem 1rem;border:1px dashed var(--border-color);background:none;color:var(--primary-color);border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.add-activity-btn:hover{background:var(--background);border-color:var(--primary-color)}.activities-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.activity-editor-item{padding:1rem;background:var(--background);border:1px solid var(--border-color);border-radius:.5rem;transition:all .2s}.activity-editor-item.dragging{opacity:.5;border-color:var(--primary-color)}.activity-editor-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.drag-handle{cursor:grab;color:var(--text-secondary);padding:.25rem}.drag-handle:active{cursor:grabbing}.activity-order-number{width:32px;height:32px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.activity-title{flex:1;font-weight:600;color:var(--text-primary)}.remove-activity-btn{padding:.375rem;border:none;background:none;color:var(--danger);cursor:pointer;border-radius:.375rem;transition:all .2s}.remove-activity-btn:hover{background:#ef44441a}.activity-editor-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.price-calculator{margin-top:1rem;padding:1rem;background:var(--background);border-radius:.5rem;border:1px solid var(--border-color)}.price-calculator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.calculator-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.calculator-total{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.calculator-breakdown{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.view-mode-toggle{display:flex;gap:.5rem;padding:.25rem;background:var(--background);border-radius:.5rem}.view-mode-btn{padding:.5rem 1rem;border:none;background:none;color:var(--text-secondary);border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.view-mode-btn.active{background:var(--surface);color:var(--primary-color);box-shadow:0 1px 3px #0000001a}.plans-list{background:var(--surface);border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.plan-list-item{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);transition:background-color .2s;cursor:pointer}.plan-list-item:last-child{border-bottom:none}.plan-list-item:hover{background-color:var(--background)}.plan-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.plan-list-main{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.plan-list-avatar-wrapper{width:48px;height:48px;border-radius:999px;background:#eef2ff;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.plan-list-avatar-image{width:100%;height:100%;object-fit:cover}.plan-list-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#4b5563}.plan-list-info{flex:1}.plan-list-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.plan-list-meta{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:var(--text-secondary)}.plan-list-stats{display:flex;gap:1.5rem;align-items:center}.plan-list-stat{text-align:center}@media (max-width: 768px){.plans-grid,.activity-editor-fields{grid-template-columns:1fr}.plan-list-header{flex-direction:column;gap:1rem}.plan-list-stats{width:100%;justify-content:space-around}}.categories-page{padding:0}.modal{background:var(--surface);border-radius:.75rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{padding:.5rem;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:.375rem;transition:all .2s}.modal-close:hover{background:var(--background);color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.modal .form-group{margin-bottom:1.25rem}.modal .form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.modal .form-input,.modal .form-textarea,.modal .form-select{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background:var(--background);color:var(--text-primary);transition:border-color .2s}.modal .form-textarea{resize:vertical;min-height:80px}.modal .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.modal .btn-primary,.modal .btn-secondary{padding:.625rem 1.25rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer}.modal .btn-primary{background:var(--primary-color);color:#fff;border:none}.modal .btn-secondary{border:1px solid var(--border-color);background:var(--surface);color:var(--text-primary)}.category-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.category-card{background:var(--surface);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .2s;cursor:pointer;border:2px solid transparent}.category-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.category-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.category-icon{width:48px;height:48px;border-radius:.75rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}.category-actions{display:flex;gap:.5rem}.category-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.category-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.5}.category-stats{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-color)}.category-plans-count{font-size:.875rem;color:var(--text-secondary)}.category-plans-count strong{color:var(--primary-color);font-weight:600}.category-modal{max-width:700px}@media (max-width: 768px){.category-cards,.vendor-type-selectors,.range-inputs{grid-template-columns:1fr}}.users-page{max-width:1400px;display:flex;flex-direction:column;min-height:calc(100vh - var(--header-height) - 2rem);margin-bottom:-2rem}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.users-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:.5rem;background:var(--surface);padding:.625rem 1rem;border-radius:.5rem;border:1px solid var(--border-color);flex:1;max-width:none}.search-box input{border:none;background:none;outline:none;width:100%;font-size:.875rem}.filter-buttons{display:flex;gap:.5rem}.card{background:var(--surface);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:background-color .3s ease,box-shadow .3s ease;flex:1;display:flex;flex-direction:column}.table-container{overflow-x:auto;flex:1}.user-cell{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0;overflow:hidden}.user-avatar img,.user-avatar .user-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.user-name{font-weight:600;color:var(--text-primary);font-size:.875rem}.user-email{font-size:.75rem;color:var(--text-secondary)}.contact-cell{display:flex;flex-direction:column;gap:.375rem}.contact-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-secondary)}.action-buttons{display:flex;gap:.5rem}.icon-btn{background:none;border:1px solid var(--border-color);padding:.5rem;border-radius:.375rem;cursor:pointer;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background-color:var(--background);color:var(--text-primary)}.icon-btn.danger:hover{background-color:#fee2e2;color:var(--danger);border-color:var(--danger)}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color);background:var(--surface)}.page-numbers{display:flex;gap:.5rem}.page-number{background:var(--surface);border:1px solid var(--border-color);padding:.5rem .875rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .2s}.page-number:hover{background-color:var(--background)}.page-number.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width: 768px){.page-header{flex-direction:column}.users-controls{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.filter-buttons{justify-content:stretch}.filter-buttons button{flex:1}}.settings-page{max-width:1200px}.settings-container{display:block}.settings-tabs{display:flex;flex-direction:column;gap:.5rem}.tab-button{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--surface);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.tab-button:hover{background-color:var(--background);color:var(--text-primary)}.tab-button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.settings-content{background:var(--surface);border:1px solid var(--border-color);border-radius:.75rem;padding:2rem}.settings-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.section-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.profile-field{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--background);border:1px solid var(--border-color);border-radius:.5rem;font-size:.9375rem}.profile-value{color:var(--text-primary);flex:1}.profile-password{flex-wrap:wrap}.profile-password-value{letter-spacing:.15em}.btn-reveal-password{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:var(--surface);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:color .2s,border-color .2s}.btn-reveal-password:hover{color:var(--primary-color);border-color:var(--primary-color)}.password-verified-badge{display:inline-block;margin-top:.5rem;padding:.25rem .5rem;background:var(--primary-color);color:#fff;font-size:.75rem;font-weight:600;border-radius:.25rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--surface);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 20px 40px #00000026}.profile-verify-modal h3{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.modal-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.25rem}.profile-verify-modal .error-message{margin-bottom:1rem;padding:.5rem .75rem;background:#ef44441a;color:#dc2626;border-radius:.375rem;font-size:.875rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.profile-upload{display:flex;align-items:center;gap:1.5rem}.profile-image{width:80px;height:80px;border-radius:50%;border:3px solid var(--border-color)}.notification-group{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.notification-group:last-child{border-bottom:none;margin-bottom:2rem}.notification-group h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border-color)}.setting-item:last-child{border-bottom:none}.setting-label{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.setting-description{font-size:.75rem;color:var(--text-secondary)}.toggle{position:relative;display:inline-block;width:48px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle input:checked+.toggle-slider{background-color:var(--primary-color)}.toggle input:checked+.toggle-slider:before{transform:translate(24px)}.divider{height:1px;background-color:var(--border-color);margin:2rem 0}@media (max-width: 768px){.settings-container{grid-template-columns:1fr}.settings-tabs{flex-direction:row;overflow-x:auto}.tab-button span{display:none}.form-row{grid-template-columns:1fr}.settings-content{padding:1.5rem}}.vendor-detail-page{padding:2rem}.back-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;margin-bottom:1.5rem;font-size:.875rem;transition:color .2s}.back-link:hover{color:var(--primary-color)}.vendor-header-card{background:var(--surface);border-radius:1rem;padding:2rem;display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.vendor-detail-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.vendor-detail-top-bar .back-link{margin-bottom:0}.vendor-detail-actions{display:flex;gap:1rem}.hidden-status{color:var(--danger)!important;border-color:var(--danger)!important}.hidden-status:hover{background:#ef44440d!important}.vendor-header-left{display:flex;gap:1.5rem;align-items:center}.vendor-large-logo{width:100px;height:100px;border-radius:1rem;object-fit:cover;border:4px solid var(--background);background:var(--background);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:var(--primary-color);overflow:hidden}.vendor-large-logo img{width:100%;height:100%;object-fit:cover;display:block}.vendor-title-section h1{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.vendor-meta{display:flex;gap:1.5rem;color:var(--text-secondary);font-size:.875rem}.meta-item{display:flex;align-items:center;gap:.4rem}.detail-content-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:2rem;align-items:start}.info-section{display:flex;flex-direction:column;gap:2rem}.secondary-section{display:flex;flex-direction:column;gap:2rem;position:sticky;top:2rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.description-card{grid-column:1 / -1}.info-card{background:var(--surface);border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a}.info-card h3{font-size:1rem;margin-bottom:1.25rem;color:var(--text-primary);display:flex;align-items:center;gap:.6rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.info-list{display:flex;flex-direction:column;gap:1rem}.info-item{display:flex;justify-content:space-between;font-size:.875rem}.info-label{color:var(--text-secondary)}.info-value{color:var(--text-primary);font-weight:500}.image-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.gallery-item{aspect-ratio:1;border-radius:.75rem;overflow:hidden;background:var(--background)}.gallery-item img{width:100%;height:100%;object-fit:cover}.hour-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-color);font-size:.875rem}.hour-row:last-child{border-bottom:none}.offering-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.offering-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--background);border-radius:.75rem;margin-bottom:.75rem;border:1px solid var(--border-color);transition:transform .2s}.offering-item:hover{transform:translate(4px);border-color:var(--primary-color)}.offering-info{display:flex;flex-direction:column;gap:.25rem}.offering-name{font-weight:600;color:var(--text-primary);font-size:.95rem}.offering-desc{font-size:.8rem;color:var(--text-secondary)}.offering-price-tag{background:var(--primary-color);color:#fff;padding:.4rem .8rem;border-radius:2rem;font-weight:600;font-size:.85rem;white-space:nowrap}.offering-editor-list{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}.offering-edit-row{display:flex;gap:.75rem;align-items:flex-start;background:var(--background);padding:1rem;border-radius:.75rem;border:1px solid var(--border-color);position:relative}.offering-edit-inputs{flex:1;display:flex;flex-direction:column;gap:.5rem}.btn-remove-offering{color:var(--danger);background:none;border:none;cursor:pointer;padding:.25rem;transition:opacity .2s}.btn-remove-offering:hover{opacity:.7}@media (max-width: 1024px){.detail-content-grid{grid-template-columns:1fr}.secondary-section{position:static}}.calendar-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.refresh-btn{border:1px solid var(--border-color);background:var(--background);border-radius:.75rem;padding:.5rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}.refresh-btn:hover{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.booking-calendar{padding-top:.75rem}.booking-calendar-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem;padding:.5rem 0}.calendar-nav-btn{border:1px solid var(--border-color);background:var(--background);border-radius:.75rem;padding:.5rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,transform .05s}.calendar-nav-btn:hover{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.calendar-month-label{font-weight:700;color:var(--text-primary);display:flex;align-items:center}.calendar-month-text{font-size:1.1rem;font-weight:800}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.35rem;margin-bottom:.45rem}.calendar-weekday{text-align:center;font-size:.75rem;color:var(--text-secondary);font-weight:600}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.35rem}.calendar-day-cell{border:1px solid var(--border-color);background:var(--background);border-radius:.9rem;height:52px;cursor:pointer;padding:.35rem .25rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;transition:transform .05s,border-color .2s}.calendar-day-cell:hover{transform:translateY(-1px);border-color:var(--primary-color)}.calendar-day-cell--selected{border-color:var(--primary-color);background:#02c0a722}.calendar-day-cell--empty{border:1px solid transparent;background:transparent;cursor:default}.calendar-day-number{font-weight:700;font-size:.85rem;color:var(--text-primary);line-height:1}.calendar-dots{margin-top:.35rem;display:flex;gap:.15rem;justify-content:center}.calendar-dot{width:6px;height:6px;border-radius:50%}.calendar-legend{display:flex;gap:1rem;margin-top:.85rem;margin-bottom:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-secondary);font-size:.85rem}.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.booking-day-section{padding-top:.25rem}.booking-day-title{color:var(--text-secondary);font-weight:700;font-size:.9rem;margin-bottom:.75rem}.booking-empty{color:var(--text-secondary);font-size:.85rem;padding:.5rem 0}.booking-list{display:flex;flex-direction:column;gap:.75rem}.booking-card{border-radius:1rem;border:1px solid var(--border-color);background:#fff;padding:1rem;box-shadow:0 4px 6px -1px #0000000f}.booking-card-top{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:.5rem}.booking-title{font-weight:800;color:var(--text-primary)}.booking-type-pill{font-weight:800;font-size:.75rem;padding:.25rem .6rem;border-radius:999px;white-space:nowrap}.booking-card-meta{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.6rem}.booking-time{color:var(--text-secondary);font-weight:700;font-size:.9rem}.booking-guest{color:var(--text-secondary);font-weight:600;font-size:.85rem}.booking-status-row{display:flex;gap:.5rem;align-items:baseline}.booking-status-label{color:var(--text-secondary);font-size:.8rem;font-weight:700}.booking-status-value{color:var(--text-primary);font-size:.85rem;font-weight:800}.plan-quiz-page{padding:2rem}.add-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:opacity .2s}.add-btn:hover{opacity:.9}.questions-list{display:flex;flex-direction:column;gap:1.5rem}.question-card{background:var(--surface);border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a}.question-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.question-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.type-badge{padding:.25rem .6rem;border-radius:2rem;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.4rem}.type-badge.single{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.type-badge.multi{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.question-actions{display:flex;gap:.75rem}.action-icon-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.4rem;border-radius:.4rem;transition:all .2s}.action-icon-btn:hover{background:var(--background)}.action-icon-btn.edit:hover{color:var(--primary-color)}.action-icon-btn.delete:hover{color:var(--error)}.choices-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.choice-box{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.edit-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.form-input{background:var(--background);border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem;border-radius:.5rem;outline:none}.form-input:focus{border-color:var(--primary-color)}.choices-edit-grid{display:flex;flex-direction:column;gap:.75rem}.choice-edit-row{display:flex;gap:.75rem;align-items:center}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.cancel-btn{background:none;border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer}.save-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer}.add-choice-btn{display:flex;align-items:center;gap:.4rem;font-size:.8125rem;font-weight:600;color:var(--primary-color);background:#02c0a71a;border:1px solid var(--primary-color);padding:.4rem .8rem;border-radius:2rem;cursor:pointer;transition:all .2s}.add-choice-btn:hover{background:var(--primary-color);color:#fff}.plan-detail-container{padding:2rem;max-width:1400px;margin:0 auto}.plan-detail-loading{padding:4rem 2rem;max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.plan-detail-loading .loading-spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(148,163,184,.4);border-top-color:var(--primary-color);animation:spin .6s linear infinite}.back-link{display:flex;align-items:center;gap:.5rem;color:var(--primary-color);text-decoration:none;font-size:.875rem;margin-bottom:.5rem;transition:color .2s}.back-link:hover{color:#008a44}.header-actions{display:flex;gap:1rem;align-items:center}.header-actions .btn-primary,.header-actions .btn-secondary{display:inline-flex;align-items:center;gap:.4rem}.danger-btn{display:inline-flex;align-items:center;gap:.4rem;background:#ef4444!important;color:#fff!important;border:1px solid #dc2626!important}.danger-btn:hover:not(:disabled){background:#b91c1c!important;border-color:#991b1b!important;color:#fff!important}.confirm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-modal{width:100%;max-width:420px;background:var(--surface);border-radius:1rem;padding:1.75rem 1.75rem 1.5rem;box-shadow:0 20px 45px #0f172a59}.confirm-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.confirm-text{margin:0 0 1.5rem;font-size:.9rem;color:var(--text-secondary)}.confirm-actions{display:flex;justify-content:flex-end;gap:.75rem}.visibility-toggle{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:.5rem;border:1px solid var(--border-color);background:var(--surface);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .2s}.visibility-toggle.public{border-color:var(--primary-color);color:var(--primary-color);background:#02c0a70d}.plan-grid-layout{display:grid;grid-template-columns:1fr 320px;gap:2rem;margin-top:2rem}.card{background:var(--surface);border-radius:1rem;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000001a}.card-title{font-size:1.125rem;font-weight:700;margin-bottom:1.5rem;color:var(--text-primary)}.card-header-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-header-flex .card-title{margin-bottom:0}.add-activity-button{display:flex;align-items:center;gap:.5rem;background:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:opacity .2s}.add-activity-button:disabled{opacity:.5;cursor:not-allowed}.activities-list-detail{display:flex;flex-direction:column;gap:1.5rem}.activity-slot-item{background:var(--background);border:1px solid var(--border-color);border-radius:.75rem;overflow:hidden}.slot-header{background:var(--surface);padding:.75rem 1rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--border-color)}.slot-index{width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.slot-title{font-weight:600;font-size:.875rem;flex:1}.remove-slot{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;transition:color .2s}.remove-slot:hover{color:var(--danger)}.remove-slot:disabled{opacity:.3;cursor:not-allowed}.remove-slot:disabled:hover{color:var(--text-secondary)}.slot-body{padding:1.25rem}.slot-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;font-weight:700}.condensed{margin-top:.25rem}.summary-item{display:flex;align-items:center;gap:1rem;padding:1rem 0}.summary-icon{width:40px;height:40px;background:var(--background);color:var(--primary-color);border-radius:.5rem;display:flex;align-items:center;justify-content:center}.summary-info{display:flex;flex-direction:column}.summary-label{font-size:.75rem;color:var(--text-secondary)}.summary-value{font-weight:700;color:var(--text-primary)}.summary-divider{height:1px;background:var(--border-color);margin:1rem 0}.summary-status{display:flex;justify-content:space-between;align-items:center}.status-label{font-size:.875rem;color:var(--text-secondary)}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge.published{background:#10b9811a;color:#10b981}.status-badge.draft{background:#f59e0b1a;color:#f59e0b}.empty-activities{padding:3rem;text-align:center;color:var(--text-secondary);font-style:italic;background:var(--background);border-radius:.75rem;border:2px dashed var(--border-color)}.multi-select-dropdown{position:relative;width:100%;margin-top:.25rem}.dropdown-field{min-height:42px;padding:.5rem 1rem;background:var(--background);border:1px solid var(--border-color);border-radius:.5rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.dropdown-field:hover{border-color:var(--primary-color)}.dropdown-field.active{border-color:var(--primary-color);box-shadow:0 0 0 2px #02c0a71a}.multi-select-dropdown.disabled .dropdown-field{opacity:.6;cursor:not-allowed;background:#0000000d}.selected-values{flex:1;display:flex;flex-wrap:wrap;gap:.4rem}.placeholder{color:var(--text-secondary);font-size:.875rem}.chips-container{display:flex;flex-wrap:wrap;gap:.4rem}.vendor-chip{background:#02c0a71a;color:var(--primary-color);padding:.15rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600}.dropdown-arrow{color:var(--text-secondary);display:flex;align-items:center;transition:transform .2s}.dropdown-arrow .rotate{transform:rotate(45deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;background:var(--surface);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:0 10px 15px -3px #0003;z-index:100;max-height:250px;overflow-y:auto}.dropdown-menu::-webkit-scrollbar{width:6px}.dropdown-menu::-webkit-scrollbar-track{background:transparent}.dropdown-menu::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:10px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}.no-options{padding:1.5rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:#02c0a70d}.dropdown-item input{width:16px;height:16px;accent-color:var(--primary-color)}.item-info{display:flex;flex-direction:column}.item-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.item-meta{font-size:.75rem;color:var(--text-secondary)}@media (max-width: 1024px){.plan-grid-layout{grid-template-columns:1fr}}.vendor-categories-page{padding:0}.vendor-categories-actions{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.vendor-category-input{flex:1;max-width:420px;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background:var(--surface);color:var(--text-primary)}.vendor-category-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #02c0a71f}.vendor-categories-error{color:var(--danger, #ef4444);font-size:.875rem;margin-bottom:1rem}.vendor-categories-loading{padding:1rem 0;color:var(--text-secondary)}.vendor-categories-empty{background:var(--surface);border-radius:.75rem;padding:1.25rem}.vendor-categories-empty h3{margin:0 0 .25rem;color:var(--text-primary)}.vendor-categories-empty p{margin:0;color:var(--text-secondary);font-size:.875rem}.vendor-categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem}.vendor-category-card{background:var(--surface);border-radius:.75rem;padding:1rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.vendor-category-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px #00000014}.vendor-category-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.vendor-category-card-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.vendor-category-card-header span{color:var(--text-secondary);font-size:.75rem}.vendor-category-empty{margin:0;color:var(--text-secondary);font-size:.875rem}.vendor-category-vendors{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.625rem}.vendor-category-vendor-item{display:flex;align-items:center;gap:.625rem;padding:.5rem;border-radius:.5rem;background:var(--background)}.vendor-category-vendor-avatar{width:30px;height:30px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-secondary)}.vendor-category-vendor-avatar img,.vendor-category-vendor-avatar .vendor-category-vendor-avatar-img{width:100%;height:100%;object-fit:cover}.vendor-category-vendor-details{min-width:0}.vendor-category-vendor-name{margin:0;color:var(--text-primary);font-size:.875rem;font-weight:600}.vendor-category-vendor-type{margin:0;color:var(--text-secondary);font-size:.75rem}.vendor-category-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.vendor-category-modal{width:100%;max-width:520px;max-height:80vh;overflow-y:auto;background:var(--surface);border-radius:.75rem;padding:1rem}.vendor-category-create-modal{max-width:460px}.vendor-category-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.vendor-category-modal-header h2{margin:0;font-size:1.125rem;color:var(--text-primary)}.vendor-category-modal-header p{margin:.125rem 0 0;color:var(--text-secondary);font-size:.8125rem}.vendor-category-modal-close{border:none;background:transparent;color:var(--text-secondary);border-radius:.375rem;padding:.25rem;cursor:pointer}.vendor-category-modal-close:hover{background:var(--background);color:var(--text-primary)}.vendor-category-modal-empty{margin:0;color:var(--text-secondary);font-size:.875rem}.vendor-category-create-btn{margin-top:.875rem;width:100%;justify-content:center}@media (max-width: 640px){.vendor-category-input{max-width:none}}.banners-page{padding:0}.banners-list{margin-top:1.5rem}.banner-cards{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.banner-card{background:var(--surface);border-radius:1.25rem;overflow:hidden;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000005;display:grid;grid-template-columns:320px 1fr;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border-color);position:relative}.banner-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-4px);border-color:var(--primary-color)}.banner-card.inactive{opacity:.6;filter:grayscale(.5);background:var(--background)}.banner-preview{position:relative;height:180px;background:#f1f5f9}.banner-preview img{width:100%;height:100%;object-fit:cover}.banner-status-badge{position:absolute;top:12px;left:12px}.banner-status-badge span{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-active{background:#dcfce7;color:#15803d}.status-inactive{background:#f1f5f9;color:#475569}.banner-content{padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between}.banner-info{display:flex;flex-direction:column;gap:.5rem}.banner-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.banner-link{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--text-secondary);word-break:break-all}.banner-actions{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.order-actions,.crud-actions{display:flex;gap:.5rem}.action-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--background);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all .2s}.action-btn:hover:not(:disabled){background:var(--surface);color:var(--primary-color);border-color:var(--primary-color)}.action-btn:disabled{opacity:.3;cursor:not-allowed}.action-btn.danger:hover{background:#fee2e2;color:#ef4444;border-color:#ef4444}.banner-upload-area{margin-top:.5rem}.upload-label{display:block;border:2px dashed var(--border-color);border-radius:12px;padding:2.5rem 1rem;background:var(--background);text-align:center;cursor:pointer;transition:all .3s ease}.upload-label:hover{border-color:var(--primary-color);background:#fff}.upload-label.upload-label-disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-secondary)}.upload-preview-container{position:relative;width:100%;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);height:200px}.upload-preview-container img{width:100%;height:100%;object-fit:cover}.remove-image-btn{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;border:none;background:#000000bf;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.remove-image-btn:hover{background:#ef4444}.checkbox-group{display:flex;align-items:center}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.875rem;color:var(--text-primary)}.form-help{font-size:.75rem;color:var(--text-secondary);margin-top:4px}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:4rem 2rem;background:var(--surface);border-radius:1rem;border:2px dashed var(--border-color)}.empty-state h3{margin:1rem 0 .5rem;font-size:1.5rem}.empty-state p{color:var(--text-secondary);margin-bottom:2rem}@media (max-width: 900px){.banner-card{grid-template-columns:1fr}.banner-preview{height:160px}}.feedback-page{max-width:1400px;display:flex;flex-direction:column;min-height:calc(100vh - var(--header-height) - 2rem);margin-bottom:-2rem}.feedback-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;gap:1rem}.btn-refresh{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:.5rem;border:1px solid var(--border-color);background:var(--surface);color:var(--text);cursor:pointer;transition:background .2s}.btn-refresh:hover:not(:disabled){background:var(--surface-hover, rgba(0, 0, 0, .04))}.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.btn-refresh .spin{animation:feedback-spin .8s linear infinite}@keyframes feedback-spin{to{transform:rotate(360deg)}}.feedback-stats{margin-bottom:1.25rem}.feedback-stat-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#02c0a71f,#8b5cf614);border-radius:.75rem;border:1px solid var(--border-color);max-width:280px}.feedback-stat-icon{color:#02c0a7;flex-shrink:0}.feedback-stat-value{font-size:1.5rem;font-weight:700;line-height:1.2}.feedback-stat-label{font-size:.8125rem;color:var(--text-muted, #6b7280)}.feedback-banner{padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.feedback-banner.error{background:#ef44441a;border:1px solid rgba(239,68,68,.35);color:#b91c1c}.feedback-card{padding:0;overflow:hidden}.feedback-loading,.feedback-empty{padding:2.5rem 1.5rem;text-align:center;color:var(--text-muted, #6b7280);margin:0}.feedback-table th{white-space:nowrap;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted, #6b7280)}.feedback-cell-time{white-space:nowrap;font-size:.875rem;vertical-align:top;padding-top:1rem;color:var(--text-muted, #6b7280)}.feedback-user-name{font-weight:600;font-size:.9375rem}.feedback-user-email{font-size:.8125rem;color:var(--text-muted, #6b7280);word-break:break-all}.feedback-user-meta{font-size:.75rem;color:var(--text-muted, #9ca3af);margin-top:.25rem;text-transform:capitalize}.feedback-pill{display:inline-block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:.2rem .5rem;border-radius:999px;margin-right:.35rem;margin-bottom:.25rem;background:var(--surface-alt, #f3f4f6);color:#374151}.feedback-pill.cat-bug{background:#ef44441f;color:#b91c1c}.feedback-pill.cat-suggestion{background:#3b82f61f;color:#1d4ed8}.feedback-pill.cat-general{background:#02c0a726;color:#0f766e}.feedback-pill.cat-other{background:#6b728026;color:#4b5563}.feedback-pill.source{background:#8b5cf61f;color:#6d28d9}.feedback-cell-msg{vertical-align:top;max-width:520px}.feedback-msg{font-size:.9375rem;line-height:1.55;white-space:pre-wrap;word-break:break-word}@media (max-width: 1024px){.feedback-table .feedback-cell-msg{max-width:280px}}.login-container{display:flex;min-height:100vh;width:100%;background:var(--surface);font-family:Poppins,sans-serif}.login-side-visual{flex:1.2;background-color:var(--primary-color);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:3rem}.typing-container{text-align:left;max-width:600px;z-index:1;margin-top:-5rem}.visual-logo{height:60px;width:auto;margin-bottom:70px;display:block;object-fit:contain;z-index:2}.welcome-text{font-size:4rem;font-weight:700;color:#fff;margin-bottom:.5rem;line-height:1.1}.dynamic-text-wrapper{font-size:4.5rem;font-weight:800;color:#fff;margin-bottom:2rem;min-height:5.5rem;display:flex;align-items:center}.dynamic-name{color:#fff}.cursor{font-weight:300;color:#fff;animation:blink 1s step-end infinite;margin-left:5px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.visual-subtitle{font-size:1.125rem;color:#ffffffe6;line-height:1.6;max-width:450px;margin-top:1.5rem}.visual-footer{position:absolute;bottom:2rem;left:0;right:0;text-align:center;color:#fffc;font-size:.875rem;z-index:1}.login-side-form{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem;background:var(--surface)}.login-card-minimal{width:100%;max-width:360px;animation:fadeIn .8s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-header{margin-bottom:3.5rem;text-align:left}.login-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.login-header p{color:#8b8b8b;font-size:.875rem;font-weight:400}.login-form{display:flex;flex-direction:column;gap:1.5rem}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:.875rem;border-radius:.75rem;font-size:.875rem}.form-group{display:flex;flex-direction:column;gap:.625rem}.form-group label{font-size:.875rem;font-weight:600;color:#64748b}.input-with-icon{display:flex;align-items:center;background:transparent;border:1px solid #e2e8f0;border-radius:.5rem;transition:all .2s;padding:0 1.25rem}.input-with-icon:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 4px #02c0a71a}.input-with-icon svg:first-child{color:#94a3b8;width:18px;height:18px;flex-shrink:0}.input-with-icon input{flex:1;width:100%;padding:1rem 0 1rem .75rem;background:transparent;border:none;color:var(--text-primary);font-size:.875rem}.input-with-icon input::placeholder{color:#94a3b8}.input-with-icon input:focus{outline:none}.input-with-icon input:-webkit-autofill,.input-with-icon input:-webkit-autofill:hover,.input-with-icon input:-webkit-autofill:focus,.input-with-icon input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px var(--surface) inset!important;-webkit-text-fill-color:var(--text-primary)!important;transition:background-color 5000s ease-in-out 0s}.show-password{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0 0 0 .75rem;transition:color .2s;flex-shrink:0}.show-password svg{width:18px;height:18px}.show-password:hover{color:var(--text-primary)}.login-button{width:100%;padding:.875rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;margin-top:1rem}.login-button:hover{background-color:var(--primary-dark);box-shadow:0 10px 15px -3px #02c0a74d;transform:translateY(-1px)}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.login-container{flex-direction:column}.login-side-visual{flex:none;height:200px}.login-side-form{flex:1;padding:2rem}.typing-container{padding:2rem;text-align:center}.welcome-text{font-size:2.5rem}.dynamic-text-wrapper{font-size:3rem;min-height:3.5rem;justify-content:center}.visual-subtitle{font-size:1rem}.login-card-minimal{max-width:100%}}.app{min-height:100vh}.btn{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--surface);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--background)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{background-color:#dc2626}.card{background:var(--surface);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}.card-header{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #02c0a71a}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:.75rem 1rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.table td{padding:.875rem 1rem;font-size:.875rem;border-bottom:1px solid var(--border-color)}.table tbody tr:hover{background-color:var(--background)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-success{background-color:#d1fae5;color:#065f46}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-info{background-color:#dbeafe;color:#1e40af}.page-header{display:flex!important;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.header-titles{display:flex;flex-direction:column;gap:.25rem}.page-header h1{font-size:2rem;font-weight:700;margin:0;color:var(--text-primary)}.page-header p{margin:0;color:var(--text-secondary);font-size:.875rem}:root{--primary-color: #02c0a7;--primary-dark: #019485;--primary-light: #03ddc0;--secondary-color: #8b5cf6;--background: #f8fafc;--surface: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--sidebar-width: 260px;--header-height: 70px}*{margin:0;padding:0;box-sizing:border-box}html{transition:background-color .3s ease,color .3s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}
