@import url(https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap);.navbar{backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:var(--bg-glass);border-bottom:1px solid var(--bg-glass-border);box-shadow:0 1px 12px #0000000f;height:var(--navbar-height);left:0;position:fixed;right:0;top:0;z-index:1000}.nav-container{height:100%;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 24px}.nav-brand,.nav-container{align-items:center;display:flex}.nav-brand{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:1.35rem;font-weight:800;gap:10px;letter-spacing:-.03em;text-decoration:none;transition:transform var(--transition-normal)}.nav-brand:hover{transform:scale(1.03)}.brand-icon{-webkit-text-fill-color:initial;font-size:1.5rem}.nav-menu{gap:4px}.nav-link,.nav-menu{align-items:center;display:flex}.nav-link{border-radius:var(--radius-full);color:var(--text-secondary);font-size:14px;font-weight:500;gap:6px;padding:10px 18px;position:relative;text-decoration:none;transition:all var(--transition-normal)}.nav-link:hover{background:var(--primary-50);color:var(--primary-600)}.nav-link.active{background:var(--primary-100);color:var(--primary-600);font-weight:600}.nav-actions{align-items:center;display:flex;gap:12px}.user-info{text-align:right}.user-name{color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.3;margin:0}.user-budget{color:var(--text-tertiary);font-size:12px;margin:0}.btn-icon{background:#0000;border:1px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;height:40px;transition:all var(--transition-normal);width:40px}.btn-icon:hover{background:var(--bg-elevated);border-color:var(--border-medium);box-shadow:var(--shadow-sm);color:var(--primary-600);transform:translateY(-2px)}.btn-logout:hover{background:var(--rose-50);border-color:#f43f5e33;color:var(--rose-500)}.nav-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;padding:6px}.nav-toggle span{background:var(--text-primary);border-radius:999px;display:block;height:2px;transition:all var(--transition-normal);width:22px}@media (max-width:768px){.nav-toggle{display:flex}.nav-menu{backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:var(--bg-glass);border-bottom:1px solid var(--bg-glass-border);flex-direction:column;gap:4px;left:0;opacity:0;padding:16px;pointer-events:none;position:fixed;right:0;top:var(--navbar-height);transform:translateY(-100%);transition:all var(--transition-normal)}.nav-menu.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-link{border-radius:var(--radius-md);justify-content:center;padding:14px;width:100%}.user-info{display:none}}.guest-mode{min-height:100vh;overflow-x:hidden}.hero-section{align-items:center;background:var(--bg-body);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:60px 24px;position:relative;text-align:center}.hero-pattern{opacity:.5;position:absolute;top:10%;z-index:0}.hero-pattern.left{left:5%}.hero-pattern.right{right:5%;top:30%}.floating-orbs{bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.orb{animation:floatOrb 10s ease-in-out infinite alternate;border-radius:50%;filter:blur(60px);opacity:.2;position:absolute}.orb-teal{background:var(--teal-500)}.orb-amber{background:var(--amber-500)}.orb-1{height:300px;left:-100px;top:-100px;width:300px}.orb-2{animation-delay:-2s;height:400px;right:-200px;top:20%;width:400px}.orb-3{animation-delay:-4s;bottom:10%;height:250px;left:20%;width:250px}.orb-4{animation-delay:-6s;bottom:-150px;height:350px;right:15%;width:350px}@keyframes floatOrb{0%{transform:translate(0)}to{transform:translate(40px,-50px)}}.hero-graphics{animation:fadeInUp 1s cubic-bezier(.2,.8,.2,1);display:flex;justify-content:center;margin-bottom:2rem;position:relative;z-index:2}.hero-bowl{filter:drop-shadow(0 20px 30px rgba(0,0,0,.15));height:auto;max-width:320px;width:100%}.hero-section:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%236366f1' fill-opacity='.03' fill-rule='evenodd'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.hero-content{max-width:700px;position:relative;z-index:1}.hero-content h1{-webkit-text-fill-color:#0000;animation:fadeInUp .8s ease-out;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:900;line-height:1.1;margin-bottom:20px}.hero-content>p{animation:fadeInUp .8s ease-out .15s backwards;color:var(--text-secondary);font-size:1.2rem;margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:520px}.hero-buttons{animation:fadeInUp .8s ease-out .3s backwards;display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.hero-buttons .btn-lg{border-radius:var(--radius-xl);font-size:16px;padding:18px 36px}.demo-preview{animation:fadeInUp .6s ease-out;margin-top:50px}.demo-card{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);margin:0 auto;max-width:550px;padding:32px}.demo-card h3{color:var(--text-primary);font-size:1.125rem;margin-bottom:20px}.demo-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.demo-stat{text-align:center}.demo-stat p{margin:0}.demo-stat p:first-child{color:var(--text-tertiary);font-size:12px;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.demo-stat .value{color:var(--primary-600);font-family:var(--font-display);font-size:1.5rem;font-weight:700}.demo-progress{margin-top:10px}.demo-progress .progress-bar{background:var(--slate-200);border-radius:var(--radius-full);height:10px;overflow:hidden}.demo-progress .progress-fill{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;transition:width 1s ease-out}.demo-progress .progress-text{color:var(--text-tertiary);font-size:13px;margin-top:8px}.features-section{margin:0 auto;max-width:1200px;padding:100px 24px}.section-header{margin-bottom:60px;text-align:center}.section-header h2{font-size:2.25rem;font-weight:800;margin-bottom:12px}.section-header p{color:var(--text-tertiary);font-size:1.1rem;margin:0 auto;max-width:500px}.features-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;padding:32px;position:relative;transition:all var(--transition-normal)}.feature-card:before{background:var(--gradient-primary);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-normal)}.feature-card:hover{border-color:var(--primary-200);box-shadow:var(--shadow-lg);transform:translateY(-6px)}.feature-card:hover:before{opacity:1}.feature-icon{align-items:center;animation:float 3s ease-in-out infinite;background:var(--bg-inset);border-radius:var(--radius-lg);color:var(--primary-500);display:inline-flex;height:64px;justify-content:center;margin-bottom:16px;transition:transform var(--transition-normal);width:64px}.feature-card:hover .feature-icon{background:var(--primary-50);color:var(--primary-600);transform:scale(1.1) rotate(5deg)}.feature-card:nth-child(2) .feature-icon{animation-delay:.5s}.feature-card:nth-child(3) .feature-icon{animation-delay:1s}.feature-card:nth-child(4) .feature-icon{animation-delay:1.5s}.feature-card:nth-child(5) .feature-icon{animation-delay:2s}.feature-card:nth-child(6) .feature-icon{animation-delay:2.5s}.feature-card h3{font-size:1.125rem;margin-bottom:10px}.feature-card p{color:var(--text-tertiary);font-size:14px;line-height:1.6;margin:0}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.how-it-works{margin:0 auto;max-width:900px;padding:100px 24px}.steps-grid{grid-gap:40px;display:grid;gap:40px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));position:relative}.step{position:relative;text-align:center}.step-number{align-items:center;background:var(--gradient-primary);border-radius:50%;box-shadow:var(--shadow-primary);color:#fff;display:flex;font-family:var(--font-display);font-size:1.5rem;font-weight:800;height:56px;justify-content:center;margin:0 auto 20px;width:56px}.step h3{font-size:1.125rem;margin-bottom:10px}.step p{color:var(--text-tertiary);font-size:14px;line-height:1.6}.benefits-section{margin:0 auto;max-width:1000px;padding:100px 24px}.benefits-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.benefit{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:28px;text-align:center;transition:all var(--transition-normal)}.benefit:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.benefit-check{align-items:center;background:var(--success-50);border-radius:50%;color:var(--success-500);display:flex;font-size:1.25rem;font-weight:700;height:40px;justify-content:center;margin:0 auto 14px;width:40px}.benefit h3{font-size:1rem;margin-bottom:8px}.benefit p{color:var(--text-tertiary);font-size:13px;line-height:1.5;margin:0}.cta-section{background:radial-gradient(ellipse at 50% 50%,#6366f114 0,#0000 50%),var(--bg-body);padding:100px 24px;text-align:center}.cta-section h2{font-size:2.25rem;font-weight:800;margin-bottom:12px}.cta-section p{color:var(--text-tertiary);font-size:1.1rem;margin-bottom:32px}.cta-section .btn-lg{border-radius:var(--radius-xl);font-size:17px;padding:18px 40px}@media (max-width:768px){.hero-content h1{font-size:2.5rem}.hero-content>p{font-size:1rem}.demo-stats,.features-grid{grid-template-columns:1fr}.demo-stats{gap:12px}.cta-section h2,.section-header h2{font-size:1.75rem}}@media (max-width:480px){.hero-content h1{font-size:2rem}.hero-buttons{align-items:stretch;flex-direction:column}}.profile-setup{align-items:center;background:radial-gradient(ellipse at 30% 30%,#6366f114 0,#0000 50%),radial-gradient(ellipse at 70% 70%,#a855f70f 0,#0000 50%),var(--bg-body);display:flex;justify-content:center;min-height:100vh;padding:40px 24px}.setup-container{max-width:520px;width:100%}.setup-container>.progress-bar{background:var(--slate-200);border-radius:var(--radius-full);height:5px;margin-bottom:32px;overflow:hidden}.setup-container>.progress-bar .progress{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.setup-step{animation:fadeScale .4s ease-out;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:40px}@keyframes fadeScale{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.setup-step h2{font-size:1.75rem;font-weight:800;margin-bottom:6px;text-align:center}.setup-step .subtitle{color:var(--text-tertiary);font-size:15px;margin-bottom:32px;text-align:center}.form-group{margin-bottom:24px}.form-group>label{color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input[type=number],.form-group input[type=text]{background:var(--bg-inset);border:2px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:16px;padding:14px 18px;transition:all var(--transition-normal);width:100%}.form-group input[type=number]:focus,.form-group input[type=text]:focus{background:var(--bg-card);border-color:var(--primary-400);box-shadow:0 0 0 4px #08c4a81a;outline:none}.form-group input.error{background:var(--danger-50);border-color:var(--danger-400)}.error-text{color:var(--danger-500);display:block;font-size:13px;font-weight:500;margin-top:6px}.budget-info{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:16px}.info-box{background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius-md);padding:16px;text-align:center}.info-box .label{color:var(--text-tertiary);font-size:12px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.info-box .value{color:var(--primary-600);font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-option{align-items:center;background:var(--bg-inset);border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:12px;padding:14px 18px;transition:all var(--transition-normal)}.radio-option:hover{background:var(--primary-50);border-color:var(--primary-300)}.radio-option input[type=radio]{align-items:center;appearance:none;-webkit-appearance:none;border:2px solid var(--slate-300);border-radius:50%;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all var(--transition-fast);width:20px}.radio-option input[type=radio]:after{background:var(--primary-500);border-radius:50%;content:"";height:10px;transform:scale(0);transition:transform var(--transition-spring);width:10px}.radio-option input[type=radio]:checked{border-color:var(--primary-500)}.radio-option input[type=radio]:checked:after{transform:scale(1)}.radio-option:has(input:checked){background:var(--primary-50);border-color:var(--primary-400)}.radio-option span{color:var(--text-primary);font-size:15px;font-weight:500}.button-group{display:flex;gap:12px;margin-top:8px}.button-group .btn{flex:1 1;font-size:15px;padding:14px}.setup-step>.btn{font-size:15px;margin-top:8px;padding:14px;width:100%}.btn-success{background:var(--gradient-success)!important}.btn-success:hover{box-shadow:0 8px 24px #10b98159}@media (max-width:480px){.setup-step{padding:28px}.setup-step h2{font-size:1.5rem}.budget-info{grid-template-columns:1fr}}.menu-planner{margin:0 auto;max-width:1200px;min-height:calc(100vh - var(--navbar-height));padding:32px}.planner-header{animation:fadeInUp .5s ease-out;margin-bottom:32px}.planner-header h1{font-size:2rem;font-weight:800;margin-bottom:6px}.planner-header p{color:var(--text-tertiary);font-size:15px}.planner-container{grid-gap:24px;animation:fadeInUp .5s ease-out .1s backwards;display:grid;gap:24px;grid-template-columns:2fr 1fr;margin-bottom:32px}.calendar-section{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:28px}.calendar-controls{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.btn-nav,.btn-today{background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;padding:10px 20px;transition:all var(--transition-normal)}.btn-nav:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-600)}.btn-today{background:var(--gradient-primary);border-color:var(--primary-500);box-shadow:var(--shadow-primary);color:#fff}.btn-today:hover{box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.calendar{margin-bottom:24px}.calendar-header{margin-bottom:20px;text-align:center}.month-name{color:var(--text-primary);font-family:var(--font-display);font-size:1.25rem;font-weight:700}.weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.weekday{color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px;text-align:center;text-transform:uppercase}.days-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.day{align-items:center;aspect-ratio:1/1;background:var(--bg-inset);border:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:6px;position:relative;transition:all var(--transition-normal)}.day.other-month{background:#0000;color:var(--slate-300);cursor:default}.day.current-month:hover{background:var(--primary-50);border-color:var(--primary-300);transform:scale(1.04)}.day.selected{background:var(--primary-100);border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f126}.day.selected .day-number{color:var(--primary-700)}.day.has-meals{background:linear-gradient(135deg,#6366f114,#a855f714);border-color:var(--primary-200)}.day.has-meals.selected{background:linear-gradient(135deg,#6366f126,#a855f726);border-color:var(--primary-500)}.day.today{background:var(--primary-50)}.day.today .day-number{color:var(--primary-600);font-weight:800}.day-number{color:var(--text-primary);font-size:14px;font-weight:600}.meal-indicator{align-items:center;background:var(--gradient-primary);border-radius:50%;bottom:3px;box-shadow:var(--shadow-sm);color:#fff;display:flex;height:18px;justify-content:center;position:absolute;right:3px;width:18px}.meal-count{font-size:10px;font-weight:700}.calendar-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.stat-box{background:var(--bg-inset);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:16px;text-align:center}.stat-box .label{color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.stat-box .value{color:var(--primary-600);font-family:var(--font-display);font-size:1.5rem;font-weight:800;margin:0}.details-section{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);min-height:400px;padding:28px}.date-details h2{border-bottom:2px solid var(--primary-200);color:var(--text-primary);font-size:1rem;margin-bottom:20px;padding-bottom:14px}.meals-list{display:flex;flex-direction:column;gap:10px}.meal-item{align-items:center;background:var(--bg-inset);border-left:4px solid var(--primary-400);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:14px 16px;transition:all var(--transition-fast)}.meal-item:hover{background:var(--primary-50)}.meal-info{flex:1 1}.meal-time{color:var(--text-tertiary);font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.meal-name{color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.meal-credits{color:var(--primary-600);font-family:var(--font-display);font-size:15px;font-weight:700;margin-right:8px}.meal-item .btn-delete{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.meal-item .btn-delete:hover{background:var(--danger-50);color:var(--danger-500)}.meals-total{align-items:center;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius-md);display:flex;font-weight:600;justify-content:space-between;margin-top:10px;padding:14px 16px}.meals-total p{font-size:14px;margin:0}.total-value{color:var(--primary-600);font-family:var(--font-display);font-size:1.125rem;font-weight:800}.no-meals,.no-selection{color:var(--text-tertiary);padding:40px 20px;text-align:center}.no-meals p,.no-selection p{font-size:15px;margin-bottom:16px}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0f172a80;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.modal{animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1);background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:85vh;max-width:480px;overflow-y:auto;padding:32px;width:100%}.modal h3{font-size:1.25rem;margin-bottom:6px}.modal .modal-subtitle{color:var(--text-tertiary);font-size:13px;margin-bottom:24px}.modal-filters{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:16px}.modal-filters select{background:var(--bg-inset);border:2px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:13px;padding:10px 12px;transition:all var(--transition-fast);.modal-menu-list{display:flex;flex-direction:column;gap:6px;margin-bottom:20px;max-height:300px;overflow-y:auto;padding-right:4px}}.modal-menu-item{align-items:center;background:var(--bg-inset);border:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;padding:12px 14px;transition:all var(--transition-fast)}.modal-menu-item:hover{background:var(--primary-50);border-color:var(--primary-200)}.modal-menu-item.selected{background:var(--primary-50);border-color:var(--primary-400)}.modal-menu-item .item-name{color:var(--text-primary);font-size:14px;font-weight:600}.modal-menu-item .item-credits{color:var(--primary-600);font-family:var(--font-display);font-size:13px;font-weight:700}.modal-menu-item .item-tag{border-radius:var(--radius-full);font-size:10px;font-weight:600;padding:2px 6px}.modal-menu-item .item-tag.veg{background:#10b9811a;color:var(--success-600)}.modal-menu-item .item-tag.non-veg{background:#f973161a;color:var(--accent-600)}.modal-actions{display:flex;gap:10px}.modal-actions .btn{flex:1 1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.upcoming-section{animation:fadeInUp .5s ease-out .2s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:28px}.upcoming-section h2{font-size:1.125rem;margin-bottom:20px}.upcoming-list{display:flex;flex-direction:column;gap:10px}.upcoming-item{align-items:center;background:var(--bg-inset);border-left:4px solid var(--primary-400);border-radius:var(--radius-md);display:flex;gap:14px;padding:14px 16px;transition:all var(--transition-normal)}.upcoming-item:hover{background:var(--primary-50);transform:translateX(4px)}.item-date{background:var(--gradient-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-primary);color:#fff;font-size:13px;font-weight:700;min-width:50px;padding:8px 12px;text-align:center}.item-details{flex:1 1}.item-meal{color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.item-type{color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;margin:2px 0 0;text-transform:uppercase}.item-credits{color:var(--primary-600);font-family:var(--font-display);font-size:15px;font-weight:800;min-width:50px;text-align:right}.no-upcoming{color:var(--text-tertiary);font-size:14px;padding:24px 16px;text-align:center}@media (max-width:1024px){.planner-container{grid-template-columns:1fr}.details-section{min-height:auto}}@media (max-width:768px){.menu-planner{padding:20px}.planner-header h1{font-size:1.75rem}.calendar-stats{grid-template-columns:1fr}.day{font-size:12px}.weekday{font-size:9px}.modal{margin:16px;padding:24px}.modal-filters{grid-template-columns:1fr}}.dashboard{margin:0 auto;max-width:1200px;min-height:calc(100vh - var(--navbar-height));padding:32px}.dashboard-header{animation:fadeInUp .5s ease-out;margin-bottom:32px}.dashboard-header h1{font-size:2rem;font-weight:800;margin-bottom:4px}.dashboard-header p{color:var(--text-tertiary);font-size:15px}.alert{align-items:center;animation:slideDown .4s ease-out;border-radius:var(--radius-lg);display:flex;font-size:14px;font-weight:500;gap:8px;margin-bottom:24px;padding:16px 20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.alert-danger{background:var(--danger-50);border:1px solid #f43f5e33;color:var(--danger-600)}.alert-warning{background:var(--warning-50);border:1px solid #f59e0b33;color:var(--warning-600)}.quick-stats{grid-gap:20px;animation:fadeInUp .5s ease-out .1s backwards;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:32px}.stat-card{align-items:center;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;gap:16px;overflow:hidden;padding:24px;position:relative;transition:all var(--transition-normal)}.stat-card:before{background:var(--gradient-primary);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-normal)}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-card:hover:before{opacity:1}.stat-icon{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:28px;height:56px;justify-content:center;width:56px}.stat-icon.spent{background:linear-gradient(135deg,#6366f11f,#8b5cf61f)}.stat-icon.remaining{background:linear-gradient(135deg,#10b9811f,#34d3991f)}.stat-icon.rate{background:linear-gradient(135deg,#f973161f,#fb923c1f)}.stat-icon.days{background:linear-gradient(135deg,#0ea5e91f,#38bdf81f)}.stat-content{flex:1 1;min-width:0}.stat-label{color:var(--text-tertiary);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.stat-value{color:var(--text-primary);font-family:var(--font-display);font-size:1.75rem;font-weight:800;line-height:1.1;margin-bottom:2px}.stat-subtext{color:var(--text-tertiary);font-size:12px}.budget-section{animation:fadeInUp .5s ease-out .2s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:28px}.budget-section h2{font-size:1.125rem;margin-bottom:20px}.progress-container,.progress-label{margin-bottom:10px}.progress-label{color:var(--text-secondary);display:flex;font-size:13px;font-weight:500;justify-content:space-between}.progress-bar-wrapper .progress-bar{background:var(--bg-elevated);border-radius:var(--radius-full);height:14px;overflow:visible;position:relative}.progress-fill{position:relative;transition:width .8s cubic-bezier(.34,1.56,.64,1)}.progress-fill.safe{background:var(--gradient-primary);box-shadow:0 2px 8px #6366f14d}.progress-fill.caution{background:linear-gradient(90deg,var(--warning-400),var(--warning-500));box-shadow:0 2px 8px #f59e0b4d}.progress-fill.exceeded{background:linear-gradient(90deg,var(--danger-400),var(--danger-500));box-shadow:0 2px 8px #f43f5e4d}.safe-limit-marker{background:var(--warning-500);border-radius:2px;height:22px;opacity:.7;position:absolute;top:-4px;transform:translateX(-50%);width:3px;z-index:1}.safety-section{animation:fadeInUp .5s ease-out .3s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:28px}.safety-section h2{font-size:1.125rem;margin-bottom:20px}.safety-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.safety-card{border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:20px;text-align:center;transition:all var(--transition-normal)}.safety-card:hover{border-color:var(--primary-200);box-shadow:var(--shadow-md)}.safety-card .label{color:var(--text-tertiary);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.safety-card .value{color:var(--text-primary);font-family:var(--font-display);font-size:1.5rem;font-weight:800;margin-bottom:6px}.safety-card .status{font-size:12px;font-weight:600}.safety-card .status.safe{color:var(--success-500)}.safety-card .status.exceeded{color:var(--danger-500)}.safety-card .status.info{color:var(--primary-500)}.trend-section{animation:fadeInUp .5s ease-out .4s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:28px}.trend-section h2{font-size:1.125rem;margin-bottom:20px}.trend-chart{align-items:center;display:flex;justify-content:center;min-height:280px;width:100%}.chart-empty{color:var(--text-tertiary);padding:40px 20px;text-align:center}.chart-empty p{font-size:15px}.recent-section{animation:fadeInUp .5s ease-out .5s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:28px}.recent-section h2{font-size:1.125rem;margin-bottom:20px}.transactions-list{display:flex;flex-direction:column;gap:8px}.transaction-item{align-items:center;background:var(--bg-inset);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:14px 16px;transition:all var(--transition-fast)}.transaction-item:hover{background:var(--primary-50);transform:translateX(4px)}.transaction-info{display:flex;flex-direction:column}.transaction-name{color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.transaction-date{color:var(--text-tertiary);font-size:12px;margin:2px 0 0}.transaction-credits{color:var(--primary-600);font-family:var(--font-display);font-size:15px;font-weight:700}.no-transactions{color:var(--text-tertiary);padding:32px 20px;text-align:center}.no-transactions p{font-size:14px}@media (max-width:768px){.dashboard{padding:20px}.dashboard-header h1{font-size:1.75rem}.quick-stats{grid-template-columns:1fr 1fr}.stat-card{flex-direction:column;padding:20px;text-align:center}.safety-grid{grid-template-columns:1fr}}.smart-suggestions{margin:0 auto;max-width:1200px;min-height:calc(100vh - var(--navbar-height));padding:32px}.suggestions-header{animation:fadeInUp .5s ease-out;margin-bottom:36px}.suggestions-header h1{font-size:2rem;font-weight:800;margin-bottom:6px}.suggestions-header p{color:var(--text-tertiary);font-size:15px}.smart-suggestions .budget-section{animation:fadeInUp .5s ease-out .1s backwards;margin-bottom:28px}.smart-suggestions .budget-section h2{font-size:1.125rem;margin-bottom:16px}.budget-cards{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.budget-cards .card{background:var(--bg-card);border:2px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);cursor:pointer;padding:20px;text-align:center;transition:all var(--transition-normal)}.budget-cards .card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-md);transform:translateY(-3px)}.budget-cards .card.active{background:var(--gradient-primary);border-color:var(--primary-500);box-shadow:var(--shadow-primary);color:#fff;transform:translateY(-2px)}.budget-cards .card .label{color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.budget-cards .card.active .label{color:#fffc}.budget-cards .card.active .amount,.budget-cards .card.active .subtitle{color:#fff}.budget-cards .card .amount{color:var(--text-primary);font-family:var(--font-display);font-size:1.75rem;font-weight:800;line-height:1.1;margin-bottom:4px}.budget-cards .card .subtitle{color:var(--text-secondary);font-size:12px;opacity:.7}.budget-cards .card.custom{border-style:dashed;padding:16px}.budget-cards .card.custom label{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:8px}.budget-cards .card.custom input{background:var(--bg-inset);border:2px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-weight:600;padding:10px;text-align:center;transition:all var(--transition-fast);width:100%}.budget-cards .card.custom input:focus{background:var(--bg-card);border-color:var(--primary-400);box-shadow:0 0 0 4px #08c4a81a;outline:none}.filters-section{animation:fadeInUp .5s ease-out .2s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:28px;padding:28px}.filters-section h2{font-size:1.125rem;margin-bottom:20px}.filters-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.filter-group{display:flex;flex-direction:column}.filter-group label{color:var(--text-primary);font-size:13px;font-weight:600;margin-bottom:6px}.filter-group select{background-color:var(--bg-inset);border:2px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:14px;padding:12px 14px;transition:all var(--transition-fast)}.filter-group select:focus{background:var(--bg-card);border-color:var(--primary-400);box-shadow:0 0 0 4px #08c4a81a;outline:none;width:100%}.recommendations-section{animation:fadeInUp .4s ease-out;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:28px;padding:28px}.recommendations-section h2{font-size:1.125rem;margin-bottom:16px}.recommendations-info{grid-gap:16px;background:var(--bg-inset);border:1px solid var(--border-light);border-radius:var(--radius-lg);display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px;padding:16px 20px}.recommendations-info p{color:var(--text-secondary);font-size:13px;margin:0}.recommendations-info strong{color:var(--primary-600);font-family:var(--font-display);font-size:1.125rem}.meals-grid{background:#0000;border:none;display:flex;flex-direction:column;gap:12px;padding:0}.meal-card{background:#00000008;background:var(--bg-hover,#00000008);border:1px solid var(--border-light);border-radius:var(--radius-md);justify-content:space-between;overflow:hidden;padding:12px 14px;position:relative;transition:all var(--transition-fast);width:100%}.meal-card,.meal-header{align-items:center;display:flex}.meal-header{flex-direction:row;gap:8px}.meal-header h3{color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.meal-details{align-items:flex-end;flex-direction:column;gap:6px}.meal-card:before{background:var(--gradient-primary);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-normal)}.meal-card:hover{background:var(--bg-card);border-color:var(--primary-200);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.meal-card:hover:before{opacity:1}.tag{border-radius:var(--radius-full);font-size:11px;font-weight:600;padding:4px 10px;white-space:nowrap}.tag.veg{background:#10b9811a;color:var(--success-600)}.tag.non-veg{background:#f973161a;color:var(--accent-600)}.meal-card .category{display:none}.meal-details{align-items:center;display:flex;font-size:12px;gap:12px;justify-content:flex-end;margin:0}.meal-type{color:var(--text-tertiary)}.credits-badge{background:var(--gradient-primary);border-radius:var(--radius-full);color:#fff;font-size:12px;font-weight:700;padding:4px 10px}.meal-meta{margin-bottom:14px}.meal-meta p{color:var(--text-tertiary);font-size:13px;margin:0}.meal-card .btn{width:100%}.no-results{color:var(--text-tertiary);padding:40px 20px;text-align:center}.no-results p{margin:8px 0}.progress-section{animation:fadeInUp .5s ease-out .3s backwards;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:28px}.progress-section h2{font-size:1.125rem;margin-bottom:20px}.progress-bar-container{background:var(--bg-inset);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:16px}.progress-bar{background:var(--slate-200);height:10px;margin-bottom:12px;overflow:hidden}.progress-bar,.progress-fill{border-radius:var(--radius-full)}.progress-fill{background:var(--gradient-primary);height:100%;transition:width .6s ease}.progress-text{color:var(--text-tertiary);font-size:13px;font-weight:500;margin:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.smart-suggestions{padding:20px}.suggestions-header h1{font-size:1.75rem}.budget-cards{grid-template-columns:1fr 1fr}.meals-grid{background:#00000008;background:var(--bg-hover,#00000008);border:2px dashed #08c4a866;border:2px dashed var(--primary-300,#08c4a866);border-radius:16px;border-radius:var(--radius-xl,16px);display:flex;flex-direction:column;gap:16px;padding:24px}.recommendations-info{gap:8px;grid-template-columns:1fr}}.menu-page{margin:0 auto;max-width:1200px;min-height:calc(100vh - var(--navbar-height));padding:32px}.menu-page .page-header{align-items:center;animation:fadeInUp .5s ease-out;display:flex;flex-wrap:wrap;gap:16px;gap:1.5rem;justify-content:center;margin-bottom:32px}.menu-page .page-header h1{font-family:var(--font-display);font-size:2rem;font-weight:800;margin-bottom:4px}.menu-page .page-header p{color:var(--text-tertiary);font-size:15px}.date-selector select{appearance:none;background-color:var(--bg-inset);background-image:url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2212%22%20height%3D%2212%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M2%204L6%208L10%204%22%20fill%3D%22none%22%20stroke%3D%22%2308c4a8%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E");background-position:right 15px center;background-repeat:no-repeat;border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:0 4px 12px var(--shadow-sm);color:var(--text-primary);cursor:pointer;font-family:var(--font-sans);font-size:1rem;font-weight:600;outline:none;padding:12px 40px 12px 20px;transition:all var(--transition-normal)}.date-selector select:focus,.date-selector select:hover{border-color:var(--primary-500);box-shadow:0 6px 16px #08c4a826;transform:translateY(-1px)}.daily-menu-grid{grid-gap:24px;animation:slideUp .6s ease-out backwards;background:#00000008;background:var(--bg-hover,#00000008);border:2px dashed #08c4a866;border:2px dashed var(--primary-200,#08c4a866);border-radius:12px;border-radius:var(--radius-lg,12px);display:grid;gap:24px;grid-template-columns:1fr;padding:24px}@media (min-width:768px){.daily-menu-grid{grid-template-columns:repeat(2,1fr)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.meal-time-card{background:var(--bg-card);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='80' height='80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M50 50c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10s-10-4.477-10-10 4.477-10 10-10zM10 10c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10S0 25.523 0 20s4.477-10 10-10zm10 8a8 8 0 1 0 0-16 8 8 0 0 0 0 16zm40 40a8 8 0 1 0 0-16 8 8 0 0 0 0 16z' fill='%2308c4a8' fill-opacity='.08' fill-rule='evenodd'/%3E%3C/svg%3E");border:2px solid #08c4a880;border:2px solid var(--primary-200,#08c4a880);border-radius:var(--radius-lg);box-shadow:0 4px 16px var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;padding:24px;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.meal-time-card:hover{border-color:#08c4a8;border-color:var(--primary-500,#08c4a8);box-shadow:0 12px 32px var(--shadow-md);transform:translateY(-4px)}.meal-section-inner{display:flex;flex-direction:column;height:100%;padding:24px}.meal-title{border-bottom:2px solid #08c4a833;border-bottom:2px solid var(--primary-100,#08c4a833);color:var(--primary-600);font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin-bottom:20px;margin-top:0;padding-bottom:12px;text-align:center;text-transform:capitalize}.meal-content{flex-grow:1;gap:14px}.diet-section,.meal-content{display:flex;flex-direction:column}.diet-section{gap:8px}.diet-header{align-items:center;color:var(--text-primary);display:flex;flex-direction:row;font-family:var(--font-display);font-size:1rem;font-weight:600;gap:6px;justify-content:center;margin:0}.meal-items-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.meal-item-row{grid-gap:16px;align-items:center;background-color:var(--bg-body);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:grid;gap:16px;grid-template-columns:1fr max-content;margin:0 auto;max-width:260px;padding:12px 16px;transition:background-color var(--transition-fast);width:100%}.meal-item-row:hover{background-color:var(--bg-card-hover)}.veg-indicator{align-items:center;border-radius:50%;display:inline-flex;flex-shrink:0;height:14px;justify-content:center;position:relative;width:14px}.veg-indicator:after{border-radius:50%;content:"";height:8px;width:8px}.veg-indicator.veg{background-color:#10b9811a;border:2px solid var(--emerald-500)}.veg-indicator.veg:after{background-color:var(--emerald-500)}.veg-indicator.non-veg{background-color:#ef44441a;border:2px solid #ef4444}.veg-indicator.non-veg:after{background-color:#ef4444}.item-name{color:var(--text-primary);font-family:var(--font-sans);font-size:.95rem;font-weight:500}.item-credits.badge{background:var(--bg-elevated);border-radius:var(--radius-full);box-shadow:0 2px 4px var(--shadow-sm);color:var(--text-primary);font-family:var(--font-display);font-size:.8rem;font-weight:700;padding:4px 8px}.empty-menu{background:var(--bg-card);border:1px dashed var(--border-light);border-radius:var(--radius-lg);box-shadow:0 4px 16px var(--shadow-sm);color:var(--text-secondary);font-family:var(--font-sans);font-size:1.1rem;font-weight:500;margin:2rem auto;max-width:600px;padding:4rem 2rem;text-align:center}.app-container{margin:0 auto;max-width:1400px}:root{--teal-50:#effefb;--teal-100:#c8fff3;--teal-200:#91fee8;--teal-300:#52f5d8;--teal-400:#20dfc2;--teal-500:#08c4a8;--teal-600:#039e8a;--teal-700:#077e70;--teal-800:#0b645a;--teal-900:#0e524a;--amber-50:#fffbeb;--amber-100:#fef3c7;--amber-200:#fde68a;--amber-300:#fcd34d;--amber-400:#fbbf24;--amber-500:#f59e0b;--amber-600:#d97706;--amber-700:#b45309;--amber-800:#92400e;--amber-900:#78350f;--rose-50:#fff1f2;--rose-400:#fb7185;--rose-500:#f43f5e;--rose-600:#e11d48;--emerald-50:#ecfdf5;--emerald-400:#34d399;--emerald-500:#10b981;--emerald-600:#059669;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-2xl:32px;--radius-full:999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:400ms cubic-bezier(0.4,0,0.2,1);--transition-spring:500ms cubic-bezier(0.34,1.56,0.64,1);--font-sans:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-display:"Outfit","DM Sans",sans-serif;--navbar-height:72px;--gradient-brand:linear-gradient(135deg,#08c4a8,#20dfc2 50%,#fbbf24);--gradient-brand-hover:linear-gradient(135deg,#039e8a,#08c4a8 50%,#f59e0b);--gradient-teal:linear-gradient(135deg,#20dfc2,#039e8a);--gradient-warm:linear-gradient(135deg,#fbbf24,#f59e0b);--gradient-dark:linear-gradient(135deg,#f7f8fa,#eef0f4);--gradient-dark-card:linear-gradient(145deg,#fff,#f7f8fa);--gradient-mesh:radial-gradient(at 15% 25%,#08c4a81a 0%,#0000 50%),radial-gradient(at 85% 15%,#fbbf2414 0%,#0000 50%),radial-gradient(at 50% 80%,#08c4a80d 0%,#0000 50%);--bg-body:#f4f6fa;--bg-card:#fff;--bg-card-hover:#fafbff;--bg-elevated:#fff;--bg-inset:#eff1f5;--bg-glass:#ffffffd9;--bg-glass-border:#08c4a81a;--bg-surface:#fff9;--primary-50:var(--teal-50);--primary-100:var(--teal-100);--primary-200:var(--teal-200);--primary-300:var(--teal-300);--primary-400:var(--teal-400);--primary-500:var(--teal-500);--primary-600:var(--teal-600);--primary-700:var(--teal-700);--primary-800:var(--teal-800);--primary-900:var(--teal-900);--accent-400:var(--amber-400);--accent-500:var(--amber-500);--accent-600:var(--amber-600);--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--danger-50:var(--rose-50);--danger-400:var(--rose-400);--danger-500:var(--rose-500);--danger-600:var(--rose-600);--warning-50:var(--amber-50);--warning-400:var(--amber-400);--warning-500:var(--amber-500);--warning-600:var(--amber-600);--success-50:var(--emerald-50);--success-400:var(--emerald-400);--success-500:var(--emerald-500);--success-600:var(--emerald-600);--slate-800:#1e293b;--slate-900:#0f172a;--gradient-primary:var(--gradient-brand);--gradient-primary-hover:var(--gradient-brand-hover);--gradient-success:linear-gradient(135deg,#10b981,#059669);--shadow-primary:var(--shadow-glow-teal);--shadow-primary-lg:var(--shadow-glow-teal-lg);--shadow-success:0 4px 14px #10b98166;--border-light:var(--border-subtle);--text-primary:#181d2a;--text-secondary:#4e5669;--text-tertiary:#717a90;--text-inverse:#fff;--text-teal:#08c4a8;--text-amber:#f59e0b;--border-subtle:#0000000a;--border-medium:#00000014;--border-teal:#08c4a84d;--border-amber:#fbbf2466;--shadow-xs:0 1px 3px #0000000d;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 12px 40px #0000001a;--shadow-xl:0 24px 60px #0000001f;--shadow-glow-teal:0 0 20px #08c4a833,0 0 60px #08c4a81a;--shadow-glow-amber:0 0 20px #fbbf2433,0 0 60px #fbbf241a;--shadow-glow-teal-lg:0 4px 24px #08c4a84d,0 0 80px #08c4a826;--shadow-glass:0 8px 32px #08c4a80f,inset 0 1px 0 #ffffff80;color-scheme:light}[data-theme=dark]{--gradient-dark:linear-gradient(135deg,#181d2a,#252b3b);--gradient-dark-card:linear-gradient(145deg,#1e2435,#161b28);--gradient-mesh:radial-gradient(at 15% 25%,#08c4a812 0%,#0000 50%),radial-gradient(at 85% 15%,#fbbf240d 0%,#0000 50%),radial-gradient(at 50% 80%,#08c4a80a 0%,#0000 50%);--bg-body:#0e111b;--bg-card:#161b28;--bg-card-hover:#1a2030;--bg-elevated:#1e2435;--bg-inset:#121620;--bg-glass:#161b28cc;--bg-glass-border:#ffffff0f;--bg-surface:#1e243599;--slate-50:#0f172a;--slate-100:#1e293b;--slate-200:#334155;--slate-300:#475569;--slate-400:#64748b;--slate-500:#94a3b8;--slate-600:#cbd5e1;--slate-700:#e2e8f0;--slate-800:#f1f5f9;--slate-900:#f8fafc;--primary-50:var(--teal-900);--primary-100:var(--teal-800);--primary-200:var(--teal-700);--primary-300:var(--teal-600);--primary-400:var(--teal-500);--primary-500:var(--teal-400);--primary-600:var(--teal-300);--primary-700:var(--teal-200);--primary-800:var(--teal-100);--primary-900:var(--teal-50);--accent-400:var(--amber-400);--accent-500:var(--amber-500);--accent-600:var(--amber-600);--danger-50:#4c0519;--danger-400:#e11d48;--danger-500:#f43f5e;--danger-600:#fb7185;--warning-50:#451a03;--warning-400:#d97706;--warning-500:#f59e0b;--warning-600:#fbbf24;--success-50:#022c22;--success-400:#059669;--success-500:#10b981;--success-600:#34d399;--gradient-success:linear-gradient(135deg,#10b981,#059669);--shadow-primary:var(--shadow-glow-teal);--shadow-primary-lg:var(--shadow-glow-teal-lg);--shadow-success:0 4px 14px #10b98166;--border-light:var(--border-subtle);--text-primary:#f0f2f7;--text-secondary:#a8afc0;--text-tertiary:#636c82;--text-inverse:#0e111b;--text-teal:#52f5d8;--text-amber:#fcd34d;--border-subtle:#ffffff0f;--border-medium:#ffffff1a;--shadow-xs:0 1px 3px #0000004d;--shadow-sm:0 2px 8px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 12px 40px #0009;--shadow-xl:0 24px 60px #000000b3;--shadow-glass:0 8px 32px #0006,inset 0 1px 0 #ffffff0d;color-scheme:dark}body{transition:background-color .25s cubic-bezier(.4,0,.2,1),color .25s cubic-bezier(.4,0,.2,1);transition:background-color var(--transition-normal),color var(--transition-normal)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;scroll-behavior:smooth}body{background-attachment:fixed;background-color:var(--bg-body);background-image:var(--gradient-mesh);color:var(--text-primary);font-family:var(--font-sans);line-height:1.6}#root,body{min-height:100vh}#root{width:100%}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-family:var(--font-display);font-weight:700;line-height:1.2}h1{font-size:2.25rem;letter-spacing:-.025em}h2{font-size:1.75rem;letter-spacing:-.02em}h3{font-size:1.375rem;letter-spacing:-.015em}h4{font-size:1.125rem}h5{font-size:1rem}p{color:var(--text-secondary);margin-bottom:.75rem}::selection{background:var(--primary-500);color:#fff}::-moz-selection{background:var(--primary-500);color:#fff}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--primary-400)}a{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}:focus-visible{border-radius:4px;outline:2px solid var(--primary-400);outline-offset:2px}button{background:none;border:none;cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.app-container{padding-top:var(--navbar-height)}.loading-screen{align-items:center;background:var(--bg-body);display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:100vh}.loading-screen .spinner{animation:spin .8s linear infinite;border:4px solid var(--primary-100);border-radius:50%;border-top-color:var(--primary-500);height:48px;width:48px}.loading-screen p{color:var(--primary-600);font-family:var(--font-display);font-size:1.125rem;font-weight:600}@keyframes spin{to{transform:rotate(1turn)}}.btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:14px;font-weight:600;gap:8px;justify-content:center;overflow:hidden;padding:12px 24px;position:relative;transition:all var(--transition-normal)}.btn:after{background:linear-gradient(#ffffff26,#0000);content:"";inset:0;opacity:0;position:absolute;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:var(--gradient-primary);box-shadow:var(--shadow-primary);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-card);border:2px solid var(--primary-200);box-shadow:var(--shadow-sm);color:var(--primary-600)}.btn-secondary:hover{background:var(--primary-50);border-color:var(--primary-400);transform:translateY(-1px)}.btn-success{background:var(--gradient-success);box-shadow:var(--shadow-success);color:#fff}.btn-success:hover{box-shadow:0 8px 24px #10b98152;transform:translateY(-2px)}.btn-danger{background:var(--danger-500);box-shadow:var(--shadow-danger);color:#fff}.btn-danger:hover{background:var(--danger-600);transform:translateY(-1px)}.btn-ghost{background:#0000;color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{background:var(--slate-100);color:var(--text-primary)}.btn-sm{border-radius:var(--radius-sm);font-size:13px;padding:8px 16px}.btn-lg{border-radius:var(--radius-lg);font-size:16px;padding:16px 32px}.btn-icon{align-items:center;border-radius:var(--radius-md);display:inline-flex;font-size:18px;height:36px;justify-content:center;padding:0;width:36px}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--bg-glass-border);box-shadow:var(--shadow-glass)}.toast-container{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{align-items:center;animation:toastSlideIn .4s var(--transition-spring) forwards;background:var(--slate-800);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);color:#fff;display:flex;font-size:14px;font-weight:500;gap:10px;min-width:280px;padding:14px 20px}.toast.success{background:linear-gradient(135deg,#059669,#10b981)}.toast.error{background:linear-gradient(135deg,#e11d48,#f43f5e)}.toast-icon{flex-shrink:0;font-size:18px}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(100%) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateX(0) scale(1)}to{opacity:0;transform:translateX(100%) scale(.95)}}@media (max-width:768px){h1{font-size:1.75rem}h2{font-size:1.375rem}h3{font-size:1.125rem}.btn-lg{font-size:15px;padding:14px 24px}}@media (max-width:480px){h1{font-size:1.5rem}h2{font-size:1.25rem}}
/*# sourceMappingURL=main.fd358962.css.map*/