@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=Montserrat:wght@500;600&display=swap";.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-family-base);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-wide);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:center;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.btn-md{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.btn-primary{background-color:var(--color-gold);color:#fff;border:2px solid var(--color-gold)}.btn-primary:hover:not(:disabled){background-color:var(--color-gold-light);border-color:var(--color-gold-light);transform:translateY(-2px);box-shadow:var(--shadow-gold)}.btn-secondary{background-color:var(--color-cream);color:var(--color-coffee-darker);border:2px solid var(--color-beige)}.btn-secondary:hover:not(:disabled){background-color:var(--color-cream-dark);border-color:var(--color-gold);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background-color:transparent;color:var(--color-gold);border:2px solid var(--color-gold)}.btn-outline:hover:not(:disabled){background-color:var(--color-gold);color:#fff}.btn-ghost{background-color:transparent;color:var(--color-coffee-dark);border:2px solid transparent}.btn-ghost:hover:not(:disabled){background-color:var(--color-cream-dark);border-color:var(--color-beige)}.btn-full-width{width:100%}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.input-wrapper-full-width{width:100%}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-brown-dark)}.input{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);font-family:var(--font-family-base);border:2px solid var(--color-gray);border-radius:var(--radius-md);background-color:#fff!important;transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-orange);box-shadow:0 0 0 3px #ff99331a}.input-error{border-color:var(--color-error)}.input-error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #f443361a}.input-error-message{font-size:var(--font-size-sm);color:var(--color-error)}.input-full-width{width:100%}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:99999;animation:fadeIn .2s ease-out;pointer-events:auto;padding:var(--spacing-xl)}.auth-modal{background-color:#fff;border-radius:var(--radius-xl);padding:var(--spacing-2xl);max-width:480px;width:100%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out;z-index:100000;pointer-events:auto;margin:auto}.close-hint{position:absolute;top:-50px;left:50%;transform:translate(-50%);background-color:#000000d9;color:#fff;padding:12px 24px;border-radius:var(--radius-lg);font-size:var(--font-size-sm);white-space:nowrap;animation:fadeInDown .3s ease-out;z-index:1;box-shadow:0 4px 12px #0000004d}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.auth-modal-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-coffee-dark);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.auth-modal-close:hover{background-color:var(--color-cream-dark);color:var(--color-coffee-darker)}.auth-modal-title{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);text-align:center;letter-spacing:var(--letter-spacing-tight)}.auth-modal-subtitle{text-align:center;color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-light)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg);position:relative;z-index:1}.auth-form input{pointer-events:auto;position:relative;z-index:1}.auth-error{padding:var(--spacing-md);background-color:#ffebee;border-left:4px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide)}.auth-success{padding:var(--spacing-md);background-color:#e8f5e9;border-left:4px solid #4CAF50;border-radius:var(--radius-md);color:#2e7d32;font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide)}.auth-forgot-password{text-align:right;margin-top:calc(var(--spacing-sm) * -1)}.auth-divider{display:flex;align-items:center;text-align:center;margin:var(--spacing-xl) 0;color:var(--color-gray-dark);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide)}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-beige)}.auth-divider span{padding:0 var(--spacing-md)}.google-login-btn{display:flex;align-items:center;justify-content:center}.auth-footer{text-align:center;margin-top:var(--spacing-xl);color:var(--color-coffee-dark);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide)}.auth-link{background:none;border:none;color:var(--color-gold);font-weight:var(--font-weight-semibold);cursor:pointer;text-decoration:underline;transition:color var(--transition-fast);font-family:var(--font-family-base);font-size:inherit;letter-spacing:inherit}.auth-link:hover{color:var(--color-coffee-dark)}@media (max-width: 768px){.auth-modal{padding:var(--spacing-xl);width:95%}.auth-modal-title{font-size:var(--font-size-2xl)}}.membership-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;border:1px solid;background-color:var(--background-color, #ffffff);font-size:12px;font-weight:600;white-space:nowrap}.membership-badge--small{padding:2px 6px;font-size:10px;gap:2px}.membership-badge--medium{padding:4px 8px;font-size:12px;gap:4px}.membership-badge--large{padding:6px 12px;font-size:14px;gap:6px}.membership-badge__icon{font-size:1em;line-height:1}.membership-badge__label{line-height:1}.locked-feature-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;background-color:#9e9e9e1a;border:1px solid rgba(158,158,158,.3);font-size:12px;color:var(--text-secondary, #666666)}.locked-feature-badge__icon{font-size:14px;line-height:1;opacity:.6}.locked-feature-badge__text{line-height:1.2}.locked-feature-badge__upgrade{padding:4px 8px;border-radius:4px;background-color:var(--accent-color, #ff6b6b);color:#fff;border:none;font-size:11px;font-weight:600;cursor:pointer;transition:background-color .2s ease;min-width:44px;min-height:28px}.locked-feature-badge__upgrade:hover{background-color:#ff5252}.locked-feature-badge__upgrade:focus{outline:2px solid var(--accent-color, #ff6b6b);outline-offset:2px}@media (prefers-color-scheme: dark){.membership-badge{background-color:var(--background-color-dark, #2a2a2a)}.locked-feature-badge{background-color:#9e9e9e33;border-color:#9e9e9e66;color:var(--text-secondary-dark, #999999)}}@media (prefers-contrast: high){.membership-badge,.locked-feature-badge{border-width:2px}}.navigation{background-color:#f5f1e8f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #00000026;position:fixed;top:0;left:0;right:0;width:100%;z-index:9999;isolation:isolate}.navigation-container{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-lg);max-width:1400px;margin:0 auto;gap:var(--spacing-md);min-height:60px}.navigation-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:1;min-width:0;flex-wrap:nowrap;overflow:hidden}.navigation-store-link{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);background-color:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast);font-family:var(--font-family-base);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide);color:var(--color-white);min-height:40px;min-width:80px;position:relative;overflow:hidden;flex-shrink:1}.navigation-store-icon{width:auto;height:24px;object-fit:contain;transition:opacity var(--transition-fast)}.navigation-store-text{position:absolute;font-family:var(--font-family-base);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide);color:var(--color-white);opacity:0;transition:opacity var(--transition-fast);pointer-events:none}.navigation-store-link:hover{background-color:var(--color-gold);border-color:var(--color-gold);color:var(--color-white)}.navigation-store-link:hover .navigation-store-icon{opacity:0}.navigation-store-link:hover .navigation-store-text{opacity:1}.navigation-back-to-main{padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-gold);border:1px solid var(--color-gold);border-radius:var(--radius-md);text-decoration:none;font-family:var(--font-family-base);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide);color:var(--color-white);transition:all var(--transition-fast)}.navigation-back-to-main:hover{background-color:var(--color-coffee-darker);border-color:var(--color-coffee-darker);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.navigation-logo{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-white);text-decoration:none;display:flex;align-items:center;gap:0;letter-spacing:var(--letter-spacing-wide);transition:color var(--transition-base);flex-shrink:1;min-width:0}.navigation-logo:hover{color:var(--color-gold)}.navigation-logo-icon{width:100px;height:100px;object-fit:contain;flex-shrink:0;min-width:100px}.navigation-logo-text{font-style:italic}.navigation-menu{display:flex;gap:var(--spacing-sm);list-style:none;align-items:center;flex-wrap:nowrap;overflow:visible;flex-shrink:1;min-width:0}.navigation-link{padding:var(--spacing-sm) var(--spacing-md);color:var(--color-white);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-wide);font-size:var(--font-size-sm);white-space:nowrap;display:inline-flex;align-items:center}.navigation-link:hover{background-color:#d4af3733;color:var(--color-gold)}.navigation-link-active{background-color:var(--color-gold);color:var(--color-coffee-darker);font-weight:var(--font-weight-medium)}.navigation-link-active:hover{background-color:var(--color-gold);color:var(--color-coffee-darker)}.navigation-language-toggle{padding:var(--spacing-sm) var(--spacing-md);background-color:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family-base);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide);color:var(--color-white);transition:all var(--transition-fast);white-space:nowrap;flex-shrink:1;min-width:fit-content}.navigation-language-toggle:hover{background-color:var(--color-gold);border-color:var(--color-gold);color:var(--color-coffee-darker)}.navigation-auth-button-combined{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-gold);border:1px solid var(--color-gold);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family-base);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-wide);color:var(--color-coffee-darker);transition:all var(--transition-fast);white-space:nowrap;flex-shrink:1;min-width:fit-content}.navigation-auth-button-combined:hover{background-color:var(--color-white);border-color:var(--color-white);color:var(--color-coffee-darker)}.navigation-user{position:relative}.navigation-user-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background-color:transparent;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family-base);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-white);transition:all var(--transition-fast);flex-shrink:1;min-width:fit-content}.navigation-user-button:hover{background-color:#d4af3733;border-color:var(--color-gold)}.navigation-user-avatar,.navigation-user-avatar-placeholder{width:32px;height:32px;border-radius:50%;object-fit:cover}.navigation-user-avatar-placeholder{display:flex;align-items:center;justify-content:center;background-color:var(--color-gold);color:var(--color-white);font-weight:var(--font-weight-semibold)}.navigation-user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navigation-user-menu{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:200px;background-color:#f5f1e8;border:1px solid var(--color-beige);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown)}.navigation-user-menu-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-beige)}.navigation-user-menu-name{font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs)}.navigation-user-menu-email{font-size:var(--font-size-sm);color:var(--color-coffee);margin-bottom:var(--spacing-sm)}.navigation-user-menu-membership{margin-top:var(--spacing-sm);display:flex;justify-content:center}.navigation-user-menu-membership .membership-badge{width:100%;justify-content:center;font-size:.85rem;padding:.4rem .8rem}.navigation-user-menu-item{width:100%;padding:var(--spacing-md);background:none;border:none;text-align:left;font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-coffee-dark);cursor:pointer;transition:background-color var(--transition-fast)}.navigation-user-menu-item:hover{background-color:var(--color-cream-dark)}.navigation-user-menu-item:last-child{border-top:1px solid var(--color-beige);color:var(--color-error)}.navigation-mobile-toggle{display:none;background:none;border:none;font-size:var(--font-size-2xl);cursor:pointer;color:var(--color-coffee-dark)}@media (max-width: 1200px){.navigation-container{gap:var(--spacing-sm)}.navigation-actions{gap:4px}.navigation-store-link{padding:var(--spacing-xs) var(--spacing-sm);min-width:40px;min-height:36px}.navigation-store-text{display:none}.navigation-auth-button-combined,.navigation-language-toggle{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs);min-width:auto}.navigation-user-button{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.navigation-user-name{display:none}.navigation-user-avatar,.navigation-user-avatar-placeholder{width:28px;height:28px}}@media (max-width: 768px){.navigation-container{padding:4px 8px;gap:4px}.navigation-logo-icon{width:90px;height:90px}.navigation-store-link{padding:var(--spacing-xs) var(--spacing-sm);min-height:32px;min-width:36px}.navigation-store-icon{height:20px}.navigation-store-text{display:none}.navigation-language-toggle{display:none!important}.navigation-actions{gap:4px;flex-wrap:nowrap;overflow:hidden}.navigation-mobile-toggle{font-size:24px;padding:4px;display:block!important;flex-shrink:0}.navigation-menu{display:none;position:absolute;top:100%;left:0;right:0;background-color:#fff;flex-direction:column;padding:var(--spacing-md);box-shadow:var(--shadow-lg)}.navigation-menu.open{display:flex;background-color:#fff}.navigation-link{background-color:#fff;color:#4a3728;padding:var(--spacing-md);border-bottom:1px solid #f0f0f0}.navigation-link:hover{background-color:#f5f1e8;color:#d4af37}.navigation-link-active{background-color:#d4af37;color:#fff}.navigation-auth-button-combined{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);min-width:auto;flex-shrink:0}.navigation-user-button{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);flex-shrink:0}.navigation-user-name{display:none}.navigation-user-avatar,.navigation-user-avatar-placeholder{width:24px;height:24px}.navigation-user-menu{right:auto;left:0;width:100%}}@media (max-width: 1024px) and (min-width: 769px){.navigation-logo-text{display:none}.navigation-logo-icon{width:80px;height:80px}}.navigation-dropdown{position:relative}.navigation-dropdown-toggle{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.25rem;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-wide);color:var(--color-white);transition:all .3s ease;border-radius:var(--radius-md);white-space:nowrap;line-height:1.5;font-family:var(--font-family-base)}.navigation-dropdown-toggle:hover{background-color:#d4af3733;color:var(--color-gold)}.navigation-dropdown-arrow{font-size:.7rem;transition:transform .3s ease;margin-left:.25rem}.navigation-dropdown:hover .navigation-dropdown-arrow{transform:rotate(180deg)}.navigation-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--color-cream);border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000026;min-width:220px;padding:var(--spacing-sm) 0;list-style:none;z-index:99999;animation:dropdownFadeIn .2s ease;border:1px solid rgba(212,175,55,.3);opacity:1;pointer-events:auto;visibility:visible;display:block}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.navigation-dropdown-menu li{margin:0}.navigation-dropdown-link{display:block;padding:var(--spacing-sm) var(--spacing-lg);color:var(--color-coffee-darker);text-decoration:none;transition:all .2s ease;white-space:nowrap;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-normal);background-color:transparent}.navigation-dropdown-link:hover{background:var(--color-cream-dark);color:var(--color-coffee-darker);font-weight:var(--font-weight-semibold)}.navigation-dropdown-link-active{background:var(--color-gold);color:var(--color-white);font-weight:var(--font-weight-semibold)}@media (max-width: 768px){.navigation-dropdown-menu{position:static;box-shadow:none;background:#fff!important;border-radius:0;margin-top:var(--spacing-xs);padding-left:var(--spacing-lg);border:none;border-left:2px solid var(--color-gold);-webkit-backdrop-filter:none!important;backdrop-filter:none!important;opacity:1!important;display:block}.navigation-dropdown-toggle{width:100%;justify-content:space-between;background-color:transparent!important;color:#4a3728!important}.navigation-dropdown-toggle:hover{background-color:var(--color-cream-dark)!important;color:#4a3728!important}.navigation-dropdown-arrow{margin-left:auto;color:#4a3728!important}.navigation-menu.open .navigation-dropdown{width:100%}.navigation-dropdown-link{padding:var(--spacing-sm) var(--spacing-md);background-color:#fff!important;color:#4a3728!important}.navigation-dropdown-link:hover{background-color:#f5f1e8!important;color:#4a3728!important}.navigation-dropdown-link-active{background-color:var(--color-gold)!important;color:#fff!important}}.quick-nav-toggle{display:none!important}.quick-nav-toggle:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 8px 24px #d4af3766}.quick-nav-toggle.open{background:var(--color-coffee-darker)}.quick-nav-toggle-icon{display:block;transition:transform var(--transition-base)}.quick-nav-toggle.open .quick-nav-toggle-icon{transform:rotate(90deg)}.quick-nav-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1150;animation:fadeIn .3s ease-out}.quick-nav-panel{position:fixed;right:-320px;top:120px;bottom:0;width:320px;background-color:var(--color-white);box-shadow:var(--shadow-xl);z-index:1160;transition:right var(--transition-base);display:flex;flex-direction:column;overflow:hidden}.quick-nav-panel.open{right:0}.quick-nav-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-coffee-dark) 100%);color:var(--color-white);border-bottom:2px solid var(--color-gold)}.quick-nav-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);margin:0}.quick-nav-close{background:none;border:none;color:var(--color-white);font-size:var(--font-size-2xl);cursor:pointer;padding:var(--spacing-xs);line-height:1;transition:transform var(--transition-fast);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.quick-nav-close:hover{transform:rotate(90deg);background-color:#fff3}.quick-nav-list{flex:1;overflow-y:auto;padding:var(--spacing-md)}.quick-nav-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:transparent;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;margin-bottom:var(--spacing-sm);position:relative}.quick-nav-item:hover{background-color:var(--color-cream-dark);transform:translate(-4px)}.quick-nav-item.active{background:linear-gradient(135deg,var(--color-gold) 0%,rgba(212,175,55,.8) 100%);color:var(--color-white);box-shadow:var(--shadow-sm)}.quick-nav-item.active:hover{background:linear-gradient(135deg,var(--color-coffee-dark) 0%,var(--color-coffee-darker) 100%)}.quick-nav-item-icon{font-size:var(--font-size-2xl);flex-shrink:0}.quick-nav-item-label{flex:1;font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-wide);color:var(--color-coffee-darker)}.quick-nav-item.active .quick-nav-item-label{color:var(--color-white);font-weight:var(--font-weight-semibold)}.quick-nav-item-external{font-size:var(--font-size-sm);opacity:.7;color:var(--color-coffee-dark)}.quick-nav-item.active .quick-nav-item-external{color:var(--color-white)}@media (max-width: 768px){.quick-nav-toggle{right:15px;width:45px;height:45px}.quick-nav-panel{width:100%;right:-100%;top:55px}}.quick-nav-list::-webkit-scrollbar{width:6px}.quick-nav-list::-webkit-scrollbar-track{background:var(--color-cream);border-radius:var(--radius-sm)}.quick-nav-list::-webkit-scrollbar-thumb{background:var(--color-gold);border-radius:var(--radius-sm)}.quick-nav-list::-webkit-scrollbar-thumb:hover{background:var(--color-coffee-dark)}.loading-screen{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 50%,var(--color-cream) 100%);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-out}.loading-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.loading-logo{width:120px;height:120px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.loading-logo img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(212,175,55,.3))}.loading-text{display:flex;align-items:baseline;gap:var(--spacing-xs);font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-coffee-darker);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide)}.loading-dots{display:flex;gap:2px}.loading-dots span{animation:blink 1.4s infinite;opacity:0}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,20%{opacity:0}50%{opacity:1}to{opacity:0}}.loading-subtext{font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-gold);letter-spacing:var(--letter-spacing-wider);font-weight:var(--font-weight-medium);animation:fadeInText .8s ease-out,pulse 2s ease-in-out infinite .8s;min-height:20px}@keyframes fadeInText{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.loading-bar{width:200px;height:3px;background-color:#d4af3733;border-radius:var(--radius-full);overflow:hidden;position:relative}.loading-bar-fill{position:absolute;top:0;left:0;height:100%;width:40%;background:linear-gradient(90deg,transparent 0%,var(--color-gold) 50%,transparent 100%);animation:slide 1.5s ease-in-out infinite}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}@media (max-width: 768px){.loading-logo{width:80px;height:80px}.loading-text{font-size:var(--font-size-xl)}.loading-bar{width:150px}}.footer{background:linear-gradient(135deg,#2c3e50,#34495e);color:#ecf0f1;padding:3rem 0 1rem;margin-top:4rem;font-family:Montserrat,sans-serif}.footer-container{max-width:1200px;margin:0 auto;padding:0 2rem}.footer-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:1.5rem}.footer-section-title{font-family:Playfair Display,serif;font-size:1.1rem;font-weight:600;color:#d4af37;margin:0 0 1rem;letter-spacing:.05em}.footer-section-links{list-style:none;padding:0;margin:0}.footer-section-links li{margin-bottom:.75rem}.footer-section-links a{color:#bdc3c7;text-decoration:none;font-size:.9rem;transition:color .3s ease}.footer-section-links a:hover{color:#d4af37}.footer-main-site-link{color:#d4af37;text-decoration:none;transition:color .3s ease;font-weight:500}.footer-main-site-link:hover{color:#f39c12;text-decoration:underline}.footer-bottom{text-align:center;padding-top:1rem}.footer-copyright{font-size:.85rem;color:#95a5a6;margin:0}@media (max-width: 768px){.footer{padding:2rem 0 1rem}.footer-container{padding:0 1rem}.footer-links{grid-template-columns:repeat(2,1fr);gap:1.5rem}.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}}@media (max-width: 480px){.footer-links{grid-template-columns:1fr}}.footer-social{margin-top:3rem;text-align:center}.footer-social-links{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem}.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;font-size:1.5rem;color:#bdc3c7;background:#ffffff0d;border-radius:50%;text-decoration:none;transition:all .3s ease;border:1px solid rgba(255,255,255,.1)}.footer-social-link svg{width:24px;height:24px;fill:currentColor}.footer-social-link:hover{background:#ffffff1a;transform:translateY(-3px);border-color:#d4af37;color:#d4af37}.pwa-install-prompt{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#8b7355,#6b5335);color:#fff;padding:var(--spacing-lg);box-shadow:0 -4px 12px #00000026;z-index:9999;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-install-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:var(--spacing-md)}.pwa-install-icon{font-size:2.5rem;flex-shrink:0}.pwa-install-text{flex:1}.pwa-install-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs);color:#fff}.pwa-install-description{font-size:var(--font-size-sm);color:#ffffffe6;margin:0}.pwa-install-ios-instructions{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:#ffffff1a;border-radius:var(--radius-md);font-size:var(--font-size-sm)}.pwa-install-ios-icon{display:inline-block;font-size:var(--font-size-lg);vertical-align:middle;margin:0 var(--spacing-xs)}.pwa-install-actions{display:flex;gap:var(--spacing-sm);flex-shrink:0}.pwa-install-actions button{white-space:nowrap}@media (max-width: 768px){.pwa-install-content{flex-direction:column;text-align:center}.pwa-install-actions{width:100%;justify-content:center}.pwa-install-actions button{flex:1}}@media (max-width: 480px){.pwa-install-prompt{padding:var(--spacing-md)}.pwa-install-icon{font-size:2rem}.pwa-install-title{font-size:var(--font-size-md)}.pwa-install-description{font-size:var(--font-size-xs)}.pwa-install-actions{flex-direction:column}.pwa-install-actions button{width:100%}}.card{background-color:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base);overflow:hidden;box-sizing:border-box}.card-hoverable:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.home{max-width:1200px;margin:0 auto}.home-hero-new{position:relative;width:100vw;height:100vh;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);margin-top:-140px;margin-bottom:var(--spacing-3xl);display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:0}@media (max-width: 768px){.home-hero-new{margin-top:-110px}}.home-hero-background{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(https://images.unsplash.com/photo-1556912173-46c336c7fd55?q=80&w=2070);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;background-color:#8b7355;animation:kenBurns 20s ease-in-out infinite alternate;z-index:0}@keyframes kenBurns{0%{transform:scale(1)}to{transform:scale(1.1)}}.home-hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f5f1e8d9,#f5f1e8bf,#8b73554d);z-index:1}.home-hero-content{position:relative;z-index:2;text-align:center;padding:var(--spacing-xl);max-width:900px}.home-hero-title-new{font-family:Unisono,Qurova,Poppins,sans-serif;font-size:4rem;font-weight:700;color:#2c2c2c;margin-bottom:var(--spacing-xl);line-height:1.3;display:flex;flex-direction:column;gap:var(--spacing-sm)}.home-hero-title-line1{font-style:italic;font-size:3.5rem;letter-spacing:.02em;animation:fadeInChar 1.5s ease-out forwards;opacity:0}.home-hero-title-line2{font-size:2rem;color:#8b7355;letter-spacing:.1em;animation:fadeInChar 1.5s ease-out .3s forwards;opacity:0}@keyframes fadeInChar{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home-hero-tagline{font-size:1.25rem;color:#2c2c2c;margin-bottom:var(--spacing-2xl);line-height:1.8;letter-spacing:.05em;font-weight:300;animation:fadeInUp 1s ease-out .6s forwards;opacity:0}.home-hero-cta{padding:var(--spacing-md) var(--spacing-2xl);font-size:1.125rem;font-weight:600;color:#8b7355;background:transparent;border:2px solid #D4AF37;border-radius:50px;cursor:pointer;transition:all .3s ease-out;letter-spacing:.1em;animation:fadeInUp 1s ease-out .9s forwards,breathe 2s ease-in-out 2s infinite;opacity:0;font-family:Noto Sans TC,sans-serif}.home-hero-cta:hover{background:#d4af37;color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #d4af3766}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.home-hero-scroll-indicator{position:absolute;bottom:var(--spacing-2xl);left:50%;transform:translate(-50%);z-index:2;animation:bounce 2s ease-in-out infinite;font-size:2rem;color:#8b7355;opacity:.6}@media (max-width: 768px){.home-hero-new{height:80vh}.home-hero-title-new{font-size:2.5rem}.home-hero-title-line1{font-size:2rem}.home-hero-title-line2{font-size:1.5rem}.home-hero-tagline{font-size:1rem;padding:0 var(--spacing-md)}.home-hero-cta{padding:var(--spacing-sm) var(--spacing-xl);font-size:1rem}}@media (max-width: 480px){.home-hero-new{height:70vh}.home-hero-title-new{font-size:2rem}.home-hero-title-line1{font-size:1.75rem}.home-hero-title-line2{font-size:1.25rem}.home-hero-tagline{font-size:.875rem}}.home-inspiration{margin-bottom:var(--spacing-xl);animation:fadeInDown .8s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.home-inspiration-content{text-align:center;padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,#d4af3714,#8b451308);border-left:3px solid var(--color-gold)}.home-inspiration-label{font-size:var(--font-size-xs);color:var(--color-gold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.home-inspiration-quote{font-size:var(--font-size-md);color:var(--color-coffee-darker);font-style:italic;line-height:var(--line-height-normal);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-light);letter-spacing:var(--letter-spacing-normal)}.home-inspiration-author{font-size:var(--font-size-sm);color:var(--color-coffee-dark);font-weight:var(--font-weight-normal);letter-spacing:var(--letter-spacing-normal)}.home-hero{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 100%);border-radius:var(--radius-xl);margin-bottom:var(--spacing-2xl)}.home-hero-logo{margin-bottom:var(--spacing-lg);animation:fadeInDown .6s ease-out}.home-hero-logo-image{max-width:280px;height:auto;margin:0 auto;display:block;filter:drop-shadow(0 4px 12px rgba(139,69,19,.15))}.home-hero-title{font-family:var(--font-family-heading);font-size:var(--font-size-5xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-xl);animation:fadeInUp .6s ease-out;display:flex;flex-direction:column;gap:0;font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);line-height:1.5}.home-hero-brand{font-style:italic;font-size:var(--font-size-4xl);color:var(--color-coffee-darker);letter-spacing:var(--letter-spacing-wide);font-family:Unisono,Qurova,Poppins,sans-serif;font-weight:500}.home-hero-subtitle-line{font-size:var(--font-size-2xl);font-weight:var(--font-weight-normal);color:var(--color-gold);letter-spacing:var(--letter-spacing-wider);font-family:var(--font-family-base)}.home-hero-description{font-size:var(--font-size-lg);color:var(--color-coffee-dark);max-width:700px;margin:0 auto var(--spacing-xl) auto;line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-wide);animation:fadeInUp .8s ease-out;font-weight:var(--font-weight-light)}.home-hero-4c{display:flex;justify-content:center;gap:var(--spacing-xl);flex-wrap:wrap;margin-top:var(--spacing-xl);animation:fadeInUp 1s ease-out}.home-hero-4c-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:#ffffff80;border-radius:var(--radius-lg);transition:all .3s cubic-bezier(.4,0,.2,1);min-width:100px}.home-hero-4c-item:hover{transform:translateY(-4px);background:#fffc;box-shadow:0 8px 20px #d4af3733}.home-hero-4c-icon{font-size:var(--font-size-3xl);transition:transform .3s cubic-bezier(.4,0,.2,1)}.home-hero-4c-item:hover .home-hero-4c-icon{transform:scale(1.2)}.home-hero-4c-text{font-size:var(--font-size-sm);color:var(--color-coffee-darker);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home-section-title{text-align:center;margin-bottom:var(--spacing-xl);color:var(--color-coffee-darker);font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight)}.home-quick-start{margin-bottom:var(--spacing-2xl)}.home-quick-start-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}.home-quick-start-card{cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:center;padding:var(--spacing-lg) var(--spacing-md);background:linear-gradient(135deg,#d4af370d,#8b451305)}.home-quick-start-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d4af3740;background:linear-gradient(135deg,#d4af371a,#8b45130d)}.home-quick-start-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm);transition:transform .3s cubic-bezier(.4,0,.2,1)}.home-quick-start-card:hover .home-quick-start-icon{transform:scale(1.15)}.home-quick-start-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);letter-spacing:var(--letter-spacing-normal)}.home-categories{margin-bottom:var(--spacing-3xl)}.home-categories-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}.home-category-card{cursor:default;transition:all .3s cubic-bezier(.4,0,.2,1);padding:var(--spacing-xl)}.home-category-card:hover{box-shadow:0 8px 24px #d4af3726}.home-category-header{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid rgba(212,175,55,.2)}.home-category-icon{font-size:2.5rem;flex-shrink:0}.home-category-info{flex:1}.home-category-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs);font-family:var(--font-family-heading);letter-spacing:var(--letter-spacing-tight)}.home-category-description{font-size:var(--font-size-sm);color:var(--color-coffee-dark);font-weight:var(--font-weight-light);letter-spacing:var(--letter-spacing-normal)}.home-category-features{display:flex;flex-direction:column;gap:var(--spacing-md)}.home-category-feature-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:#ffffff80}.home-category-feature-item:hover{background:linear-gradient(135deg,#d4af3714,#8b451308);transform:translate(4px)}.home-category-feature-icon{font-size:1.5rem;flex-shrink:0;transition:transform .2s cubic-bezier(.4,0,.2,1)}.home-category-feature-item:hover .home-category-feature-icon{transform:scale(1.1)}.home-category-feature-content{flex:1;min-width:0}.home-category-feature-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.home-category-feature-badge{font-size:var(--font-size-xs);padding:2px var(--spacing-xs);background:linear-gradient(135deg,#d4af3733,#d4af371a);border-radius:var(--radius-sm);font-weight:var(--font-weight-medium);white-space:nowrap}.home-category-feature-description{font-size:var(--font-size-sm);color:var(--color-coffee-dark);line-height:var(--line-height-normal);font-weight:var(--font-weight-light)}.home-features{margin-bottom:var(--spacing-3xl)}.home-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.home-features-grid>*{transition:all .3s ease;cursor:pointer}.home-features-grid>*:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.home-feature-card{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-sm);height:100%;padding:var(--spacing-md);overflow:hidden}.home-feature-icon{font-size:3rem;margin-bottom:var(--spacing-xs)}.home-feature-title{color:var(--color-coffee-darker);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.home-feature-subtitle{color:var(--color-gold);font-size:var(--font-size-xs);font-style:italic;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-light);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.home-feature-badge{background:linear-gradient(135deg,#d4af3726,#d4af370d);border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-coffee-darker);font-weight:var(--font-weight-medium);word-wrap:break-word;overflow-wrap:break-word}.home-feature-description{color:var(--color-coffee-dark);line-height:var(--line-height-normal);font-size:var(--font-size-sm);flex:1;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-light);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.home-about{margin-bottom:var(--spacing-2xl)}.home-about p{line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-wide);color:var(--color-coffee-dark);font-weight:var(--font-weight-light)}@media (max-width: 768px){.home-hero-logo-image{max-width:180px}.home-hero-title{font-size:var(--font-size-3xl)}.home-hero-brand{font-size:var(--font-size-2xl)}.home-hero-subtitle-line{font-size:var(--font-size-lg)}.home-hero-4c{gap:var(--spacing-md)}.home-hero-4c-item{min-width:80px;padding:var(--spacing-sm)}.home-hero-4c-icon{font-size:var(--font-size-2xl)}.home-hero-4c-text{font-size:var(--font-size-xs)}.home-quick-start-grid{grid-template-columns:repeat(2,1fr)}.home-categories-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.home-category-card{padding:var(--spacing-lg)}.home-features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.home-quick-start-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.home-quick-start-card{padding:var(--spacing-md) var(--spacing-sm)}.home-quick-start-icon{font-size:2rem}.home-quick-start-title{font-size:var(--font-size-xs)}.home-categories-grid{gap:var(--spacing-md)}.home-category-card{padding:var(--spacing-md)}.home-category-header{flex-direction:column;align-items:center;text-align:center}.home-features-grid{grid-template-columns:1fr}}.home-newsletter{margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-3xl)}.home-newsletter-title{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md);text-align:center;letter-spacing:var(--letter-spacing-tight)}.home-newsletter-description{font-size:var(--font-size-lg);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl);text-align:center;line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-light)}.home-newsletter button{display:block;margin:0 auto}.home-idia-link{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.home-idia-link-content{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.home-idia-link-icon{font-size:var(--font-size-2xl);transition:transform .3s cubic-bezier(.4,0,.2,1)}.home-idia-link-text{font-family:var(--font-family-heading);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);letter-spacing:var(--letter-spacing-wide)}.home-idia-link-arrow{font-size:var(--font-size-xl);color:var(--color-gold);transition:transform .3s cubic-bezier(.4,0,.2,1)}.home-idia-link:hover .home-idia-link-content{background:linear-gradient(135deg,#d4af3714,#8b451308)}.home-idia-link:hover .home-idia-link-icon{transform:scale(1.2) rotate(5deg)}.home-idia-link:hover .home-idia-link-arrow{transform:translate(8px)}@media (max-width: 768px){.home-idia-link-content{flex-direction:column;gap:var(--spacing-sm)}.home-idia-link-text{font-size:var(--font-size-md);text-align:center}}.card{position:relative;border-radius:var(--radius-lg);transition:var(--transition-normal);box-sizing:border-box;overflow:visible}.card-default{background:#fff;box-shadow:var(--shadow-md);border:1px solid transparent}.card-elevated{background:#fff;box-shadow:var(--shadow-lg);border:1px solid transparent}.card-outlined{background:#fff;border:2px solid var(--gray-200);box-shadow:none}.card-filled{background:linear-gradient(135deg,#d4af370d,#8b451305);border:1px solid transparent;box-shadow:var(--shadow-sm)}.card-padding-none{padding:0}.card-padding-sm{padding:var(--spacing-sm)}.card-padding-md{padding:var(--spacing-md)}.card-padding-lg{padding:var(--spacing-lg)}.card-padding-xl{padding:var(--spacing-xl)}.card-hoverable{cursor:pointer}.card-outlined.card-hoverable:hover{border-color:var(--color-gold);border-width:2px}.card-filled.card-hoverable:hover{background:linear-gradient(135deg,#d4af3714,#8b45130a)}.card-hoverable:focus{outline:2px solid var(--color-gold);outline-offset:2px}.card-hoverable:focus:not(:focus-visible){outline:none}.card-locked{opacity:.6;cursor:not-allowed}.card-locked.card-hoverable:hover{transform:none;box-shadow:var(--shadow-md);border-color:transparent}.card-locked.card-outlined.card-hoverable:hover{border-color:var(--gray-200)}.card-lock-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#ffffffb3;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;z-index:10}.card-lock-icon{font-size:3rem;opacity:.3;animation:lockPulse 2s ease-in-out infinite}@keyframes lockPulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.1);opacity:.5}}.card-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-sm);background:linear-gradient(135deg,#d4af3733,#d4af371a);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-coffee-darker);letter-spacing:var(--letter-spacing-wide);z-index:5;box-shadow:var(--shadow-sm)}@media (min-width: 768px) and (max-width: 1023px){.card-padding-lg{padding:var(--spacing-md)}.card-padding-xl{padding:var(--spacing-lg)}.card-lock-icon{font-size:2.5rem}}@media (max-width: 767px){.card-padding-lg,.card-padding-xl{padding:var(--spacing-md)}.card-lock-icon{font-size:2rem}.card-badge{top:var(--spacing-sm);right:var(--spacing-sm);padding:.125rem var(--spacing-xs);font-size:.625rem}.card-hoverable{min-height:44px}}@media (prefers-reduced-motion: reduce){.card,.card-hoverable,.card-lock-icon{animation:none;transition:none}.card-hoverable:hover{transform:none}}@media (prefers-contrast: high){.card-default,.card-elevated,.card-filled{border:2px solid currentColor}.card-lock-overlay{background:#ffffffe6}}@media print{.card{box-shadow:none;border:1px solid var(--gray-300);page-break-inside:avoid}.card-lock-overlay,.card-badge{display:none}}.hero{position:relative;width:100vw;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);margin-top:0;display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:1}.hero-small{height:30vh;min-height:300px}.hero-medium{height:50vh;min-height:400px}.hero-large{height:70vh;min-height:500px}.hero-full{height:100vh;min-height:600px}.hero-background{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-repeat:no-repeat;z-index:1}.hero-background{animation:fadeIn var(--duration-slow) var(--ease-out)}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2}.hero-content{position:relative;z-index:3;padding:var(--spacing-xl);max-width:900px;width:100%}.hero-align-left .hero-content{text-align:left;margin-right:auto}.hero-align-center .hero-content{text-align:center;margin-left:auto;margin-right:auto}.hero-align-right .hero-content{text-align:right;margin-left:auto}.hero-title{font-family:var(--font-family-serif-zh);font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);color:var(--color-dark);margin-bottom:var(--spacing-lg);line-height:var(--line-height-tight);text-shadow:0 2px 4px rgba(0,0,0,.1)}.hero-subtitle{font-size:var(--font-size-xl);font-weight:var(--font-weight-medium);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md);line-height:var(--line-height-normal);text-shadow:0 1px 2px rgba(0,0,0,.1)}.hero-description{font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl);line-height:var(--line-height-relaxed);text-shadow:0 1px 2px rgba(0,0,0,.1)}.hero-cta{padding:var(--spacing-md) var(--spacing-2xl);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);background:transparent;border:2px solid var(--color-gold);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-normal);letter-spacing:var(--letter-spacing-wide);font-family:var(--font-family-sans-zh)}.hero-cta:hover{background:var(--color-gold);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-gold)}.hero-cta:active{transform:translateY(0)}.hero-cta:focus{outline:2px solid var(--color-gold);outline-offset:4px}.hero-scroll-indicator{position:absolute;bottom:var(--spacing-2xl);left:50%;transform:translate(-50%);z-index:3;animation:bounce 2s ease-in-out infinite;font-size:2rem;color:var(--color-coffee);opacity:.6;cursor:pointer}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(10px)}}.hero-scroll-indicator:hover{opacity:1}.hero-animate-fade .hero-content{animation:heroFadeIn var(--duration-slow) var(--ease-out)}@keyframes heroFadeIn{0%{opacity:0}to{opacity:1}}.hero-animate-slide .hero-content{animation:heroSlideUp var(--duration-slow) var(--ease-out)}@keyframes heroSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-animate-zoom .hero-content{animation:heroZoomIn var(--duration-slow) var(--ease-out)}@keyframes heroZoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.hero-small{height:21vh;min-height:210px}.hero-medium{height:35vh;min-height:280px}.hero-large{height:49vh;min-height:350px}.hero-full{height:70vh;min-height:420px}.hero-title{font-size:var(--font-size-4xl)}.hero-subtitle{font-size:var(--font-size-lg)}.hero-description{font-size:var(--font-size-base)}.hero-cta{padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-base)}}@media (max-width: 480px){.hero-content{padding:var(--spacing-md)}.hero-title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-md)}.hero-subtitle{font-size:var(--font-size-base);margin-bottom:var(--spacing-sm)}.hero-description{font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.hero-cta{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}.hero-scroll-indicator{bottom:var(--spacing-lg);font-size:1.5rem}}@media (prefers-reduced-motion: reduce){.hero-background,.hero-content,.hero-scroll-indicator,.hero-cta{animation:none!important;transition:none!important}.hero-cta:hover{transform:none}}.hero-cta:focus-visible{outline:3px solid var(--color-gold);outline-offset:4px}@media (prefers-contrast: high){.hero-title,.hero-subtitle,.hero-description{text-shadow:none}.hero-overlay{background:#f5f1e8f2!important}}.hero-background,.hero-overlay,.hero-content{will-change:transform,opacity}.hero-animate-fade .hero-content,.hero-animate-slide .hero-content,.hero-animate-zoom .hero-content{animation-fill-mode:forwards}.hero-background{background-color:var(--color-cream)}@media print{.hero{height:auto!important;min-height:0!important;page-break-inside:avoid}.hero-background,.hero-overlay,.hero-scroll-indicator,.hero-cta{display:none}}.calculator-selector{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg, 1.5rem);animation:fadeIn .4s ease-out}.calculator-page-header{text-align:center;padding:var(--spacing-3xl, 3rem) 0;max-width:800px;margin:0 auto}.calculator-page-title{font-size:var(--font-size-3xl, 2rem);font-weight:var(--font-weight-bold, 700);color:var(--color-coffee-darker, #2c2c2c);font-family:var(--font-family-serif-zh, "Noto Serif TC", serif);margin-bottom:var(--spacing-md, 1rem);letter-spacing:.02em}.calculator-page-subtitle{font-size:var(--font-size-lg, 1.125rem);color:var(--color-coffee-dark, #666);line-height:var(--line-height-relaxed, 1.75);font-weight:var(--font-weight-light, 300)}.calculator-section{margin-top:var(--spacing-3xl, 3rem);margin-bottom:var(--spacing-3xl, 3rem);width:100%}.calculator-section-title{font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--color-coffee-darker, #2c2c2c);font-family:var(--font-family-serif-zh, "Noto Serif TC", serif);margin-bottom:var(--spacing-xl, 2rem);padding-bottom:var(--spacing-md, 1rem);border-bottom:2px solid var(--color-gold, #d4af37);position:relative;text-align:center}.calculator-section-title:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:60px;height:2px;background:var(--color-gold, #d4af37);box-shadow:0 0 8px #d4af3780}.calculator-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg, 1.5rem);width:100%;margin:0 auto}.calculator-card-wrapper{position:relative}.calculator-card-wrapper.calculator-card-active{border-color:var(--color-gold, #d4af37)!important;box-shadow:0 8px 20px #d4af374d!important}.calculator-card-wrapper.calculator-card-active:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,var(--color-gold, #d4af37),var(--color-coffee, #8B7355));border-radius:var(--radius-lg, .75rem);z-index:-1;opacity:.3;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.5}}.calculator-card-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md, 1rem);text-align:center;aspect-ratio:1 / 1;min-height:200px}.calculator-icon{font-size:2.5rem;color:var(--color-coffee, #8B7355);transition:transform var(--duration-normal, .3s) var(--ease-out, ease-out);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.calculator-card-wrapper:hover .calculator-icon{transform:scale(1.15);filter:drop-shadow(0 4px 8px rgba(212,175,55,.3))}.calculator-title{font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--color-coffee-darker, #2c2c2c);margin:0;transition:color var(--duration-fast, .2s) var(--ease-out, ease-out);text-align:center;line-height:1.3}.calculator-card-wrapper:hover .calculator-title{color:var(--color-gold, #d4af37)}.calculator-description{font-size:var(--font-size-sm, .875rem);color:var(--color-coffee-dark, #666);line-height:var(--line-height-normal, 1.5);margin:0;text-align:center}.upgrade-hint{font-size:var(--font-size-sm, .875rem);color:var(--color-coffee, #8B7355);font-weight:var(--font-weight-medium, 500);margin-top:var(--spacing-sm, .5rem);display:flex;align-items:center;gap:var(--spacing-xs, .25rem)}.upgrade-hint:before{content:"🔒";font-size:1rem}@media (max-width: 1024px){.calculator-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.calculator-section{padding:0 var(--spacing-md, 1rem)}.calculator-section-title{font-size:var(--font-size-xl, 1.25rem)}.calculator-grid{grid-template-columns:1fr;gap:var(--spacing-md, 1rem)}.calculator-icon{font-size:2rem}.calculator-title{font-size:var(--font-size-base, 1rem)}.calculator-description{font-size:var(--font-size-xs, .75rem)}}@media (max-width: 480px){.calculator-grid{grid-template-columns:1fr}.calculator-section{margin-top:var(--spacing-2xl, 2.5rem);margin-bottom:var(--spacing-2xl, 2.5rem)}.calculator-card-content{aspect-ratio:auto;min-height:180px}}.why-precision-section{padding:var(--spacing-3xl, 3rem) var(--spacing-lg, 1.5rem);margin-top:var(--spacing-4xl, 4rem);width:100%;display:flex;flex-direction:column;align-items:center}.precision-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg, 1.5rem);width:100%}.precision-cards-grid .card{cursor:default;transition:all .3s ease;background:var(--color-cream, #F5F1E8)}.precision-cards-grid .card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.precision-card-content{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-sm, .5rem);justify-content:center;aspect-ratio:1 / 1;min-height:200px}.precision-icon{font-size:3rem;margin-bottom:var(--spacing-xs, .25rem);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform var(--duration-normal, .3s) var(--ease-out, ease-out)}.precision-cards-grid .card:hover .precision-icon{transform:scale(1.1)}.precision-title{color:var(--color-coffee-darker, #2c2c2c);font-size:var(--font-size-lg, 1.125rem);margin-bottom:var(--spacing-xs, .25rem);font-family:var(--font-family-serif-zh, "Noto Serif TC", serif);font-weight:var(--font-weight-semibold, 600);margin:0}.precision-description{color:var(--color-coffee-dark, #666);line-height:var(--line-height-normal, 1.5);font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-light, 300);margin:0}@media (max-width: 1024px){.precision-cards-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md, 1rem)}}@media (max-width: 768px){.precision-cards-grid{grid-template-columns:1fr}.why-precision-section{padding:var(--spacing-2xl, 2.5rem) var(--spacing-md, 1rem);margin-top:var(--spacing-3xl, 3rem)}.precision-icon{font-size:2.5rem}.precision-title{font-size:var(--font-size-base, 1rem)}.precision-description{font-size:var(--font-size-xs, .75rem)}}@media (prefers-reduced-motion: reduce){.calculator-selector,.calculator-card-wrapper,.calculator-icon,.calculator-title,.precision-icon{animation:none!important;transition:none!important}.calculator-card-wrapper.calculator-card-active:before{animation:none!important}}.calc-form{display:flex;flex-direction:column;gap:1rem}.calc-form input,.calc-form select{background-color:#fff!important}.calc-form h3{margin-bottom:1rem;color:var(--text-primary, #2c2c2c)}.select-group{display:flex;flex-direction:column;gap:.5rem}.select-group label{font-weight:500;color:var(--text-primary, #2c2c2c)}.select-group select{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background-color:#fff!important;cursor:pointer;transition:border-color .3s ease}.select-group select option{background-color:#fff!important;color:var(--text-primary, #2c2c2c);padding:.5rem}.select-group select:focus{outline:none;border-color:var(--gold, #d4af37)}.checkbox-group{display:flex;align-items:center;gap:.5rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-group input[type=checkbox]{width:1.2rem;height:1.2rem;cursor:pointer}.calc-result{margin-top:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#fff9e6,#fff);border:2px solid var(--gold, #d4af37);border-radius:12px}.calc-result p{margin:.5rem 0;font-size:1rem;color:var(--text-primary, #2c2c2c)}.calc-result .calc-total{margin-top:1rem;padding-top:1rem;border-top:2px solid var(--gold, #d4af37);font-size:1.1rem;color:var(--gold, #d4af37)}.calc-result .calc-price{font-size:1.2rem;color:var(--gold, #d4af37);font-weight:600}.calc-hint{margin-top:.5rem;font-size:.9rem;color:var(--text-secondary, #666);font-style:italic}.calc-error{margin-top:1rem;padding:1rem;background:#ffe6e6;border:2px solid #ff4444;border-radius:8px;color:#c00;font-weight:500}@media (max-width: 768px){.calc-form{gap:.75rem}.calc-result{padding:1rem}.calc-result p{font-size:.95rem}}.hydration-calculator{padding:1rem}.hydration-calculator-header{margin-bottom:2rem;text-align:center}.hydration-calculator-title{font-size:1.75rem;font-weight:600;color:#2c3e50;margin-bottom:.5rem}.hydration-calculator-description{font-size:.95rem;color:#7f8c8d;margin:0}.hydration-calculator-inputs{display:grid;gap:2rem;margin-bottom:2rem}.ingredient-group{background:#f8f9fa;padding:1.5rem;border-radius:8px}.ingredient-group-title{font-size:1.25rem;font-weight:600;color:#34495e;margin-bottom:1rem}.ingredient-entry{display:grid;grid-template-columns:2fr 1.5fr .8fr auto;gap:.5rem;align-items:center;margin-bottom:.75rem}.ingredient-label-input,.ingredient-weight-input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s;background-color:#fff!important}.ingredient-label-input:focus,.ingredient-weight-input:focus{outline:none;border-color:#3498db}.ingredient-unit-select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s}.ingredient-unit-select:focus{outline:none;border-color:#3498db}.ingredient-remove-btn{width:36px;height:36px;border:none;background:#e74c3c;color:#fff;border-radius:4px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.ingredient-remove-btn:hover{background:#c0392b}.ingredient-remove-btn:active{transform:scale(.95)}.hydration-calculator-actions{margin-bottom:2rem}.hydration-calculator-result{min-height:200px}.hydration-placeholder{text-align:center;padding:3rem 1rem;color:#95a5a6;font-size:1rem}.hydration-error{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:4px;text-align:center}.hydration-result{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;border-radius:12px;color:#fff}.hydration-totals{display:flex;justify-content:space-around;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.3)}.hydration-total-item{text-align:center}.hydration-total-label{display:block;font-size:.9rem;opacity:.9;margin-bottom:.5rem}.hydration-total-value{display:block;font-size:1.5rem;font-weight:600}.hydration-rate-display{text-align:center;margin-bottom:2rem}.hydration-rate-value{font-size:4rem;font-weight:700;line-height:1;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.hydration-rate-label{font-size:1.1rem;opacity:.95;text-transform:uppercase;letter-spacing:1px}.hydration-recipe-type{text-align:center;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.3)}.hydration-recipe-type-label{font-size:.95rem;opacity:.9;margin-bottom:.5rem}.hydration-recipe-type-value{font-size:1.5rem;font-weight:600}@media (min-width: 768px){.hydration-calculator-inputs{grid-template-columns:1fr 1fr}}@media (max-width: 767px){.hydration-calculator{padding:.75rem}.hydration-calculator-title{font-size:1.5rem}.ingredient-entry{grid-template-columns:1fr;gap:.5rem}.ingredient-remove-btn{width:100%;height:44px;margin-top:.25rem}.hydration-rate-value{font-size:3rem}.hydration-totals{flex-direction:column;gap:1rem}.ingredient-label-input,.ingredient-weight-input,.ingredient-unit-select{min-height:44px;font-size:16px}}@media (max-width: 480px){.hydration-calculator-header{margin-bottom:1.5rem}.ingredient-group{padding:1rem}.hydration-result{padding:1.5rem}.hydration-rate-value{font-size:2.5rem}}.hydration-recipe-actions{margin-top:2rem;padding-top:2rem;border-top:1px solid #e0e0e0}.hydration-recipe-actions-row{display:flex;gap:1rem;justify-content:center}.hydration-recipe-load{margin-top:1.5rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.hydration-recipe-load-label{display:block;font-size:.95rem;font-weight:600;color:#34495e;margin-bottom:.75rem}.hydration-recipe-load-select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s}.hydration-recipe-load-select:focus{outline:none;border-color:#3498db}@media (max-width: 767px){.hydration-recipe-actions-row{flex-direction:column}}.unit-converter{max-width:600px;margin:0 auto}.unit-converter-description{color:var(--color-gray-dark);margin-bottom:var(--spacing-lg)}.unit-converter-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.unit-converter-form input,.unit-converter-form select{background-color:#fff!important}.unit-converter-row{display:flex;gap:var(--spacing-md);align-items:flex-end}.unit-converter-select-group{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.unit-converter-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-brown-dark)}.unit-converter-select{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);font-family:var(--font-family-base);border:2px solid var(--color-gray);border-radius:var(--radius-md);background-color:var(--color-white);transition:all var(--transition-fast);cursor:pointer}.unit-converter-select option{background-color:#fff!important;color:var(--color-brown-dark);padding:var(--spacing-sm)}.unit-converter-select:focus{outline:none;border-color:var(--color-orange);box-shadow:0 0 0 3px #ff99331a}.unit-converter-arrow{font-size:var(--font-size-2xl);color:var(--color-orange);padding-bottom:var(--spacing-sm)}.unit-converter-result{padding:var(--spacing-md);background-color:var(--color-cream-dark);border-radius:var(--radius-md);border-left:4px solid var(--color-success);font-size:var(--font-size-lg)}.unit-converter-error{padding:var(--spacing-md);background-color:#ffebee;border-radius:var(--radius-md);border-left:4px solid var(--color-error);color:var(--color-error)}@media (max-width: 768px){.unit-converter-row{flex-direction:row;flex-wrap:wrap}.unit-converter-select-group{flex:1;min-width:120px}.unit-converter-arrow{padding-bottom:var(--spacing-sm);font-size:var(--font-size-xl)}}.recipe-scaler{max-width:1000px;margin:0 auto}.recipe-scaler-description{color:var(--color-gray-dark);margin-bottom:var(--spacing-lg)}.recipe-scaler-content{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-lg)}.recipe-scaler-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);font-family:var(--font-family-base);border:2px solid var(--color-gray);border-radius:var(--radius-md);background-color:var(--color-white);margin-bottom:var(--spacing-md);cursor:pointer}.recipe-scaler-servings{padding:var(--spacing-sm);background-color:var(--color-cream-dark);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.recipe-scaler-results{display:flex;flex-direction:column;gap:var(--spacing-lg)}.recipe-scaler-ingredients{display:flex;flex-direction:column;gap:var(--spacing-sm)}.recipe-scaler-ingredient{display:flex;justify-content:space-between;padding:var(--spacing-sm);background-color:var(--color-gray-light);border-radius:var(--radius-sm)}.ingredient-name{font-weight:var(--font-weight-medium)}.ingredient-quantity{color:var(--color-orange);font-weight:var(--font-weight-semibold)}@media (max-width: 768px){.recipe-scaler-content{grid-template-columns:1fr}}.nutrition-module{max-width:1200px;margin:0 auto}.nutrition-module-description{color:var(--color-gray-dark);margin-bottom:var(--spacing-xl);text-align:center}.nutrition-module-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.nutrient-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg);justify-content:center}.nutrient-grid .card{cursor:pointer;transition:all .3s ease;aspect-ratio:1 / 1;display:flex;flex-direction:column;justify-content:center}.nutrient-grid .card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.nutrient-card{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);height:100%;justify-content:center}.nutrient-card-active{border:2px solid var(--color-orange)}.nutrient-icon{font-size:3rem;margin-bottom:var(--spacing-xs)}.nutrient-name{color:var(--color-coffee-darker);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold)}.nutrient-description{color:var(--color-coffee-dark);line-height:var(--line-height-normal);font-size:var(--font-size-sm);font-weight:var(--font-weight-light)}.nutrient-detail{animation:fadeIn .3s ease-in;scroll-margin-top:120px}.nutrient-detail-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-cream-dark)}.nutrient-detail-icon{font-size:3rem}.nutrient-detail-section{margin-bottom:var(--spacing-lg)}.nutrient-detail-section h4{color:var(--color-orange);margin-bottom:var(--spacing-sm);font-size:var(--font-size-lg)}.nutrient-detail-section p{line-height:var(--line-height-relaxed);color:var(--color-gray-dark)}.nutrient-calorie-badge{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 100%);border-radius:var(--radius-md);border-left:4px solid var(--color-orange)}.nutrient-calorie-icon{font-size:2.5rem;flex-shrink:0}.nutrient-calorie-content{flex:1}.nutrient-calorie-label{color:var(--color-coffee-dark);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.nutrient-calorie-value{color:var(--color-orange);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);font-family:var(--font-family-heading)}.nutrient-calorie-unit{font-size:var(--font-size-md);color:var(--color-coffee-dark);font-weight:var(--font-weight-normal)}.nutrient-calorie-note{color:var(--color-gray-dark);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.nutrient-sources-list{list-style:none;padding:0}.nutrient-sources-list li{padding:var(--spacing-sm);margin-bottom:var(--spacing-sm);background-color:var(--color-cream);border-radius:var(--radius-md);line-height:var(--line-height-relaxed)}@media (max-width: 1024px){.nutrient-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.nutrient-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.nutrient-icon{font-size:2rem}.nutrient-name{font-size:var(--font-size-md)}.nutrient-description{font-size:var(--font-size-xs)}.nutrient-calorie-badge{flex-direction:column;text-align:center}.nutrient-calorie-icon{font-size:2rem}.nutrient-calorie-value{font-size:var(--font-size-lg)}}@media (max-width: 480px){.nutrient-grid{grid-template-columns:1fr}}.baking-ingredients-module{max-width:1200px;margin:0 auto}.baking-ingredients-module-description{color:var(--color-gray-dark);margin-bottom:var(--spacing-xl);text-align:center}.baking-ingredients-module-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.ingredient-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);justify-content:center}.ingredient-grid .card{cursor:pointer;transition:all .3s ease}.ingredient-grid .card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.ingredient-card{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.ingredient-card-active{border:2px solid var(--color-orange)}.ingredient-icon{font-size:3rem;margin-bottom:var(--spacing-xs)}.ingredient-name{color:var(--color-coffee-darker);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold)}.ingredient-description{color:var(--color-coffee-dark);line-height:var(--line-height-normal);font-size:var(--font-size-sm);font-weight:var(--font-weight-light)}.ingredient-detail{animation:fadeIn .3s ease-in;scroll-margin-top:120px}.ingredient-detail-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-cream-dark)}.ingredient-detail-icon{font-size:3rem}.ingredient-detail-section{margin-bottom:var(--spacing-lg)}.ingredient-detail-section h4{color:var(--color-orange);margin-bottom:var(--spacing-sm);font-size:var(--font-size-lg)}.ingredient-detail-section p{line-height:var(--line-height-relaxed);color:var(--color-gray-dark)}.ingredient-type{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-cream);border-radius:var(--radius-md)}.ingredient-type h5{color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.ingredient-type p{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.ingredient-tips-list{list-style:none;padding:0}.ingredient-tips-list li{padding:var(--spacing-sm);margin-bottom:var(--spacing-sm);background-color:var(--color-cream);border-radius:var(--radius-md);line-height:var(--line-height-relaxed)}.ingredient-calculators{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}@media (max-width: 768px){.ingredient-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.ingredient-icon{font-size:2rem}.ingredient-name{font-size:var(--font-size-md)}.ingredient-description{font-size:var(--font-size-xs)}}.ingredient-card-locked{opacity:.6;cursor:not-allowed!important;position:relative}.ingredient-lock-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);font-size:1.5rem;z-index:1}.ingredient-upgrade-hint{margin-top:var(--spacing-sm);font-size:.75rem;color:var(--color-primary);font-weight:600}.ingredient-upgrade-notice{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,#e6f7ff,#cef);border:1px solid #66ccff;border-radius:var(--border-radius-md);margin-top:var(--spacing-md)}.ingredient-upgrade-notice .ingredient-upgrade-icon{font-size:1.5rem;flex-shrink:0}.ingredient-upgrade-notice .ingredient-upgrade-content{flex:1}.ingredient-upgrade-notice .ingredient-upgrade-content strong{display:block;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:.95rem}.ingredient-upgrade-notice .ingredient-upgrade-content p{margin:0;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.baking-science-module{max-width:1200px;margin:0 auto}.baking-science-module-description{color:var(--color-gray-dark);margin-bottom:var(--spacing-xl);text-align:center}.baking-science-module-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.science-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);justify-content:center}.science-grid .card{cursor:pointer;transition:all .3s ease}.science-grid .card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.science-card{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.science-card-active{border:2px solid var(--color-orange)}.science-icon{font-size:3rem;margin-bottom:var(--spacing-xs)}.science-name{color:var(--color-coffee-darker);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold)}.science-description{color:var(--color-coffee-dark);line-height:var(--line-height-normal);font-size:var(--font-size-sm);font-weight:var(--font-weight-light)}.science-detail{animation:fadeIn .3s ease-in;scroll-margin-top:120px}.science-detail-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-cream-dark)}.science-detail-icon{font-size:3rem}.science-detail-section{margin-bottom:var(--spacing-lg)}.science-detail-section h4{color:var(--color-orange);margin-bottom:var(--spacing-sm);font-size:var(--font-size-lg)}.science-detail-section p{line-height:var(--line-height-relaxed);color:var(--color-gray-dark)}.science-factor{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-cream);border-radius:var(--radius-md)}.science-factor h5{color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.science-factor p{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.science-factor-range{color:var(--color-orange);font-weight:var(--font-weight-semibold)}.science-applications-list,.science-examples-list{list-style:none;padding:0}.science-applications-list li,.science-examples-list li{padding:var(--spacing-sm);margin-bottom:var(--spacing-sm);background-color:var(--color-cream);border-radius:var(--radius-md);line-height:var(--line-height-relaxed)}.science-calculators{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}@media (max-width: 768px){.science-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.science-icon{font-size:2rem}.science-name{font-size:var(--font-size-md)}.science-description{font-size:var(--font-size-xs)}}.science-card-locked{opacity:.6;cursor:not-allowed!important;position:relative}.science-lock-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);font-size:1.5rem;z-index:1}.science-upgrade-hint{margin-top:var(--spacing-sm);font-size:.75rem;color:var(--color-primary);font-weight:600}.science-upgrade-notice{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,#f0e6ff,#e0ccff);border:1px solid #cc99ff;border-radius:var(--border-radius-md);margin-top:var(--spacing-md)}.science-upgrade-notice .science-upgrade-icon{font-size:1.5rem;flex-shrink:0}.science-upgrade-notice .science-upgrade-content{flex:1}.science-upgrade-notice .science-upgrade-content strong{display:block;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:.95rem}.science-upgrade-notice .science-upgrade-content p{margin:0;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.cultural-history{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:12px;box-shadow:0 2px 8px #0000000d}.cultural-history-title{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:3px solid #e67e22;display:flex;align-items:center;gap:.5rem}.history-section{margin-bottom:1rem;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014;transition:box-shadow .3s ease}.history-section:hover{box-shadow:0 2px 6px #0000001f}.history-section:last-child{margin-bottom:0}.history-section-header{width:100%;display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fff;border:none;cursor:pointer;transition:background-color .2s ease;text-align:left;font-size:1rem}.history-section-header:hover{background-color:#f8f9fa}.history-section-header:focus{outline:2px solid #e67e22;outline-offset:-2px}.section-icon{font-size:1.5rem;flex-shrink:0}.section-title{flex:1;font-weight:600;color:#2c3e50;font-size:1.1rem}.expand-icon{font-size:.875rem;color:#7f8c8d;transition:transform .3s ease;flex-shrink:0}.expand-icon.expanded{transform:rotate(180deg)}.history-section-content{padding:1.25rem;border-top:1px solid #ecf0f1;animation:slideDown .3s ease}.history-text{line-height:1.8;color:#34495e;margin-bottom:1rem;text-align:justify}.history-text:last-child{margin-bottom:0}.history-meta{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding:1rem;background:#f8f9fa;border-radius:6px;border-left:4px solid #e67e22}.meta-item{display:flex;align-items:baseline;gap:.5rem}.meta-label{font-weight:600;color:#7f8c8d;font-size:.9rem}.meta-value{color:#2c3e50;font-size:.95rem}.historical-figure{padding:1rem;margin-bottom:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.historical-figure:last-child{margin-bottom:0}.figure-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.figure-name{font-size:1.1rem;font-weight:700;color:#2c3e50;margin:0}.figure-period{font-size:.9rem;color:#7f8c8d;font-style:italic}.figure-contribution,.figure-biography{margin-bottom:.75rem;line-height:1.7;color:#34495e}.figure-contribution:last-child,.figure-biography:last-child{margin-bottom:0}.figure-contribution strong,.figure-biography strong{color:#2c3e50;font-weight:600}.festival-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.festival-tag{display:inline-block;padding:.4rem .8rem;background:linear-gradient(135deg,#e67e22,#d35400);color:#fff;border-radius:20px;font-size:.85rem;font-weight:500;box-shadow:0 2px 4px #e67e2233;transition:transform .2s ease,box-shadow .2s ease}.festival-tag:hover{transform:translateY(-2px);box-shadow:0 4px 8px #e67e224d}@media (max-width: 768px){.cultural-history{padding:1rem;margin-top:1.5rem}.cultural-history-title{font-size:1.3rem}.history-section-header{padding:.875rem 1rem}.section-title{font-size:1rem}.section-icon{font-size:1.3rem}.history-section-content{padding:1rem}.figure-header{flex-direction:column;align-items:flex-start}.figure-name{font-size:1rem}.history-text{text-align:left}}@media (max-width: 480px){.cultural-history{padding:.75rem}.cultural-history-title{font-size:1.2rem}.history-section-header{padding:.75rem;gap:.5rem}.section-title{font-size:.95rem}.section-icon{font-size:1.2rem}.history-section-content,.historical-figure{padding:.875rem}.festival-tag{font-size:.8rem;padding:.35rem .7rem}}@media print{.cultural-history{box-shadow:none;background:#fff}.history-section{box-shadow:none;page-break-inside:avoid}.history-section-header{background:#fff}.expand-icon{display:none}.history-section-content{display:block!important}}.knowledge-detail{max-width:900px;margin:0 auto;padding:2rem 1rem;animation:fadeIn .3s ease-in}.detail-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.item-icon{font-size:4rem;line-height:1}.item-title{flex:1}.item-title h2{margin:0 0 .5rem;font-size:2rem;color:#2c3e50}.cert-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;text-transform:uppercase}.cert-badge.cert-core{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.cert-badge.cert-common{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.cert-badge.cert-extended{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.section-title{font-size:1.5rem;color:#2c3e50;margin:0 0 1rem;font-weight:600}.description-card,.explanation-card,.techniques-card,.tips-card,.examples-card,.parent-education-card,.certification-topics-card{margin-bottom:1.5rem}.item-description{font-size:1.125rem;color:#555;line-height:1.6;margin:0}.item-explanation{font-size:1rem;color:#666;line-height:1.8;margin:0}.content-list{list-style:none;padding:0;margin:0}.content-list li{padding:.75rem 0 .75rem 2rem;position:relative;color:#555;line-height:1.6;border-bottom:1px solid #f0f0f0}.content-list li:last-child{border-bottom:none}.content-list li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:700;font-size:1.2rem}.idia-badges-section{margin:2rem 0}.idia-badges{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem}.idia-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:25px;font-size:.875rem;font-weight:500;box-shadow:0 4px 6px #667eea4d;transition:transform .2s,box-shadow .2s}.idia-badge:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.badge-icon{font-size:1.2rem;font-weight:700}.badge-text{line-height:1.4}.octa-logic-section{margin:2rem 0}.octa-logic-items{display:grid;gap:1.5rem;margin-top:1rem}.octa-logic-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border:none}.framework-standard{font-size:1.25rem;color:#2c3e50;margin:0 0 .75rem;font-weight:600;text-transform:capitalize}.framework-description{font-size:1rem;color:#555;margin:0 0 1rem;font-weight:500}.framework-application{font-size:.95rem;color:#666;margin:0 0 1rem;line-height:1.6}.quality-checkpoints{font-size:.95rem;color:#666}.quality-checkpoints ul{margin:.5rem 0 0;padding-left:1.5rem}.quality-checkpoints li{margin:.5rem 0;line-height:1.5}.french-terminology-section{margin:2rem 0}.french-terminology-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.french-name{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.pronunciation-section{background:#ffffff1a;padding:1.25rem;border-radius:12px;margin:1.5rem 0}.ipa{display:flex;align-items:center;gap:.75rem;font-size:1.2rem;margin-bottom:1rem}.ipa-text{font-family:Doulos SIL,Charis SIL,Times New Roman,serif;font-size:1.3rem}.play-pronunciation-btn{background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .2s;color:#fff}.play-pronunciation-btn:hover{background:#ffffff4d;transform:scale(1.1)}.play-pronunciation-btn:active{transform:scale(.95)}.pronunciation-tips{font-size:.95rem;line-height:1.6}.etymology-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.2);font-size:.95rem;line-height:1.6}.literal-meaning{margin-top:1rem;font-style:italic}.french-terminology-card .label{font-weight:600;opacity:.9;margin-right:.5rem}.french-terminology-card .value{opacity:1}.parent-info{display:flex;flex-direction:column;gap:1rem}.parent-info>div{padding:.75rem 0;border-bottom:1px solid #f0f0f0}.parent-info>div:last-child{border-bottom:none}.parent-info strong{color:#2c3e50;margin-right:.5rem}.safety-considerations ul{margin:.5rem 0 0;padding-left:1.5rem}.safety-considerations li{margin:.5rem 0;line-height:1.5}.cert-topics{display:flex;flex-wrap:wrap;gap:.75rem}.cert-topic-tag{display:inline-block;padding:.5rem 1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border-radius:20px;font-size:.875rem;font-weight:500}.action-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:2px solid #f0f0f0}.action-btn{flex:1;min-width:200px;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #0000001a}.action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.action-btn:active{transform:translateY(0)}.quiz-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.audio-btn{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.game-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.btn-icon{font-size:1.5rem}.btn-text{font-size:1rem}.view-mode-parent .cert-badge,.view-mode-parent .certification-topics-card{display:none}.view-mode-certification .idia-badges-section,.view-mode-certification .octa-logic-section,.view-mode-certification .certification-topics-card{border:2px solid #f093fb;border-radius:12px;padding:1.5rem;background:#f093fb0d}.knowledge-internal-link{color:#667eea;text-decoration:none;border-bottom:1px solid rgba(102,126,234,.3);transition:all .2s ease;font-weight:500}.knowledge-internal-link:hover{color:#764ba2;border-bottom-color:#764ba2;background:#667eea0d}.french-terminology-card .knowledge-internal-link{color:#fffffff2;border-bottom-color:#fff6}.french-terminology-card .knowledge-internal-link:hover{color:#fff;border-bottom-color:#fff;background:#ffffff1a}@media (max-width: 768px){.knowledge-detail{padding:1rem .5rem}.detail-header{flex-direction:column;align-items:flex-start;gap:1rem}.item-icon{font-size:3rem}.item-title h2{font-size:1.5rem}.section-title{font-size:1.25rem}.idia-badges{flex-direction:column}.idia-badge{width:100%}.action-buttons{flex-direction:column}.action-btn{width:100%;min-width:auto}.french-name{font-size:1.25rem;flex-direction:column;align-items:flex-start}.ipa{flex-wrap:wrap}}@media (max-width: 480px){.item-icon{font-size:2.5rem}.item-title h2{font-size:1.25rem}.section-title{font-size:1.125rem}.item-description{font-size:1rem}.cert-topics{flex-direction:column}.cert-topic-tag{width:100%;text-align:center}}.quiz-system{max-width:800px;margin:0 auto}.quiz-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.quiz-back-button{background:none;border:none;font-size:var(--font-size-base);color:var(--primary-color);cursor:pointer;padding:var(--spacing-sm);transition:opacity var(--transition-base);font-weight:var(--font-weight-medium)}.quiz-back-button:hover{opacity:.7}.quiz-header h2{margin:0;flex-grow:1}.quiz-complete-actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.quiz-start{text-align:center;padding:var(--spacing-3xl)}.quiz-description{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xl);color:var(--color-coffee-dark);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-light)}.quiz-progress{margin-bottom:var(--spacing-xl);background-color:var(--color-white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.quiz-progress-bar{height:8px;background-color:var(--color-beige-light);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-md)}.quiz-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-gold),var(--color-coffee-light));transition:width var(--transition-base)}.quiz-progress-text{font-weight:var(--font-weight-medium);color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs);letter-spacing:var(--letter-spacing-wide)}.quiz-score{color:var(--color-gold);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide)}.quiz-question{display:flex;flex-direction:column;gap:var(--spacing-xl)}.quiz-question-text{font-family:var(--font-family-heading);color:var(--color-coffee-darker);font-size:var(--font-size-2xl);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-tight);margin-bottom:var(--spacing-md)}.quiz-hint{padding:var(--spacing-md) var(--spacing-lg);background-color:#fff9e6;border-left:4px solid var(--color-gold);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-coffee-dark);letter-spacing:var(--letter-spacing-wide)}.quiz-options{display:flex;flex-direction:column;gap:var(--spacing-md)}.quiz-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--color-white);border:2px solid var(--color-beige);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left;font-family:var(--font-family-base);font-size:var(--font-size-base);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-normal)}.quiz-option:hover:not(:disabled){border-color:var(--color-gold);background-color:var(--color-cream-dark);transform:translate(4px)}.quiz-option:disabled{cursor:not-allowed}.quiz-option-selected{border-color:var(--color-coffee-dark);background-color:var(--color-cream-dark)}.quiz-option-correct{border-color:var(--color-success);background-color:#e8f5e9}.quiz-option-incorrect{border-color:var(--color-error);background-color:#ffebee}.quiz-option-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--color-beige-light);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);flex-shrink:0}.quiz-option-selected .quiz-option-letter{background-color:var(--color-coffee-dark);color:var(--color-cream)}.quiz-option-correct .quiz-option-letter{background-color:var(--color-success);color:var(--color-white)}.quiz-option-incorrect .quiz-option-letter{background-color:var(--color-error);color:var(--color-white)}.quiz-option-text{flex:1;color:var(--color-coffee-dark)}.quiz-result{display:flex;gap:var(--spacing-lg);padding:var(--spacing-xl);border-radius:var(--radius-lg);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quiz-result-correct{background-color:#e8f5e9;border-left:4px solid var(--color-success)}.quiz-result-incorrect{background-color:#ffebee;border-left:4px solid var(--color-error)}.quiz-result-icon{font-size:2.5rem;font-weight:700;flex-shrink:0}.quiz-result-correct .quiz-result-icon{color:var(--color-success)}.quiz-result-incorrect .quiz-result-icon{color:var(--color-error)}.quiz-result-content{flex:1}.quiz-result-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm);letter-spacing:var(--letter-spacing-tight)}.quiz-result-answer{margin-bottom:var(--spacing-sm);letter-spacing:var(--letter-spacing-wide)}.quiz-result-explanation{font-size:var(--font-size-base);color:var(--color-coffee-dark);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-light)}.quiz-complete{text-align:center;padding:var(--spacing-xl) 0;animation:fadeInScale .5s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.quiz-complete-emoji{font-size:4rem;margin-bottom:var(--spacing-md);animation:bounce .6s ease-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.quiz-complete-title{font-family:var(--font-family-heading);color:var(--color-gold);margin-bottom:var(--spacing-md);font-size:var(--font-size-3xl);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-bold)}.quiz-complete-message{font-size:var(--font-size-lg);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl);letter-spacing:var(--letter-spacing-wide);line-height:var(--line-height-relaxed)}.quiz-complete-score{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md);color:var(--color-coffee-dark);letter-spacing:var(--letter-spacing-wide)}.quiz-complete-score strong{color:var(--color-gold);font-weight:var(--font-weight-bold)}.quiz-complete-percentage{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2xl);color:var(--color-coffee-dark);letter-spacing:var(--letter-spacing-wide)}.quiz-complete-percentage strong{color:var(--color-coffee-darker);font-weight:var(--font-weight-bold)}@media (max-width: 768px){.quiz-option{padding:var(--spacing-md)}.quiz-question-text{font-size:var(--font-size-xl)}}.quiz-integration{width:100%;max-width:800px;margin:0 auto}.quiz-integration-error,.quiz-integration-empty{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2rem}.quiz-integration-error .card,.quiz-integration-empty .card{text-align:center;padding:3rem}.quiz-integration-error p,.quiz-integration-empty p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.quiz-integration-results{display:flex;justify-content:center;align-items:center;min-height:500px;padding:2rem}.quiz-results-content{text-align:center;padding:3rem}.quiz-results-emoji{font-size:5rem;margin-bottom:1.5rem;animation:bounceIn .6s ease-out}.quiz-results-title{font-size:2rem;font-weight:700;color:var(--primary-color);margin-bottom:1rem}.quiz-results-message{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.quiz-results-score{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin:2rem 0;padding:2rem;background:linear-gradient(135deg,var(--primary-light) 0%,var(--primary-color) 100%);border-radius:16px;color:#fff}.quiz-results-score-number{font-size:3rem;font-weight:700}.quiz-results-score-percentage{font-size:1.5rem;font-weight:600;opacity:.9}.quiz-results-category{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.quiz-results-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.quiz-results-actions button{min-width:150px}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1)}}@media (max-width: 768px){.quiz-integration-results{padding:1rem}.quiz-results-content{padding:2rem 1rem}.quiz-results-emoji{font-size:4rem}.quiz-results-title{font-size:1.5rem}.quiz-results-message{font-size:1rem}.quiz-results-score-number{font-size:2.5rem}.quiz-results-score-percentage{font-size:1.25rem}.quiz-results-actions{flex-direction:column}.quiz-results-actions button{width:100%}}.parent-education-integration{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.parent-education-header h1{font-size:2.5rem;color:var(--color-primary);margin-bottom:var(--spacing-md)}.parent-education-header .subtitle{font-size:1.1rem;color:var(--color-brown);opacity:.9}.age-group-selector label{display:block;font-size:1.1rem;font-weight:600;color:var(--color-brown);margin-bottom:var(--spacing-md)}.age-group-btn{padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-md);background:#fff;color:var(--color-brown);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.age-group-btn:hover{border-color:var(--color-primary);background:var(--color-cream);transform:translateY(-2px)}.age-group-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #8b451333}.parent-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.parent-item-card{padding:var(--spacing-lg);transition:transform .3s ease,box-shadow .3s ease}.parent-item-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.parent-item-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.parent-item-icon{font-size:2.5rem}.parent-item-header h3{font-size:1.3rem;color:var(--color-primary);margin:0}.parent-item-description{color:var(--color-brown);margin-bottom:var(--spacing-md);line-height:1.6}.parent-item-meta{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap}.supervision-badge,.safety-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600}.supervision-badge.full{background:#ffebee;color:#c62828}.supervision-badge.partial{background:#fff3e0;color:#ef6c00}.supervision-badge.minimal,.safety-badge.low{background:#e8f5e9;color:#2e7d32}.safety-badge.medium{background:#fff3e0;color:#ef6c00}.safety-badge.high{background:#ffebee;color:#c62828}.food-education-pillars-mini{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);flex-wrap:wrap}.pillar-tag-mini{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.75rem;color:var(--color-brown)}.pillar-tag-mini.more{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.no-items-message{text-align:center;padding:var(--spacing-xl);color:var(--color-brown);opacity:.7}.parent-item-detail{margin-bottom:var(--spacing-xl)}.parent-detail-header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.parent-detail-title{display:flex;align-items:center;gap:var(--spacing-md)}.parent-detail-icon{font-size:3rem}.parent-detail-title h2{font-size:2rem;color:var(--color-primary);margin:0}.parent-detail-section{margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.parent-detail-section h3{font-size:1.5rem;color:var(--color-primary);margin-bottom:var(--spacing-md)}.parent-detail-section h4{font-size:1.2rem;color:var(--color-brown);margin-bottom:var(--spacing-sm)}.supervision-info{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.supervision-badge-large,.safety-badge-large{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:1rem;font-weight:600}.supervision-badge-large.full{background:#ffebee;color:#c62828}.supervision-badge-large.partial{background:#fff3e0;color:#ef6c00}.supervision-badge-large.minimal,.safety-badge-large.low{background:#e8f5e9;color:#2e7d32}.safety-badge-large.medium{background:#fff3e0;color:#ef6c00}.safety-badge-large.high{background:#ffebee;color:#c62828}.safety-list{list-style:none;padding:0}.safety-list li{padding:var(--spacing-sm) 0;padding-left:var(--spacing-lg);position:relative;color:var(--color-brown);line-height:1.6}.safety-list li:before{content:"⚠️";position:absolute;left:0}.activity-card{background:var(--color-cream);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.activity-card h4{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.role-division,.interactive-questions{margin-top:var(--spacing-md)}.interactive-questions ul{margin-top:var(--spacing-sm);padding-left:var(--spacing-lg)}.interactive-questions li{color:var(--color-brown);line-height:1.6;margin-bottom:var(--spacing-xs)}.food-education-pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.pillar-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-cream);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all .3s ease}.pillar-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.pillar-icon{font-size:1.5rem}.pillar-label{font-weight:600;color:var(--color-brown)}.recipe-section{margin-bottom:var(--spacing-lg)}.recipe-section ul,.recipe-section ol{padding-left:var(--spacing-lg)}.recipe-section li{color:var(--color-brown);line-height:1.8;margin-bottom:var(--spacing-sm)}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.nutrition-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-cream);border-radius:var(--radius-md)}.nutrition-label{font-size:.9rem;color:var(--color-brown);opacity:.8;margin-bottom:var(--spacing-xs)}.substitutions-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.substitution-item{padding:var(--spacing-md);background:var(--color-cream);border-radius:var(--radius-md);border-left:4px solid var(--color-primary)}.substitution-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.substitution-original,.substitution-new{flex:1;min-width:200px}.substitution-arrow{font-size:1.5rem;color:var(--color-primary);font-weight:700}.substitution-benefit{padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);color:var(--color-brown)}.food-education-info{margin-top:var(--spacing-xl);padding:var(--spacing-xl);background:linear-gradient(135deg,#f8f4f0,#fff5e6)}.food-education-info h3{color:var(--color-primary);margin-bottom:var(--spacing-md)}.food-education-pillars-footer{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-md)}.pillar-badge{padding:var(--spacing-sm) var(--spacing-md);background:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:var(--color-brown)}@media (max-width: 768px){.parent-education-integration{padding:var(--spacing-md)}.parent-education-header h1{font-size:1.8rem}.parent-items-grid{grid-template-columns:1fr}.age-group-buttons{flex-direction:column}.age-group-btn{width:100%}.substitution-row{flex-direction:column;align-items:flex-start}.substitution-arrow{transform:rotate(90deg)}.nutrition-grid{grid-template-columns:repeat(2,1fr)}.food-education-pillars{grid-template-columns:1fr}}.matching-game{padding:2rem;max-width:1200px;margin:0 auto}.matching-game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.matching-game-header h2{margin:0;color:var(--primary-color, #667eea);font-size:1.8rem}.game-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.stat{font-weight:600;color:var(--text-color, #333);padding:.5rem 1rem;background:var(--background-light, #f5f5f5);border-radius:8px}.feedback{text-align:center;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:600;animation:fadeIn .3s ease-in}.feedback.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.feedback.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.game-card{aspect-ratio:3/4;perspective:1000px;cursor:pointer;transition:transform .2s}.game-card:hover:not(.matched){transform:scale(1.05)}.game-card.matched{opacity:.6;cursor:default}.card-inner{position:relative;width:100%;height:100%;transition:transform .6s;transform-style:preserve-3d}.game-card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:12px;display:flex;align-items:center;justify-content:center;padding:1rem;box-shadow:0 4px 6px #0000001a}.card-front{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.card-icon{font-size:3rem}.card-back{background:#fff;transform:rotateY(180deg);border:2px solid var(--primary-color, #667eea);flex-direction:column;gap:.5rem}.card-type-badge{font-size:1.5rem;margin-bottom:.5rem}.card-content{font-size:.9rem;text-align:center;margin:0;color:var(--text-color, #333);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.modal-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}@media (max-width: 768px){.matching-game{padding:1rem}.matching-game-header{flex-direction:column;align-items:flex-start}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.card-content{font-size:.8rem;-webkit-line-clamp:3}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.sequencing-game{padding:2rem;max-width:900px;margin:0 auto}.sequencing-game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.sequencing-game-header h2{margin:0;color:var(--primary-color, #667eea);font-size:1.8rem}.game-instructions{background:var(--background-light, #f5f5f5);padding:1.5rem;border-radius:12px;margin-bottom:2rem;border-left:4px solid var(--primary-color, #667eea)}.game-instructions h3{margin:0 0 .5rem;color:var(--primary-color, #667eea)}.game-instructions p{margin:0;color:var(--text-color, #666)}.steps-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.step-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border:2px solid var(--border-color, #e0e0e0);border-radius:12px;cursor:move;transition:all .3s;box-shadow:0 2px 4px #0000001a}.step-card:hover:not(.complete){border-color:var(--primary-color, #667eea);box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.step-card.dragging{opacity:.5;transform:scale(.95)}.step-card.complete{border-color:#28a745;background:#f0f9f4;cursor:default}.step-number{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;font-weight:700;font-size:1.2rem}.step-card.complete .step-number{background:#28a745}.step-content{flex:1}.step-content p{margin:0;color:var(--text-color, #333);line-height:1.6}.drag-handle{flex-shrink:0;color:var(--text-light, #999);font-size:1.5rem;cursor:grab;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.game-actions{display:flex;justify-content:center;margin-top:2rem}.btn-secondary{background:var(--color-cream);color:var(--color-coffee-darker);border:2px solid var(--color-beige);margin-top:1rem}.explanation-panel{background:#fff;padding:2rem;border-radius:16px;border:2px solid #28a745;margin-top:2rem;animation:slideIn .5s ease-out}.explanation-panel h3{margin:0 0 1.5rem;color:#28a745;font-size:1.8rem;text-align:center}.final-stats{background:var(--background-light, #f5f5f5);padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;text-align:center}.explanation-content{margin:1.5rem 0}.explanation-content h4{margin:0 0 1rem;color:var(--primary-color, #667eea)}.tip-item{display:flex;gap:1rem;padding:1rem;background:var(--background-light, #f5f5f5);border-radius:8px;margin-bottom:.75rem}.tip-icon{flex-shrink:0;font-size:1.5rem}.tip-item p{margin:0;color:var(--text-color, #333);line-height:1.6}@media (max-width: 768px){.sequencing-game{padding:1rem}.sequencing-game-header{flex-direction:column;align-items:flex-start}.step-card{padding:1rem}.step-number{width:35px;height:35px;font-size:1rem}.step-content p{font-size:.9rem}.explanation-panel{padding:1.5rem}}.scenario-game{padding:2rem;max-width:900px;margin:0 auto}.scenario-game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.scenario-game-header h2{margin:0;color:var(--primary-color, #667eea);font-size:1.8rem}.scenario-content{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 6px #0000001a}.item-info{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-color, #e0e0e0)}.item-info h3{margin:0 0 .5rem;color:var(--primary-color, #667eea)}.item-info p{margin:0;color:var(--text-color, #666)}.scenario-situation{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.scenario-situation h4{margin:0 0 1rem;font-size:1.2rem}.scenario-situation p{margin:0;line-height:1.6;font-size:1.05rem}.choices-container{margin-bottom:2rem}.choices-container h4{margin:0 0 1rem;color:var(--text-color, #333)}.choice-btn{width:100%;padding:1.25rem;margin-bottom:1rem;background:#fff;border:2px solid var(--border-color, #e0e0e0);border-radius:12px;font-size:1rem;text-align:left;cursor:pointer;transition:all .3s;display:flex;justify-content:space-between;align-items:center}.choice-btn:hover:not(:disabled){border-color:var(--primary-color, #667eea);background:var(--background-light, #f5f5f5);transform:translate(5px)}.choice-btn.selected{border-color:var(--primary-color, #667eea);background:#667eea1a}.choice-btn.correct{border-color:#28a745;background:#f0f9f4}.choice-btn.incorrect{border-color:#dc3545;background:#f8d7da}.choice-btn:disabled{cursor:not-allowed}.choice-btn .icon{font-size:1.5rem;font-weight:700}.feedback-panel{padding:1.5rem;border-radius:12px;margin-top:1.5rem;animation:slideIn .3s ease-out}.feedback-panel.correct{background:#d4edda;border:2px solid #28a745}.feedback-panel.incorrect{background:#f8d7da;border:2px solid #dc3545}.feedback-panel h4{margin:0 0 1rem;color:inherit}.feedback-panel p{margin:0 0 1.5rem;line-height:1.6}.btn-primary,.btn-secondary{padding:.75rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:var(--color-gold);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #d4af3766}.btn-secondary:hover{background:var(--color-cream-dark)}.game-complete-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-in}.modal-content{background:#fff;padding:2.5rem;border-radius:16px;max-width:500px;width:90%;text-align:center;box-shadow:0 10px 25px #0003}.modal-content h3{margin:0 0 1.5rem;color:var(--primary-color, #667eea);font-size:2rem}.final-stats{margin:1.5rem 0;padding:1.5rem;background:var(--background-light, #f5f5f5);border-radius:12px}.final-stats p{margin:.5rem 0;font-size:1.1rem;font-weight:600;color:var(--text-color, #333)}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:var(--text-color, #666)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.scenario-game{padding:1rem}.scenario-game-header{flex-direction:column;align-items:flex-start}.scenario-content{padding:1.5rem}.choice-btn{padding:1rem;font-size:.95rem}.modal-content{padding:1.5rem}}.game-launcher{padding:2rem;max-width:1200px;margin:0 auto}.game-launcher-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.game-launcher-header h2{margin:0;color:var(--primary-color, #667eea);font-size:1.8rem}.current-item-info{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.current-item-info h3{margin:0 0 .5rem;font-size:1.5rem}.current-item-info p{margin:0;opacity:.95}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.game-card{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 6px #0000001a;cursor:pointer;transition:all .3s;position:relative;display:flex;flex-direction:column;align-items:center;text-align:center}.game-card:hover:not(.locked){transform:translateY(-5px);box-shadow:0 8px 16px #667eea4d}.game-card.locked{opacity:.6;cursor:not-allowed}.lock-badge{position:absolute;top:1rem;right:1rem;font-size:1.5rem}.game-icon{font-size:4rem;margin-bottom:1rem}.game-name{margin:0 0 1rem;color:var(--primary-color, #667eea);font-size:1.3rem}.game-description{margin:0 0 1.5rem;color:var(--text-color, #666);line-height:1.6;flex:1}.game-meta{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap;justify-content:center}.difficulty-badge,.tier-badge{padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600;color:#fff}.tier-badge{background:linear-gradient(135deg,#667eea,#764ba2)}.play-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.play-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.upgrade-notice{display:flex;align-items:center;gap:1.5rem;background:linear-gradient(135deg,#ffeaa7,#fdcb6e);padding:1.5rem;border-radius:12px;margin-bottom:2rem}.upgrade-icon{font-size:3rem;flex-shrink:0}.upgrade-content strong{display:block;margin-bottom:.5rem;color:var(--text-color, #333);font-size:1.1rem}.upgrade-content p{margin:0;color:var(--text-color, #666)}.leaderboard-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 6px #0000001a;text-align:center}.leaderboard-section h3{margin:0 0 1rem;color:var(--primary-color, #667eea)}.coming-soon{margin:0;color:var(--text-color, #999);font-style:italic}.back-btn{padding:.5rem 1rem;background:#fff;border:2px solid var(--primary-color, #667eea);color:var(--primary-color, #667eea);border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.back-btn:hover{background:var(--background-light, #f5f5f5)}@media (max-width: 768px){.game-launcher{padding:1rem}.game-launcher-header{flex-direction:column;align-items:flex-start}.games-grid{grid-template-columns:1fr;gap:1rem}.game-card{padding:1.5rem}.upgrade-notice{flex-direction:column;text-align:center}}.french-pastry-module{max-width:1200px;margin:0 auto;padding:2rem}.french-pastry-module-header{text-align:center;margin-bottom:2rem}.french-pastry-module-header h1{font-size:2.5rem;color:#2c3e50;margin-bottom:.5rem}.french-pastry-module-description{font-size:1.1rem;color:#7f8c8d;line-height:1.6}.view-mode-selector{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.view-mode-btn{padding:.75rem 1.5rem;border:2px solid #e0e0e0;background:#fff;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.view-mode-btn:hover{border-color:#667eea;color:#667eea}.view-mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.category-card{text-align:center;padding:1.5rem;transition:transform .3s ease}.category-card:hover{transform:translateY(-5px)}.category-icon{font-size:3rem;margin-bottom:1rem}.category-name{font-size:1.5rem;color:#2c3e50;margin-bottom:.5rem}.category-description{color:#7f8c8d;line-height:1.5;margin-bottom:1rem}.category-item-count{font-size:.9rem;color:#95a5a6;font-weight:600}.knowledge-items-view{animation:fadeIn .3s ease}.knowledge-items-header{margin-bottom:2rem}.back-btn{background:none;border:none;color:#667eea;font-size:1rem;cursor:pointer;padding:.5rem 1rem;margin-bottom:1rem;transition:color .3s ease}.back-btn:hover{color:#764ba2}.category-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px}.category-icon-large{font-size:4rem}.category-header h2{margin:0;font-size:2rem}.category-header p{margin:.5rem 0 0;opacity:.9}.knowledge-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.knowledge-item-card{position:relative;text-align:center;padding:1.5rem;transition:all .3s ease}.knowledge-item-card:hover:not(.locked){transform:translateY(-5px);box-shadow:0 8px 16px #0000001a}.knowledge-item-card.active{border:2px solid #667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a)}.knowledge-item-card.locked{opacity:.6;cursor:not-allowed}.lock-badge{position:absolute;top:10px;right:10px;font-size:1.5rem}.item-icon{font-size:2.5rem;margin-bottom:1rem}.item-name{font-size:1.2rem;color:#2c3e50;margin-bottom:.5rem}.item-description{color:#7f8c8d;font-size:.9rem;line-height:1.4;margin-bottom:.5rem}.upgrade-hint{font-size:.85rem;color:#e74c3c;font-weight:600;margin-top:.5rem}.upgrade-notice{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#ffeaa7,#fdcb6e);border-radius:12px;margin-top:2rem}.upgrade-icon{font-size:3rem}.upgrade-content{flex:1}.upgrade-content strong{display:block;font-size:1.2rem;color:#2c3e50;margin-bottom:.5rem}.upgrade-content p{color:#555;margin:0;line-height:1.5}.knowledge-detail-view{animation:fadeIn .3s ease}.knowledge-detail-placeholder{padding:2rem;text-align:center;color:#7f8c8d}@media (max-width: 768px){.french-pastry-module{padding:1rem}.french-pastry-module-header h1{font-size:2rem}.category-grid,.knowledge-items-grid{grid-template-columns:1fr}.view-mode-selector{flex-direction:column}.view-mode-btn{width:100%}.category-header,.upgrade-notice{flex-direction:column;text-align:center}}@media (max-width: 480px){.french-pastry-module-header h1{font-size:1.5rem}.french-pastry-module-description{font-size:1rem}.category-icon{font-size:2.5rem}.category-name{font-size:1.2rem}}.quiz-category-selector{max-width:1200px;margin:0 auto;padding:2rem 1rem}.quiz-category-header{text-align:center;margin-bottom:3rem}.quiz-category-header h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.quiz-category-subtitle{font-size:1.1rem;color:var(--text-secondary)}.quiz-category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.quiz-category-card{cursor:pointer;transition:all .3s ease;padding:0;overflow:hidden}.quiz-category-card-inner{border:3px solid transparent;padding:2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;height:100%;transition:border-color .3s ease}.quiz-category-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.quiz-category-icon{font-size:4rem;margin-bottom:.5rem;transition:transform .3s ease}.quiz-category-card:hover .quiz-category-icon{transform:scale(1.1)}.quiz-category-name{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.quiz-category-description{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0;flex-grow:1}.quiz-category-info{display:flex;justify-content:center;gap:1rem;margin-top:.5rem}.quiz-category-count{font-size:.9rem;color:var(--text-secondary);font-weight:500}.quiz-category-button{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.quiz-category-button:hover{opacity:.9;transform:scale(1.02)}.quiz-category-button:active{transform:scale(.98)}@media (max-width: 768px){.quiz-category-header h2{font-size:1.75rem}.quiz-category-subtitle{font-size:1rem}.quiz-category-grid{grid-template-columns:1fr;gap:1.5rem}.quiz-category-icon{font-size:3rem}.quiz-category-name{font-size:1.25rem}.quiz-category-description{font-size:.95rem}}@media (max-width: 480px){.quiz-category-selector{padding:1.5rem 1rem}.quiz-category-header{margin-bottom:2rem}.quiz-category-card-inner{padding:1.5rem}.quiz-category-icon{font-size:2.5rem}}.quiz-category-card-locked{cursor:not-allowed;opacity:.7}.quiz-category-card-locked:hover{transform:none;box-shadow:0 4px 8px #0000001a}.quiz-category-card-locked .quiz-category-icon{filter:grayscale(100%)}.quiz-category-card-locked:hover .quiz-category-icon{transform:none}.quiz-category-lock-badge{position:absolute;top:1rem;right:1rem;font-size:1.5rem;z-index:1}.quiz-category-card-inner{position:relative}.quiz-category-locked-info{width:100%;display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.quiz-category-upgrade-hint{font-size:.9rem;font-weight:600;color:var(--primary-color);padding:.5rem;background-color:#ff6b6b1a;border-radius:6px}.quiz-category-upgrade-button{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background-color:var(--primary-color);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}.quiz-category-upgrade-button:hover{opacity:.9;transform:scale(1.02)}.quiz-category-upgrade-button:active{transform:scale(.98)}.audio-learning{max-width:900px;margin:0 auto}.audio-learning-description{color:var(--color-gray-dark);margin-bottom:var(--spacing-xl)}.audio-learning-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.audio-learning-select{width:100%;padding:var(--spacing-md);font-size:var(--font-size-base);border:2px solid var(--color-beige);border-radius:var(--radius-md);background-color:var(--color-white);cursor:pointer;transition:border-color var(--transition-base)}.audio-learning-select:hover{border-color:var(--color-gold)}.audio-learning-select:focus{outline:none;border-color:var(--color-coffee-dark)}.audio-upgrade-notice{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(135deg,#fff9e6,#ffe5b4);border:2px solid var(--color-gold);border-radius:var(--radius-lg);margin:var(--spacing-md) 0;animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%,to{box-shadow:0 0 10px #d4af374d}50%{box-shadow:0 0 20px #d4af3780}}.audio-upgrade-icon{font-size:2rem;flex-shrink:0}.audio-upgrade-content{flex:1}.audio-upgrade-content strong{display:block;color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs);font-size:var(--font-size-lg)}.audio-upgrade-content p{margin:0;color:var(--color-coffee-dark);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.audio-membership-badge{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-cream-dark);border:1px solid var(--color-beige);border-radius:var(--radius-md);margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-coffee-dark)}.audio-membership-badge strong{color:var(--color-gold);font-weight:var(--font-weight-semibold)}.audio-learning-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);font-family:var(--font-family-base);border:2px solid var(--color-gray);border-radius:var(--radius-md);background-color:var(--color-white);margin-bottom:var(--spacing-lg);cursor:pointer}.audio-lesson-info{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--color-cream-dark);border-radius:var(--radius-md);border-left:4px solid var(--color-orange)}.audio-lesson-info h4{font-family:var(--font-family-heading);color:var(--color-brown-dark);margin-bottom:var(--spacing-sm);font-size:var(--font-size-lg)}.audio-lesson-description{color:var(--color-gray-dark);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.audio-player{display:flex;flex-direction:column;gap:var(--spacing-lg)}.audio-player-info{padding:var(--spacing-md);background-color:var(--color-cream-dark);border-radius:var(--radius-md);text-align:center}.audio-player-error{color:#c33;background-color:#fee;border:1px solid #fcc;padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.audio-player-message{color:#1976d2;background-color:#e3f2fd;border:1px solid #90caf9;padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.audio-player-controls{display:flex;flex-direction:column;gap:var(--spacing-md)}.audio-player-timeline{display:flex;align-items:center;gap:var(--spacing-md)}.audio-player-time{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-brown);min-width:40px}.audio-player-slider{flex:1;height:6px;border-radius:var(--radius-full);background:var(--color-gray);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.audio-player-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-orange);cursor:pointer}.audio-player-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-orange);cursor:pointer;border:none}.audio-player-buttons{display:flex;gap:var(--spacing-md);justify-content:center}.audio-player-speed{display:flex;flex-direction:column;gap:var(--spacing-sm)}.audio-player-speed label{font-weight:var(--font-weight-medium);color:var(--color-brown-dark)}.audio-player-speed-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.audio-speed-btn{padding:var(--spacing-xs) var(--spacing-md);border:2px solid var(--color-gray);background-color:var(--color-white);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.audio-speed-btn:hover{border-color:var(--color-orange)}.audio-speed-btn.active{background-color:var(--color-orange);color:var(--color-white);border-color:var(--color-orange)}.audio-learning-text{line-height:var(--line-height-relaxed)}.audio-learning-text h4{color:var(--color-orange);margin-bottom:var(--spacing-md)}.audio-learning-text p{margin-bottom:var(--spacing-md);color:var(--color-gray-dark)}@media (max-width: 768px){.audio-player-buttons{flex-direction:column}}.audio-unit-limit-notice{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,#fff9e6,#fff3cc);border:1px solid #ffd966;border-radius:var(--border-radius-md);margin-top:var(--spacing-md)}.audio-unit-limit-notice .audio-upgrade-icon{font-size:1.5rem;flex-shrink:0}.audio-unit-limit-notice .audio-upgrade-content{flex:1}.audio-unit-limit-notice .audio-upgrade-content strong{display:block;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:.95rem}.audio-unit-limit-notice .audio-upgrade-content p{margin:0;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.parent-education{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.parent-education-header{text-align:center;margin-bottom:var(--spacing-xl)}.parent-education-header h1{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-sm)}.parent-education-header .subtitle{font-size:var(--font-size-lg);color:var(--color-brown);font-weight:var(--font-weight-medium)}.age-group-selector{margin-bottom:var(--spacing-xl);text-align:center}.age-group-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);justify-content:center;max-width:900px;margin:0 auto}.age-group-buttons .age-group-btn:nth-child(4),.age-group-buttons .age-group-btn:nth-child(5){grid-column:span 1}.age-group-buttons:has(.age-group-btn:nth-child(5):last-child){grid-template-columns:repeat(6,1fr)}.age-group-buttons:has(.age-group-btn:nth-child(5):last-child) .age-group-btn:nth-child(1),.age-group-buttons:has(.age-group-btn:nth-child(5):last-child) .age-group-btn:nth-child(2),.age-group-buttons:has(.age-group-btn:nth-child(5):last-child) .age-group-btn:nth-child(3){grid-column:span 2}.age-group-buttons:has(.age-group-btn:nth-child(5):last-child) .age-group-btn:nth-child(4){grid-column:2 / span 2}.age-group-buttons:has(.age-group-btn:nth-child(5):last-child) .age-group-btn:nth-child(5){grid-column:4 / span 2}.age-group-btn{padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--color-gray);border-radius:var(--radius-lg);background:#fff;color:var(--color-brown);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-normal)}.parent-education-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--color-gray-light);overflow-x:auto}.tab-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border:none;border-bottom:3px solid transparent;background:transparent;color:var(--color-brown);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab-btn:hover{color:var(--color-primary);background:var(--color-cream-light)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-icon{font-size:var(--font-size-xl)}.parent-education-main{min-height:400px}.parent-education-content{animation:fadeIn .3s ease-in}.parent-education-content h3{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md)}.parent-education-content .description{font-size:var(--font-size-lg);color:var(--color-brown);line-height:1.8;margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-cream-light);border-left:4px solid var(--color-primary);border-radius:var(--radius-md)}.content-section{margin-bottom:var(--spacing-xl)}.content-section h4{font-size:var(--font-size-xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.content-section ul{list-style:none;padding:0}.content-section li{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);background:#fff;border-left:3px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d}.substitutions-grid{display:grid;gap:var(--spacing-lg)}.substitution-card{padding:var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 8px #0000001a;display:grid;grid-template-columns:1fr auto 1fr;gap:var(--spacing-md);align-items:center}.substitution-arrow{font-size:var(--font-size-2xl);color:var(--color-primary);font-weight:700}.substitution-benefit{grid-column:1 / -1;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-gray-light);color:var(--color-brown);font-size:var(--font-size-sm)}.safety-guide-card{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 8px #0000001a}.supervision-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-brown)}.supervision-level{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold)}.supervision-level.full{background:#fee;color:#c33}.supervision-level.partial{background:#ffeaa7;color:#d63031}.supervision-level.minimal{background:#dfe6e9;color:#2d3436}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl)}.experiment-series-section{margin-bottom:3rem;padding:2.5rem;background:linear-gradient(135deg,#f8f4f0,#fff5e6);border:3px solid var(--color-primary);border-radius:16px;box-shadow:0 4px 16px #ff6b3526}.experiment-series-header{text-align:center;margin-bottom:2.5rem;color:var(--color-brown-dark)}.experiment-series-header h4{font-size:1.8rem;margin-bottom:1rem;color:var(--color-primary);font-weight:var(--font-weight-bold);line-height:1.4}.experiment-series-subtitle{font-size:1.05rem;color:var(--color-brown);font-style:italic;margin-top:.75rem;line-height:1.6;max-width:800px;margin-left:auto;margin-right:auto}.experiment-grid{gap:2.5rem}.experiment-card{position:relative;background:#fff;border:3px solid var(--color-primary);box-shadow:0 6px 20px #ff6b3526;transition:all .3s ease;padding-top:2.5rem!important;overflow:visible}.regular-recipes-title{margin-top:3rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:3px solid var(--color-primary);color:var(--color-brown-dark);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.recipe-card h4{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-brown-dark);margin:0 0 var(--spacing-sm) 0;line-height:1.4}.recipe-description{color:var(--color-brown);font-size:var(--font-size-base);line-height:1.7;margin-bottom:var(--spacing-md)}.recipe-meta{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-md)}.recipe-badge{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.recipe-badge.skill-level{background:var(--color-cream);color:var(--color-brown-dark)}.recipe-badge.supervision{background:var(--color-primary-light);color:var(--color-primary)}.recipe-badge.time{background:var(--color-gray-light);color:var(--color-brown)}.recipe-section{font-size:var(--font-size-base);margin-bottom:var(--spacing-md)}.recipe-section strong{display:block;margin-bottom:var(--spacing-sm);color:var(--color-brown-dark)}.recipe-section ul{margin-top:var(--spacing-sm);padding-left:var(--spacing-lg);line-height:1.7}.recipe-section li{margin-bottom:var(--spacing-sm);background:none;border:none;box-shadow:none;padding:0;color:var(--color-brown)}.food-education-info{margin-top:var(--spacing-xl);background:linear-gradient(135deg,#fff5e6,#ffe8cc);border:2px solid var(--color-primary)}.food-education-info h3{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md)}.food-education-pillars{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-md)}.pillar-badge{padding:var(--spacing-sm) var(--spacing-md);background:#fff;color:var(--color-brown-dark);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);box-shadow:0 2px 4px #0000001a}@media (max-width: 768px){.parent-education{padding:var(--spacing-md)}.parent-education-header h1{font-size:var(--font-size-2xl)}.age-group-buttons{flex-direction:column}.age-group-btn{width:100%}.substitution-card{grid-template-columns:1fr}.substitution-arrow{transform:rotate(90deg)}.recipes-grid{grid-template-columns:1fr}}.recipe-card{display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-width: 768px){.recipe-modal-content{max-height:95vh;margin:var(--spacing-sm)}.recipe-modal-header h3{font-size:var(--font-size-xl)}.recipe-modal-body{padding:var(--spacing-md)}.recipe-modal-meta{flex-direction:column;gap:var(--spacing-md)}.ingredients-list li{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.steps-list li{padding-left:50px}.steps-list li:before{width:30px;height:30px;font-size:var(--font-size-base)}}.science-lab{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.science-lab-hero{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:linear-gradient(135deg,#f8f4f0,#fff5e6);border-radius:var(--radius-xl);margin-bottom:var(--spacing-2xl);border:3px solid var(--color-primary)}.science-lab-hero-content{max-width:800px;margin:0 auto}.science-lab-title{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md);line-height:1.3}.science-lab-slogan{font-size:var(--font-size-xl);color:var(--color-primary);font-weight:var(--font-weight-bold);font-style:italic;margin-bottom:var(--spacing-md);line-height:1.5}.science-lab-subtitle{font-size:var(--font-size-lg);color:var(--color-brown);line-height:1.7;margin-top:var(--spacing-lg)}.science-lab-intro{margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl)}.science-lab-intro h2{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md)}.science-lab-intro p{font-size:var(--font-size-lg);color:var(--color-brown);line-height:1.8;margin-bottom:var(--spacing-xl)}.age-group-selector{margin:var(--spacing-xl) 0;text-align:center}.age-group-selector label{display:block;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-brown-dark);margin-bottom:var(--spacing-md)}.age-group-buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.age-group-btn{padding:var(--spacing-md) var(--spacing-xl);border:2px solid var(--color-gray);border-radius:var(--radius-lg);background:#fff;color:var(--color-brown);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-normal)}.age-group-btn:hover{border-color:var(--color-primary);background:var(--color-cream-light)}.age-group-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #ff6b354d}.science-lab-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.science-lab-feature{text-align:center;padding:var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000014;transition:all var(--transition-normal)}.science-lab-feature:hover{transform:translateY(-4px);box-shadow:0 8px 20px #ff6b3526}.feature-icon{font-size:3rem;margin-bottom:var(--spacing-md);display:block}.science-lab-feature h3{font-size:var(--font-size-lg);color:var(--color-brown-dark);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.science-lab-feature p{font-size:var(--font-size-base);color:var(--color-brown);line-height:1.6;margin:0}.science-lab-experiments{margin-bottom:var(--spacing-2xl)}.section-title{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-brown-dark);text-align:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:3px solid var(--color-primary)}.experiments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2.5rem}.experiment-card{position:relative;background:#fff;border:3px solid var(--color-primary);box-shadow:0 6px 20px #ff6b3526;transition:all .3s ease;padding-top:2.5rem!important;overflow:visible;display:flex;flex-direction:column;gap:var(--spacing-md)}.experiment-card:hover{transform:translateY(-6px);box-shadow:0 10px 28px #ff6b3540;border-color:var(--color-brown-dark)}.experiment-badge{position:absolute;top:-14px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-brown-dark) 100%);color:#fff;padding:.5rem 1.5rem;border-radius:25px;font-size:.9rem;font-weight:700;box-shadow:0 4px 12px #ff6b3566;white-space:nowrap;z-index:10}.experiment-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-brown-dark);margin:0 0 var(--spacing-sm) 0;line-height:1.4}.experiment-description{color:var(--color-brown);font-size:var(--font-size-base);line-height:1.7;margin-bottom:var(--spacing-md)}.experiment-meta{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-md)}.experiment-badge-small{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.experiment-badge-small.skill-level{background:var(--color-cream);color:var(--color-brown-dark)}.experiment-badge-small.time{background:var(--color-gray-light);color:var(--color-brown)}.experiment-section{font-size:var(--font-size-base);margin-bottom:var(--spacing-md)}.experiment-section strong{display:block;margin-bottom:var(--spacing-sm);color:var(--color-brown-dark)}.experiment-section ul{margin-top:var(--spacing-sm);padding-left:var(--spacing-lg);line-height:1.7}.experiment-section li{margin-bottom:var(--spacing-sm);color:var(--color-brown)}.pillars-tags{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-sm)}.pillar-tag{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-cream);color:var(--color-brown);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.science-lab-cta{text-align:center;padding:var(--spacing-2xl);background:linear-gradient(135deg,#fff5e6,#ffe8cc);border:2px solid var(--color-primary)}.science-lab-cta h2{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md)}.science-lab-cta p{font-size:var(--font-size-lg);color:var(--color-brown);line-height:1.8;margin-bottom:var(--spacing-xl);max-width:800px;margin-left:auto;margin-right:auto}.cta-buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.recipe-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .2s ease-in}.recipe-modal-content{background:#fff;border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.recipe-modal-header{position:sticky;top:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-brown-dark) 100%);color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;justify-content:space-between;align-items:flex-start;z-index:10}.recipe-modal-header h3{margin:0;font-size:var(--font-size-2xl);font-family:var(--font-family-heading)}.recipe-modal-close{background:#fff3;border:none;color:#fff;font-size:var(--font-size-2xl);width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0;margin-left:var(--spacing-md)}.recipe-modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.recipe-modal-body{padding:var(--spacing-xl)}.recipe-modal-section{margin-bottom:var(--spacing-xl)}.recipe-modal-section h4{font-size:var(--font-size-xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm);border-bottom:2px solid var(--color-primary);padding-bottom:var(--spacing-sm)}.recipe-modal-meta{display:flex;gap:var(--spacing-lg);flex-wrap:wrap;padding:var(--spacing-md);background:var(--color-cream-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.recipe-modal-meta-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.recipe-modal-meta-label{font-size:var(--font-size-sm);color:var(--color-brown);font-weight:var(--font-weight-medium)}.recipe-modal-meta-value{font-size:var(--font-size-lg);color:var(--color-brown-dark);font-weight:var(--font-weight-semibold)}.ingredients-list{list-style:none;padding:0;display:grid;gap:var(--spacing-sm)}.ingredients-list li{padding:var(--spacing-md);background:#fff;border-left:3px solid var(--color-primary);border-radius:var(--radius-sm);display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000000d}.ingredient-name{font-weight:var(--font-weight-medium);color:var(--color-brown-dark)}.ingredient-amount{color:var(--color-brown);font-size:var(--font-size-sm)}.steps-list{list-style:none;padding:0;counter-reset:step-counter}.steps-list li{counter-increment:step-counter;padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:#fff;border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014;position:relative;padding-left:60px}.steps-list li:before{content:counter(step-counter);position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);width:36px;height:36px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.nutrition-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 2px 8px #00000014}.nutrition-table th,.nutrition-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-gray-light)}.nutrition-table th{background:var(--color-cream);color:var(--color-brown-dark);font-weight:var(--font-weight-semibold)}.nutrition-table tr:last-child td{border-bottom:none}.nutrition-table td:last-child{text-align:right;font-weight:var(--font-weight-semibold);color:var(--color-primary)}.allergens-warning{padding:var(--spacing-md);background:#fff3cd;border-left:4px solid #ffc107;border-radius:var(--radius-md);color:#856404}.allergens-list{margin-top:var(--spacing-sm);font-weight:var(--font-weight-semibold)}@media (max-width: 768px){.science-lab{padding:var(--spacing-md)}.science-lab-title{font-size:var(--font-size-2xl)}.science-lab-slogan{font-size:var(--font-size-lg)}.science-lab-subtitle{font-size:var(--font-size-base)}.science-lab-features,.experiments-grid{grid-template-columns:1fr}.cta-buttons{flex-direction:column}.recipe-modal-content{max-height:95vh;margin:var(--spacing-sm)}.recipe-modal-header h3{font-size:var(--font-size-xl)}.recipe-modal-body{padding:var(--spacing-md)}.recipe-modal-meta{flex-direction:column;gap:var(--spacing-md)}.ingredients-list li{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.steps-list li{padding-left:50px}.steps-list li:before{width:30px;height:30px;font-size:var(--font-size-base)}}.science-lab-upgrade-prompt{margin:var(--spacing-2xl) 0;padding:var(--spacing-2xl);background:linear-gradient(135deg,#fff5e6,#ffe8cc);border:3px solid var(--color-primary);text-align:center}.upgrade-prompt-content{max-width:900px;margin:0 auto}.upgrade-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.upgrade-prompt-content h2{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md)}.upgrade-description{font-size:var(--font-size-lg);color:var(--color-brown);line-height:1.8;margin-bottom:var(--spacing-xl)}.upgrade-benefits{background:#fff;padding:var(--spacing-xl);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;text-align:left;box-shadow:0 4px 12px #00000014}.upgrade-benefits h3{font-size:var(--font-size-xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md);text-align:center}.upgrade-benefits ul{list-style:none;padding:0;display:grid;gap:var(--spacing-md)}.upgrade-benefits li{padding:var(--spacing-md);background:var(--color-cream-light);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-brown);line-height:1.6}.upgrade-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl);margin:var(--spacing-xl) 0}.tier-card{background:#fff;padding:var(--spacing-xl);border-radius:var(--radius-lg);border:2px solid var(--color-gray);box-shadow:0 4px 12px #00000014;transition:all var(--transition-normal);position:relative}.tier-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #ff6b3526;border-color:var(--color-primary)}.tier-recommended{border-color:var(--color-primary);border-width:3px;box-shadow:0 8px 24px #ff6b3533}.recommended-badge{position:absolute;top:-12px;right:var(--spacing-lg);background:var(--color-primary);color:#fff;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);box-shadow:0 4px 12px #ff6b3566}.tier-card h4{font-size:var(--font-size-xl);color:var(--color-brown-dark);margin-bottom:var(--spacing-md);font-family:var(--font-family-heading)}.tier-price{font-size:var(--font-size-2xl);color:var(--color-primary);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-lg)}.tier-features{list-style:none;padding:0;text-align:left}.tier-features li{padding:var(--spacing-sm) 0;color:var(--color-brown);font-size:var(--font-size-base);line-height:1.6;border-bottom:1px solid var(--color-gray-light)}.tier-features li:last-child{border-bottom:none}.upgrade-actions{margin-top:var(--spacing-xl)}.login-hint{margin-top:var(--spacing-md);font-size:var(--font-size-base);color:var(--color-brown)}.login-hint a{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-semibold);transition:all var(--transition-fast)}.login-hint a:hover{text-decoration:underline;color:var(--color-brown-dark)}@media (max-width: 768px){.science-lab-upgrade-prompt{padding:var(--spacing-lg)}.upgrade-icon{font-size:3rem}.upgrade-prompt-content h2{font-size:var(--font-size-xl)}.upgrade-description{font-size:var(--font-size-base)}.upgrade-tiers{grid-template-columns:1fr}.tier-card{padding:var(--spacing-lg)}.tier-price{font-size:var(--font-size-xl)}}.oli-display{display:flex;flex-direction:column;align-items:center;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:20px;box-shadow:0 10px 40px #0000001a;max-width:500px;margin:0 auto;position:relative;overflow:hidden}.oli-display:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.oli-octagon-ring{position:relative;width:280px;height:280px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.oli-octagon-svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.oli-display.animated .oli-octagon-path{animation:oli-rotate 20s linear infinite;transform-origin:center}.oli-display.animated .oli-octagon-inner{animation:oli-rotate-reverse 15s linear infinite;transform-origin:center}@keyframes oli-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes oli-rotate-reverse{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.oli-score-container{position:relative;z-index:1;text-align:center;animation:oli-fade-in .8s ease-out}@keyframes oli-fade-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.oli-score{font-size:5rem;font-weight:800;line-height:1;margin-bottom:.25rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 10px rgba(0,0,0,.1);font-family:Arial,sans-serif}.oli-label{font-size:1.25rem;font-weight:700;letter-spacing:.15em;color:#4a5568;margin-bottom:.25rem}.oli-subtitle{font-size:.75rem;color:#718096;letter-spacing:.05em;font-weight:500}.oli-grade{font-size:1.5rem;font-weight:700;padding:.5rem 1.5rem;border-radius:25px;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.1em;box-shadow:0 4px 12px #00000026;animation:oli-grade-pulse 2s ease-in-out infinite}@keyframes oli-grade-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.oli-grade.apex{background:linear-gradient(135deg,gold,orange);color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.oli-grade.gold{background:linear-gradient(135deg,#d4af37,#f4e5a1);color:#5a4a1a}.oli-grade.silver{background:linear-gradient(135deg,silver,#e8e8e8);color:#4a4a4a}.oli-grade.bronze{background:linear-gradient(135deg,#cd7f32,#e8b887);color:#4a2a0a}.oli-grade.pending{background:linear-gradient(135deg,#9e9e9e,#bdbdbd);color:#424242}.oli-description{text-align:center;color:#4a5568;font-size:1rem;line-height:1.6;margin-bottom:1.5rem;max-width:400px;padding:0 1rem}.oli-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;width:100%;margin-bottom:1rem}.oli-stat-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:#ffffffb3;border-radius:12px;box-shadow:0 2px 8px #0000000d;transition:transform .2s ease}.oli-stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.oli-stat-label{font-size:.75rem;color:#718096;margin-bottom:.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.oli-stat-value{font-size:1.25rem;font-weight:700;color:#2d3748}.oli-stat-value.positive{color:#48bb78}.oli-stat-value.negative{color:#f56565}.oli-penalties{width:100%;background:#fed7d780;border:2px solid #fc8181;border-radius:12px;padding:1rem;margin-top:1rem}.oli-penalties-title{font-size:.875rem;font-weight:700;color:#c53030;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.oli-penalty-item{font-size:.875rem;color:#742a2a;padding:.5rem;background:#fff9;border-radius:6px;margin-bottom:.5rem;border-left:3px solid #fc8181}.oli-penalty-item:last-child{margin-bottom:0}@media (max-width: 768px){.oli-display{padding:1.5rem;max-width:100%}.oli-octagon-ring{width:220px;height:220px}.oli-score{font-size:4rem}.oli-label{font-size:1rem}.oli-subtitle{font-size:.65rem}.oli-grade{font-size:1.25rem;padding:.4rem 1.2rem}.oli-description{font-size:.9rem}.oli-stats{grid-template-columns:repeat(2,1fr);gap:.75rem}.oli-stat-item{padding:.5rem}.oli-stat-label{font-size:.65rem}.oli-stat-value{font-size:1rem}}@media (max-width: 480px){.oli-display{padding:1rem}.oli-octagon-ring{width:180px;height:180px}.oli-score{font-size:3rem}.oli-grade{font-size:1rem;padding:.35rem 1rem}.oli-stats{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){.oli-display.animated .oli-octagon-path,.oli-display.animated .oli-octagon-inner,.oli-grade,.oli-score-container{animation:none}}@media (prefers-contrast: high){.oli-display{border:2px solid #000}.oli-score{-webkit-text-fill-color:#000;text-shadow:none}.oli-stat-item{border:1px solid #000}}@media print{.oli-display{box-shadow:none;background:#fff}.oli-display.animated .oli-octagon-path,.oli-display.animated .oli-octagon-inner,.oli-grade{animation:none}}.octagon-chart-container{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:box-shadow .3s ease;max-width:600px;margin:0 auto}.octagon-chart-container:focus{outline:2px solid #4CAF50;outline-offset:2px;box-shadow:0 4px 12px #4caf5033}.octagon-chart-container:hover{box-shadow:0 4px 12px #00000026}.octagon-chart-header{width:100%;text-align:center;margin-bottom:1rem}.octagon-chart-title{font-size:1.5rem;font-weight:700;color:#333;margin:0 0 .5rem;line-height:1.4}.octagon-chart-certification{font-size:1.125rem;font-weight:600;margin:0;padding:.25rem .75rem;border-radius:20px;display:inline-block;background:#ffd7001a}.octagon-chart-svg-wrapper{width:100%;max-width:500px;height:auto;margin:1rem 0}.octagon-chart-svg-wrapper svg{width:100%;height:auto;display:block}.octagon-chart-stats{display:flex;gap:2rem;justify-content:center;width:100%;margin:1rem 0;padding:1rem;background:#f5f5f5;border-radius:8px}.octagon-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.octagon-stat-label{font-size:.875rem;color:#666;font-weight:500}.octagon-stat-value{font-size:1.5rem;font-weight:700;color:#333}.octagon-chart-legend{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;width:100%;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.octagon-legend-item{display:flex;align-items:center;gap:.5rem}.octagon-legend-color{width:16px;height:16px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 3px #0003}.octagon-legend-label{font-size:.875rem;color:#666;font-weight:500}.octagon-chart-details,.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (max-width: 768px){.octagon-chart-container{padding:1rem;max-width:100%}.octagon-chart-title{font-size:1.25rem}.octagon-chart-certification{font-size:1rem}.octagon-chart-stats{gap:1rem;padding:.75rem}.octagon-stat-value{font-size:1.25rem}.octagon-chart-legend{gap:.75rem}}@media (max-width: 480px){.octagon-chart-container{padding:.75rem}.octagon-chart-title{font-size:1.125rem}.octagon-chart-certification{font-size:.875rem;padding:.25rem .5rem}.octagon-chart-stats{flex-direction:column;gap:.5rem;padding:.5rem}.octagon-stat{flex-direction:row;justify-content:space-between;width:100%}.octagon-stat-value{font-size:1.125rem}.octagon-chart-legend{gap:.5rem}.octagon-legend-item{gap:.375rem}.octagon-legend-color{width:14px;height:14px}.octagon-legend-label{font-size:.8125rem}}@media print{.octagon-chart-container{box-shadow:none;border:1px solid #e0e0e0;page-break-inside:avoid}.octagon-chart-container:focus{outline:none}.octagon-chart-details{position:static;width:auto;height:auto;margin:1rem 0;overflow:visible;clip:auto;white-space:normal}.sr-only{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}}@media (prefers-contrast: high){.octagon-chart-container{border:2px solid #000}.octagon-chart-title,.octagon-stat-value,.octagon-stat-label,.octagon-legend-label{color:#000}}@media (prefers-reduced-motion: reduce){.octagon-chart-container{transition:none}}@media (prefers-color-scheme: dark){.octagon-chart-container{background:#1e1e1e;box-shadow:0 2px 8px #0000004d}.octagon-chart-title{color:#e0e0e0}.octagon-chart-stats{background:#2a2a2a}.octagon-stat-label,.octagon-legend-label{color:#b0b0b0}.octagon-stat-value{color:#e0e0e0}.octagon-chart-legend{border-top-color:#3a3a3a}.octagon-chart-container:focus{outline-color:#66bb6a;box-shadow:0 4px 12px #66bb6a4d}}.octagon-chart-oli-section{width:100%;margin-top:2rem;padding-top:2rem;border-top:2px solid #e0e0e0}.octagon-chart-oli-title{font-size:1.25rem;font-weight:700;color:#333;text-align:center;margin:0 0 1.5rem}@media (max-width: 768px){.octagon-chart-oli-section{margin-top:1.5rem;padding-top:1.5rem}.octagon-chart-oli-title{font-size:1.125rem;margin-bottom:1rem}}@media (max-width: 480px){.octagon-chart-oli-section{margin-top:1rem;padding-top:1rem}.octagon-chart-oli-title{font-size:1rem;margin-bottom:.75rem}}@media (prefers-color-scheme: dark){.octagon-chart-oli-section{border-top-color:#3a3a3a}.octagon-chart-oli-title{color:#e0e0e0}}.idia-lab{min-height:100vh;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);font-family:Montserrat,sans-serif}.idia-header{background:linear-gradient(135deg,#6b8e7f,#4a6b5f);color:#fff;padding:3rem 2rem;text-align:center;box-shadow:0 4px 12px #0000001a}.idia-title{font-family:Playfair Display,serif;font-size:4rem;font-weight:700;letter-spacing:.05em;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.idia-subtitle{font-family:Montserrat,sans-serif;font-size:1.1rem;font-weight:500;margin:.5rem 0;opacity:.95;letter-spacing:.02em}.idia-tagline{font-family:Montserrat,sans-serif;font-size:.95rem;font-weight:500;margin:.5rem 0 0;opacity:.85;font-style:italic}.idia-container{max-width:1200px;margin:0 auto;padding:2rem}.idia-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.idia-section-title{font-family:Playfair Display,serif;font-size:2rem;color:#6b8e7f;margin:0 0 .5rem;letter-spacing:.03em}.idia-section-desc{color:#666;margin:0 0 1.5rem;font-size:.95rem}.idia-ingredients-list{margin-bottom:1.5rem}.idia-empty-state{text-align:center;padding:2rem;background-color:#f5f5f5;border-radius:8px;border:2px dashed #d0d0d0}.idia-empty-state p{color:#666;margin:0;font-size:.95rem}.idia-ingredient-row{display:flex;gap:1rem;margin-bottom:1rem;align-items:center}.idia-input-group{flex:1;display:flex;gap:.5rem;align-items:center}.idia-input-weight{flex:2}.idia-select-unit{flex:1;min-width:120px}.idia-select{flex:2;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-family:Montserrat,sans-serif;font-size:.95rem;transition:border-color .3s;background-color:#fff;cursor:pointer}.idia-select:hover{border-color:#b0b0b0}.idia-select:focus{outline:none;border-color:#6b8e7f}.idia-input{flex:1;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-family:Montserrat,sans-serif;font-size:.95rem;transition:border-color .3s}.idia-input:focus{outline:none;border-color:#6b8e7f}.idia-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-family:Montserrat,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.05em}.idia-btn-add{background-color:#6b8e7f;color:#fff}.idia-btn-add:hover{background-color:#4a6b5f;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.idia-btn-calculate{background-color:#d4af37;color:#fff}.idia-btn-calculate:hover{background-color:#b8941f;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.idia-btn-remove{background-color:#f44336;color:#fff;padding:.75rem 1rem}.idia-btn-remove:hover{background-color:#d32f2f}.idia-actions{display:flex;gap:1rem;justify-content:flex-start}.idia-results{background:linear-gradient(135deg,#fff,#f9f9f9)}.idia-octagon-section{background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 16px #0000001a;border:2px solid #6B8E7F}.idia-visualization-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.idia-oli-section{background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:16px;padding:2rem;box-shadow:0 4px 16px #0000001a;border:2px solid #D4AF37;display:flex;align-items:center;justify-content:center}.idia-verified-badge{display:inline-block;background-color:#6b8e7f;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;margin-bottom:1.5rem;letter-spacing:.05em}.idia-result-card{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #00000014;transition:box-shadow .3s}.idia-result-card:hover{box-shadow:0 4px 16px #0000001f}.idia-result-card h3{font-family:Montserrat,sans-serif;font-size:1.2rem;color:#333;margin:0 0 1rem;font-weight:600}.idia-result-primary{border:3px solid #6B8E7F}.idia-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.idia-certification-badge{padding:.5rem 1rem;border-radius:20px;color:#333;font-weight:600;font-size:.9rem;box-shadow:0 2px 4px #0000001a;letter-spacing:.03em}.idia-result-value{font-family:Montserrat,sans-serif;font-size:3.5rem;font-weight:600;color:#6b8e7f;margin:1rem 0;text-align:center}.idia-result-value-small{font-size:2.5rem}.idia-result-details{display:flex;justify-content:space-around;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.idia-result-details p{margin:0;color:#666;font-size:.95rem}.idia-result-recommendation{background-color:#e8c4c4;color:#333;padding:1rem;border-radius:8px;text-align:center;font-weight:500;margin-top:1rem}.idia-nutrition-summary{background:linear-gradient(135deg,#6b8e7f,#4a6b5f);color:#fff}.idia-nutrition-summary h3{color:#fff}.idia-nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.idia-nutrition-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#ffffff1a;border-radius:8px}.idia-nutrition-label{font-size:.85rem;opacity:.9;margin-bottom:.5rem}.idia-nutrition-value{font-size:1.5rem;font-weight:600}.idia-loading{text-align:center;padding:4rem 2rem;font-size:1.2rem;color:#6b8e7f}@media (max-width: 768px){.idia-title{font-size:2.5rem}.idia-subtitle{font-size:.95rem}.idia-container{padding:1rem}.idia-ingredient-row{flex-direction:column}.idia-select,.idia-input,.idia-input-group{width:100%}.idia-select-unit{min-width:100px}.idia-actions{flex-direction:column}.idia-btn{width:100%}.idia-result-value{font-size:2.5rem}.idia-result-details{flex-direction:column;gap:.5rem}.idia-visualization-container{grid-template-columns:1fr;gap:1.5rem}.idia-octagon-section,.idia-oli-section{padding:1.5rem}}.idia-upgrade-notice{background:linear-gradient(135deg,#fff,#f9f9f9);border:3px solid #6B8E7F;border-radius:16px;padding:3rem;text-align:center;box-shadow:0 4px 16px #0000001a}.idia-upgrade-icon{font-size:4rem;margin-bottom:1.5rem}.idia-upgrade-content h2{font-family:Playfair Display,serif;font-size:2rem;color:#6b8e7f;margin:0 0 1rem;letter-spacing:.03em}.idia-upgrade-content p{color:#666;font-size:1.1rem;line-height:1.8;margin:0 0 2rem;max-width:800px;margin-left:auto;margin-right:auto}.idia-upgrade-features{background:#fff;border-radius:12px;padding:2rem;margin-top:2rem;box-shadow:0 2px 8px #00000014}.idia-upgrade-features h3{font-family:Montserrat,sans-serif;font-size:1.3rem;color:#333;margin:0 0 1.5rem;font-weight:600}.idia-upgrade-features ul{list-style:none;padding:0;text-align:left;max-width:600px;margin:0 auto}.idia-upgrade-features li{padding:.75rem 0;color:#333;font-size:1rem;line-height:1.6;border-bottom:1px solid #e0e0e0}.idia-upgrade-features li:last-child{border-bottom:none}@media (max-width: 768px){.idia-upgrade-notice{padding:2rem 1.5rem}.idia-upgrade-icon{font-size:3rem}.idia-upgrade-content h2{font-size:1.5rem}.idia-upgrade-content p{font-size:1rem}.idia-upgrade-features{padding:1.5rem}.idia-upgrade-features h3{font-size:1.1rem}.idia-upgrade-features li{font-size:.95rem}}.blog-listing{min-height:100vh;background-color:var(--color-white)}.blog-hero{padding:var(--spacing-3xl) var(--spacing-xl);text-align:center;background-color:var(--color-cream);border-bottom:1px solid var(--color-beige-light)}.blog-hero-title{font-family:var(--font-family-heading);font-size:var(--font-size-5xl);font-weight:var(--font-weight-normal);color:var(--color-coffee-dark);margin:0 0 var(--spacing-md);letter-spacing:var(--letter-spacing-wide)}.blog-hero-subtitle{font-family:var(--font-family-base);font-size:var(--font-size-lg);color:var(--color-coffee);margin:0;letter-spacing:var(--letter-spacing-normal)}.blog-filter{padding:var(--spacing-xl) var(--spacing-md);background-color:var(--color-white);border-bottom:1px solid var(--color-beige-light);position:sticky;top:0;z-index:var(--z-sticky)}.blog-filter-container{max-width:1200px;margin:0 auto;display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.blog-filter-button{font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-coffee);background-color:transparent;border:1px solid var(--color-beige);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);letter-spacing:var(--letter-spacing-wide)}.blog-filter-button:hover{background-color:var(--color-cream);border-color:var(--color-beige-dark)}.blog-filter-button.active{background-color:var(--color-gold);color:var(--color-white);border-color:var(--color-gold)}.blog-grid{padding:var(--spacing-3xl) var(--spacing-xl);background-color:var(--color-white)}.blog-grid-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-2xl)}.blog-card{display:flex;flex-direction:column;height:100%;overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.blog-card-image-wrapper{position:relative;width:100%;padding-top:66.67%;overflow:hidden;background-color:var(--color-cream)}.blog-card-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.blog-card:hover .blog-card-image{transform:scale(1.05)}.blog-card-category{position:absolute;top:var(--spacing-md);left:var(--spacing-md);background-color:var(--color-gold);color:var(--color-white);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase}.blog-card-content{padding:var(--spacing-xl);display:flex;flex-direction:column;flex-grow:1}.blog-card-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);margin:0 0 var(--spacing-md);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight)}.blog-card-excerpt{font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--color-coffee);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-lg);flex-grow:1}.blog-card-meta{display:flex;align-items:center;gap:var(--spacing-sm);font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-gray-dark);margin-bottom:var(--spacing-lg)}.blog-card-divider{color:var(--color-beige)}.blog-card-read-more{font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);background:none;border:none;padding:0;cursor:pointer;letter-spacing:var(--letter-spacing-wide);transition:color var(--transition-base);text-align:left}.blog-card-read-more:hover{color:var(--color-gold)}.blog-divider{grid-column:1 / -1;display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl) 0}.blog-divider-icon{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-beige);font-weight:var(--font-weight-light)}.blog-contact{padding:var(--spacing-3xl) var(--spacing-xl);background-color:var(--color-cream)}.blog-contact>div{max-width:600px;margin:0 auto;text-align:center;padding:var(--spacing-2xl)}.blog-contact-title{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);margin:0 0 var(--spacing-md)}.blog-contact-description{font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--color-coffee);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-xl)}.blog-contact-form{display:flex;gap:var(--spacing-md);max-width:500px;margin:0 auto}.blog-contact-input{flex:1;font-family:var(--font-family-base);font-size:var(--font-size-base);padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-beige);border-radius:var(--radius-md);background-color:var(--color-white);color:var(--color-coffee-dark);transition:border-color var(--transition-base)}.blog-contact-input:focus{outline:none;border-color:var(--color-gold)}.blog-contact-button{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-white);background-color:var(--color-gold);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base);letter-spacing:var(--letter-spacing-wide)}.blog-contact-button:hover{background-color:var(--color-gold)}@media (max-width: 768px){.blog-hero{padding:var(--spacing-2xl) var(--spacing-md)}.blog-hero-title{font-size:var(--font-size-3xl)}.blog-hero-subtitle{font-size:var(--font-size-base)}.blog-grid-container{grid-template-columns:1fr;gap:var(--spacing-xl)}.blog-contact-form{flex-direction:column}.blog-filter-container{justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch}}.blog-post{min-height:100vh;background-color:var(--color-white)}.blog-post-back{padding:var(--spacing-xl) var(--spacing-xl) 0;max-width:1400px;margin:0 auto}.blog-post-back-button{font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-coffee);background:none;border:none;padding:var(--spacing-sm) 0;cursor:pointer;transition:color var(--transition-base);letter-spacing:var(--letter-spacing-normal)}.blog-post-back-button:hover{color:var(--color-gold)}.blog-post-header{max-width:800px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-xl);text-align:center}.blog-post-category{display:inline-block;background-color:var(--color-gold);color:var(--color-white);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;margin-bottom:var(--spacing-lg)}.blog-post-title{font-family:var(--font-family-heading);font-size:var(--font-size-4xl);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);margin:0 0 var(--spacing-lg)}.blog-post-meta{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-gray-dark)}.blog-post-divider{color:var(--color-beige)}.blog-post-featured-image{width:100%;max-width:1400px;margin:0 auto var(--spacing-3xl);padding:0 var(--spacing-xl)}.blog-post-featured-image img{width:100%;height:auto;max-height:600px;object-fit:cover;border-radius:var(--radius-lg)}.blog-post-content-wrapper{max-width:1400px;margin:0 auto;padding:0 var(--spacing-xl) var(--spacing-3xl);display:grid;grid-template-columns:1fr 280px;gap:var(--spacing-2xl);align-items:start}.blog-post-content{max-width:800px}.blog-post-body img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:var(--spacing-lg) 0}.blog-post-body figure{margin:var(--spacing-xl) 0}.blog-post-body figure img{max-width:100%;height:auto;border-radius:var(--radius-md)}.blog-post-body{font-family:var(--font-family-base);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);color:var(--color-coffee-dark)}.blog-post-lead{font-size:var(--font-size-xl);font-weight:var(--font-weight-medium);color:var(--color-coffee);margin-bottom:var(--spacing-2xl);line-height:var(--line-height-relaxed)}.blog-post-body h2{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);margin:var(--spacing-2xl) 0 var(--spacing-lg);letter-spacing:var(--letter-spacing-tight)}.blog-post-body p{margin:0 0 var(--spacing-lg)}.blog-post-infographic{margin:var(--spacing-3xl) 0;padding:var(--spacing-2xl);background-color:var(--color-cream);border-radius:var(--radius-lg);border:2px dashed var(--color-beige)}.blog-post-infographic-placeholder{text-align:center;padding:var(--spacing-3xl)}.blog-post-infographic-icon{font-size:var(--font-size-5xl);display:block;margin-bottom:var(--spacing-md)}.blog-post-infographic-placeholder p{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-coffee);margin:0 0 var(--spacing-sm)}.blog-post-infographic-placeholder small{font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-gray-dark)}.blog-post-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin:var(--spacing-2xl) 0;padding-top:var(--spacing-2xl);border-top:1px solid var(--color-beige-light)}.blog-post-tag{font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-coffee);background-color:var(--color-cream);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);border:1px solid var(--color-beige)}.blog-post-cta{margin-top:var(--spacing-3xl);padding:var(--spacing-3xl);background:linear-gradient(135deg,var(--color-coffee-dark) 0%,var(--color-coffee) 100%);border-radius:var(--radius-lg);text-align:center;color:var(--color-white)}.blog-post-cta-title{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-md);letter-spacing:var(--letter-spacing-wide)}.blog-post-cta-description{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-xl);opacity:.9}.blog-post-cta-button{display:inline-block;font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);background-color:var(--color-gold);padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-base);letter-spacing:var(--letter-spacing-wide)}.blog-post-cta-button:hover{background-color:var(--color-gold-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.blog-post-sidebar{position:sticky;top:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-lg);width:280px}.blog-post-sidebar-card{padding:var(--spacing-lg)}.blog-post-sidebar-title{font-family:var(--font-family-heading);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);margin:0 0 var(--spacing-sm)}.blog-post-sidebar-description{font-family:var(--font-family-base);font-size:var(--font-size-xs);color:var(--color-coffee);line-height:var(--line-height-normal);margin:0 0 var(--spacing-md)}.blog-post-sidebar-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.blog-post-sidebar-input{font-family:var(--font-family-base);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-beige);border-radius:var(--radius-md);background-color:var(--color-white);color:var(--color-coffee-dark);transition:border-color var(--transition-base)}.blog-post-sidebar-input:focus{outline:none;border-color:var(--color-gold)}.blog-post-sidebar-button{font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-white);background-color:var(--color-coffee-dark);border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base);letter-spacing:var(--letter-spacing-wide)}.blog-post-sidebar-button:hover{background-color:var(--color-gold)}.blog-post-related{display:flex;flex-direction:column;gap:var(--spacing-md)}.blog-post-related-item{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-beige-light);cursor:pointer;transition:transform var(--transition-base)}.blog-post-related-item:last-child{border-bottom:none;padding-bottom:0}.blog-post-related-item:hover{transform:translate(4px)}.blog-post-related-title{font-family:var(--font-family-heading);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-coffee-dark);line-height:var(--line-height-tight);margin:0 0 var(--spacing-xs);transition:color var(--transition-base)}.blog-post-related-item:hover .blog-post-related-title{color:var(--color-gold)}.blog-post-related-meta{font-family:var(--font-family-base);font-size:var(--font-size-xs);color:var(--color-gray-dark);margin:0}.blog-post-error{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center}.blog-post-error h1{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl)}.blog-post-error button{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-white);background-color:var(--color-coffee-dark);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base)}.blog-post-error button:hover{background-color:var(--color-gold)}@media (max-width: 1024px){.blog-post-content-wrapper{grid-template-columns:1fr}.blog-post-sidebar{position:static}}@media (max-width: 768px){.blog-post-title{font-size:var(--font-size-2xl)}.blog-post-body{font-size:var(--font-size-base)}.blog-post-lead{font-size:var(--font-size-lg)}.blog-post-cta{padding:var(--spacing-xl)}.blog-post-meta{flex-wrap:wrap}}.blog-card-tags{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px;z-index:2}.blog-card-tag{display:inline-block;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease}.blog-card-tag:hover{transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.blog-filter-button{transition:all .3s ease}.blog-filter-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.blog-filter-button.active{font-weight:600;box-shadow:0 4px 12px #00000026}.blog-filter-button[title]{position:relative;cursor:help}@media (max-width: 768px){.blog-card-tags{top:8px;left:8px;gap:4px}.blog-card-tag{font-size:10px;padding:3px 8px}}.formo-selection{max-width:1200px;margin:0 auto;padding:40px 20px;padding-top:var(--spacing-md)}.formo-hero{text-align:center;padding:60px 20px;background:linear-gradient(135deg,#f0ebe3,#e4ddd3);border-radius:16px;margin-bottom:40px}.formo-hero-title{font-size:3rem;font-weight:700;color:#6b5444;margin-bottom:16px;font-family:"Noto Serif TC",serif}.formo-hero-subtitle{font-size:1.2rem;color:#8b7355;max-width:800px;margin:0 auto 24px;line-height:1.8}.formo-hero-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;padding:12px 24px;border-radius:50px;box-shadow:0 4px 12px #0000001a}.formo-badge-icon{font-size:1.5rem}.formo-badge-text{font-weight:600;color:#6b5444}.formo-intro{margin-bottom:40px}.formo-intro h2{font-size:2rem;color:#6b5444;margin-bottom:16px;font-family:"Noto Serif TC",serif}.formo-intro p{font-size:1.1rem;line-height:1.8;color:#5a4a3a}.formo-section-title{font-size:2rem;color:#6b5444;text-align:center;margin-bottom:32px;font-family:"Noto Serif TC",serif}.formo-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-bottom:40px}.formo-product-wrapper{border:2px solid transparent;border-radius:12px;transition:all .3s ease}.formo-product-card{overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;cursor:pointer;border:none!important}.formo-product-wrapper:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.formo-product-wrapper:hover .formo-product-card{transform:none}.formo-card-header{padding:16px;text-align:center;color:#fff;font-weight:700}.formo-element{font-size:2rem;font-family:"Noto Serif TC",serif}.formo-element-en{font-size:.9rem;opacity:.9;text-transform:uppercase;letter-spacing:1px}.formo-card-image{width:100%;height:200px;overflow:hidden}.formo-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.formo-product-wrapper:hover .formo-card-image img{transform:scale(1.1)}.formo-card-content{padding:20px}.formo-product-name{font-size:1.5rem;color:#6b5444;margin-bottom:8px;font-family:"Noto Serif TC",serif}.formo-product-subtitle{font-size:1rem;color:#8b7355;margin-bottom:12px}.formo-product-description{font-size:.95rem;color:#5a4a3a;line-height:1.6;margin-bottom:16px}.formo-certification-badge{display:inline-block;padding:8px 16px;border:2px solid;border-radius:8px;font-weight:600;margin-bottom:16px;font-size:.9rem}.formo-certification-count{opacity:.7;margin-left:4px}.formo-view-details{width:100%;padding:12px;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:opacity .3s ease}.formo-view-details:hover{opacity:.9}.formo-detail-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:160px 20px 20px;overflow-y:auto}@media (max-width: 768px){.formo-detail-modal{padding-top:130px}}.formo-detail-content{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:none;margin:0 auto 40px;position:relative;box-shadow:0 20px 60px #0000004d}.formo-close-button{position:absolute;top:16px;right:16px;width:40px;height:40px;border:none;background:#0000001a;border-radius:50%;font-size:2rem;cursor:pointer;transition:background .3s ease;z-index:10}.formo-close-button:hover{background:#0003}.formo-detail-header{padding:40px;text-align:center;border-bottom:3px solid}.formo-detail-element{display:inline-block;padding:8px 24px;border-radius:50px;color:#fff;font-weight:700;margin-bottom:16px;font-size:1.2rem}.formo-detail-header h2{font-size:2.5rem;color:#6b5444;margin-bottom:8px;font-family:"Noto Serif TC",serif}.formo-detail-subtitle{font-size:1.2rem;color:#8b7355}.formo-detail-body{padding:40px}.formo-detail-section{margin-bottom:32px}.formo-detail-section h3{font-size:1.5rem;color:#6b5444;margin-bottom:16px;font-family:"Noto Serif TC",serif}.formo-detail-section p{font-size:1.05rem;line-height:1.8;color:#5a4a3a}.formo-detail-section ul{list-style:none;padding:0}.formo-detail-section li{padding:8px 0 8px 24px;position:relative;font-size:1.05rem;color:#5a4a3a}.formo-detail-section li:before{content:"✓";position:absolute;left:0;color:#d4af37;font-weight:700}.formo-ingredients{display:flex;flex-wrap:wrap;gap:8px}.formo-ingredient-tag{padding:6px 16px;background:#f0ebe3;border-radius:20px;font-size:.95rem;color:#6b5444}.formo-nutrition-label{background:#f9f7f4;border:2px solid #E4DDD3;border-radius:8px;padding:16px}.formo-nutrition-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #E4DDD3}.formo-nutrition-row:last-child{border-bottom:none}.formo-nutrition-row span:first-child{font-weight:600;color:#6b5444}.formo-nutrition-row span:last-child{color:#5a4a3a}.formo-octa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.octa-indicator{padding:16px;border-radius:8px;text-align:center;transition:transform .3s ease}.octa-indicator.passed{background:#e8f5e9;border:2px solid #4CAF50}.octa-indicator.warning{background:#fff3e0;border:2px solid #FF9800}.octa-indicator:hover{transform:translateY(-4px)}.octa-indicator-label{font-size:.85rem;color:#666;margin-bottom:8px}.octa-indicator-value{font-size:1.8rem;font-weight:700;color:#333;margin-bottom:4px}.octa-indicator-target{font-size:.8rem;color:#888}.formo-certification-result{display:flex;align-items:center;gap:16px;padding:20px;border:3px solid;border-radius:12px;background:#f9f7f4}.formo-certification-icon{font-size:3rem}.formo-certification-text{flex:1}.formo-certification-level{font-size:1.5rem;font-weight:700;color:#6b5444;margin-bottom:4px}.formo-certification-score{font-size:1rem;color:#8b7355}.formo-detail-actions{padding:0 40px 40px}.formo-diy-section{background:linear-gradient(135deg,#f9f7f4,#f0ebe3);border:2px solid #E4DDD3;border-radius:12px;padding:24px;margin-bottom:24px;text-align:center}.formo-diy-title{font-size:1.3rem;color:#6b5444;margin-bottom:8px;font-family:"Noto Serif TC",serif;font-weight:600}.formo-diy-description{font-size:1rem;color:#8b7355;margin-bottom:20px;line-height:1.6}.formo-diy-buttons{display:flex;gap:12px;justify-content:center;margin-bottom:16px;flex-wrap:wrap}.formo-recipe-button,.formo-equipment-button{display:flex;align-items:center;gap:8px;padding:12px 20px;border:2px solid;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;font-size:.95rem;min-width:140px;justify-content:center}.formo-recipe-button{background:#fff;border-color:#d4af37;color:#d4af37}.formo-recipe-button:hover{background:#d4af37;color:#fff;transform:translateY(-2px)}.formo-equipment-button{background:#6b5444;border-color:#6b5444;color:#fff}.formo-equipment-button:hover{background:#5a4a3a;border-color:#5a4a3a;transform:translateY(-2px)}.formo-button-icon{font-size:1.1rem}.formo-diy-note{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#d4af371a;border-radius:8px;font-size:.9rem}.formo-note-icon{font-size:1.1rem}.formo-note-text{color:#6b5444;font-weight:500}.formo-purchase-button{display:block;width:100%;padding:16px;border:none;border-radius:8px;color:#fff;font-size:1.1rem;font-weight:600;text-align:center;text-decoration:none;cursor:pointer;transition:opacity .3s ease}.formo-purchase-button:hover{opacity:.9}.formo-qr-section{margin-top:40px}.formo-qr-section h2{font-size:2rem;color:#6b5444;margin-bottom:16px;text-align:center;font-family:"Noto Serif TC",serif}.formo-qr-section p{font-size:1.05rem;line-height:1.8;color:#5a4a3a;text-align:center;margin-bottom:24px}.formo-qr-code{text-align:center}.formo-qr-code img{width:200px;height:200px;border:2px solid #E4DDD3;border-radius:8px;margin-bottom:16px}.formo-qr-url{font-size:.9rem;color:#8b7355;font-family:monospace}@media (max-width: 768px){.formo-hero-title{font-size:2rem}.formo-hero-subtitle{font-size:1rem}.formo-products-grid{grid-template-columns:1fr}.formo-detail-content{max-height:none}.formo-detail-header,.formo-detail-body,.formo-detail-actions{padding:24px}.formo-octa-grid{grid-template-columns:1fr}.formo-certification-result{flex-direction:column;text-align:center}.formo-diy-buttons{flex-direction:column;align-items:center}.formo-recipe-button,.formo-equipment-button{width:100%;max-width:200px}}@media (max-width: 480px){.formo-hero{padding:40px 16px}.formo-hero-title,.formo-detail-header h2{font-size:1.75rem}.formo-section-title{font-size:1.5rem}}.formo-recipe-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:flex-start;justify-content:center;z-index:1001;padding:160px 20px 20px;overflow-y:auto}@media (max-width: 768px){.formo-recipe-modal{padding-top:130px}}.formo-recipe-content{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:none;margin:0 auto 40px;position:relative;box-shadow:0 20px 60px #0000004d}.formo-recipe-header{padding:40px;text-align:center;border-bottom:3px solid;background:linear-gradient(135deg,#f9f7f4,#f0ebe3);border-radius:16px 16px 0 0}.formo-recipe-element{display:inline-block;padding:8px 24px;border-radius:50px;color:#fff;font-weight:700;margin-bottom:16px;font-size:1.2rem}.formo-recipe-header h2{font-size:2rem;color:#6b5444;font-family:"Noto Serif TC",serif}.formo-recipe-body{padding:40px}.formo-recipe-section{margin-bottom:32px}.formo-recipe-section h3{display:flex;align-items:center;gap:8px;font-size:1.5rem;color:#6b5444;margin-bottom:16px;font-family:"Noto Serif TC",serif}.formo-recipe-icon{font-size:1.5rem}.formo-recipe-ingredients-list{background:#f9f7f4;border:2px solid #E4DDD3;border-radius:8px;padding:16px}.formo-recipe-ingredient-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #E4DDD3}.formo-recipe-ingredient-item:last-child{border-bottom:none}.ingredient-name{font-weight:500;color:#6b5444;font-size:1rem}.ingredient-amount{font-weight:600;color:#d4af37;font-size:1rem}.formo-recipe-steps{list-style:none;counter-reset:step-counter;padding:0}.formo-recipe-steps li{counter-increment:step-counter;position:relative;padding:16px 0 16px 60px;margin-bottom:16px;border-left:3px solid #E4DDD3;font-size:1.05rem;line-height:1.8;color:#5a4a3a}.formo-recipe-steps li:before{content:counter(step-counter);position:absolute;left:-20px;top:12px;width:40px;height:40px;background:#d4af37;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.formo-recipe-steps li strong{color:#6b5444;font-weight:600}.formo-recipe-equipment{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.formo-equipment-item{display:flex;gap:12px;padding:16px;background:#f9f7f4;border:2px solid #E4DDD3;border-radius:8px;transition:all .3s ease}.formo-equipment-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.formo-equipment-highlight{background:linear-gradient(135deg,#fff9e6,#fff3d6);border-color:#d4af37;border-width:3px}.equipment-icon{font-size:2rem;flex-shrink:0}.equipment-info{flex:1}.equipment-name{font-weight:600;color:#6b5444;margin-bottom:4px;font-size:1rem}.equipment-description{font-size:.9rem;color:#8b7355;margin-bottom:8px;line-height:1.4}.equipment-buy-link{display:inline-block;font-size:.9rem;font-weight:600;text-decoration:none;transition:opacity .3s ease}.equipment-buy-link:hover{opacity:.7}.formo-recipe-tips{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4CAF50;border-radius:8px;padding:16px}.formo-tip-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(76,175,80,.2)}.formo-tip-item:last-child{border-bottom:none}.tip-icon{color:#4caf50;font-weight:700;font-size:1.2rem;flex-shrink:0}.tip-text{color:#2e7d32;font-size:.95rem;line-height:1.6}@media (max-width: 768px){.formo-recipe-content{max-height:none}.formo-recipe-header,.formo-recipe-body{padding:24px}.formo-recipe-equipment{grid-template-columns:1fr}.formo-recipe-steps li{padding-left:50px}.formo-recipe-steps li:before{left:-18px;width:36px;height:36px;font-size:1rem}}@media (max-width: 480px){.formo-recipe-header h2{font-size:1.5rem}.formo-recipe-section h3{font-size:1.2rem}.formo-recipe-steps li{font-size:.95rem}}.community{max-width:1200px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg)}.community-hero{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 100%);border-radius:var(--radius-xl);margin-bottom:var(--spacing-2xl)}.community-hero-title{font-family:var(--font-family-heading);font-size:var(--font-size-4xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md);font-weight:var(--font-weight-semibold)}.community-hero-subtitle{font-size:var(--font-size-lg);color:var(--color-coffee-dark);letter-spacing:var(--letter-spacing-wide)}.community-intro,.community-join,.community-channels,.community-faq,.community-cta{margin-bottom:var(--spacing-2xl)}.community-chef-note{margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease-out}.community-chef-note-content{padding:var(--spacing-xl);background:linear-gradient(135deg,#d4af3714,#8b451308);border-left:4px solid var(--color-gold);position:relative}.community-chef-note-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.community-chef-note-icon{font-size:var(--font-size-2xl)}.community-chef-note-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-gold);font-weight:var(--font-weight-semibold);font-style:italic;letter-spacing:var(--letter-spacing-wide);margin:0}.community-chef-note-text{font-size:var(--font-size-lg);color:var(--color-coffee-darker);line-height:var(--line-height-relaxed);font-style:italic;margin-bottom:var(--spacing-md);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-light)}.community-chef-note-signature{text-align:right;font-size:var(--font-size-md);color:var(--color-coffee-dark);font-weight:var(--font-weight-semibold);font-style:italic;letter-spacing:var(--letter-spacing-wide)}.community-features{list-style:none;padding:0;margin-top:var(--spacing-lg)}.community-features li{padding:var(--spacing-sm) 0;font-size:var(--font-size-lg);color:var(--color-coffee-dark);line-height:var(--line-height-relaxed)}.community-section-title{text-align:center;font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-xl);font-weight:var(--font-weight-semibold)}.community-steps{display:flex;flex-direction:column;gap:var(--spacing-xl);margin-top:var(--spacing-lg)}.community-step{display:flex;gap:var(--spacing-lg);align-items:flex-start}.community-step-number{flex-shrink:0;width:48px;height:48px;background:var(--color-gold);color:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);font-family:var(--font-family-heading)}.community-step-content{flex:1}.community-step-content h3{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.community-step-content p{color:var(--color-coffee-dark);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-md)}.community-channels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.community-channel{text-align:center;padding:var(--spacing-md)}.community-channel-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.community-channel h3{font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.community-channel p{color:var(--color-coffee-dark);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.community-faq-item{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-cream-dark)}.community-faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.community-faq-item h3{font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold)}.community-faq-item p{color:var(--color-coffee-dark);line-height:var(--line-height-relaxed)}.community-cta{text-align:center}.community-cta h2{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md);font-weight:var(--font-weight-semibold)}.community-cta p{font-size:var(--font-size-lg);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl);line-height:var(--line-height-relaxed)}.community-cta-buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}@media (max-width: 768px){.community-hero-title{font-size:var(--font-size-3xl)}.community-step{flex-direction:column;align-items:center;text-align:center}.community-channels-grid{grid-template-columns:1fr}.community-cta-buttons{flex-direction:column}.community-cta-buttons button{width:100%}}.community-social{margin-bottom:3rem}.social-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}.social-link{display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;background:#ffffff08;border-radius:12px;text-decoration:none;color:inherit;transition:all .3s ease;border:1px solid rgba(255,255,255,.1)}.social-link:hover{background:#ffffff0d;transform:translateY(-5px);border-color:var(--color-gold)}.social-link-disabled{opacity:.5;cursor:not-allowed}.social-link-disabled:hover{transform:none;border-color:#ffffff1a}.social-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin-bottom:1rem;color:var(--color-gold);transition:all .3s ease}.social-icon svg{width:40px;height:40px;transition:all .3s ease}.social-link:hover .social-icon{transform:scale(1.1);color:var(--color-gold-light)}.social-link:hover .social-icon svg{filter:drop-shadow(0 0 8px rgba(212,175,55,.5))}.social-name{font-size:1.2rem;font-weight:600;margin-bottom:.5rem;color:var(--color-gold)}.social-description{font-size:.9rem;color:#ffffffb3;text-align:center}.access-control-wrapper{position:relative;min-height:400px}.locked-content{filter:blur(4px);pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.5}.lock-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#fffffff2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10}.lock-overlay-content{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;max-width:500px;text-align:center}.lock-icon{font-size:4rem;line-height:1;margin-bottom:.5rem;animation:lock-pulse 2s ease-in-out infinite}@keyframes lock-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.lock-title{font-size:1.5rem;font-weight:700;color:#333;margin:0}.lock-description{font-size:1rem;color:#666;line-height:1.6;margin:0}.upgrade-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#8b7355,#6b5745);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #8b73554d;margin-top:.5rem}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b735566;background:linear-gradient(135deg,#6b5745,#5b4735)}.upgrade-button:active{transform:translateY(0);box-shadow:0 2px 8px #8b73554d}.lock-benefits{font-size:.9rem;color:#8b7355;font-style:italic;margin:0;margin-top:.5rem}@media (max-width: 768px){.lock-overlay-content{padding:1.5rem;max-width:90%}.lock-icon{font-size:3rem}.lock-title{font-size:1.25rem}.lock-description{font-size:.95rem}.upgrade-button{padding:.875rem 1.5rem;font-size:1rem;width:100%}.lock-benefits{font-size:.85rem}}@media (max-width: 480px){.access-control-wrapper{min-height:300px}.lock-overlay-content{padding:1rem}.lock-icon{font-size:2.5rem}.lock-title{font-size:1.1rem}.lock-description{font-size:.9rem}.upgrade-button{padding:.75rem 1.25rem;font-size:.95rem}}.ingredient-selector{display:flex;flex-direction:column;gap:1.5rem;margin:1rem 0}.ingredient-search-section{display:flex;flex-direction:column;gap:.5rem}.ingredient-label{font-weight:600;font-size:1rem;color:#333;margin-bottom:.25rem}.search-input-wrapper{position:relative}.ingredient-search-input{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid #ddd;border-radius:8px;transition:border-color .2s}.ingredient-search-input:focus{outline:none;border-color:#8b7355}.ingredient-dropdown{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:#fff;border:2px solid #8b7355;border-radius:8px;margin-top:.25rem;box-shadow:0 4px 12px #00000026;z-index:100}.ingredient-dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f0f0f0}.ingredient-dropdown-item:last-child{border-bottom:none}.ingredient-dropdown-item:hover{background-color:#f8f5f2}.ingredient-dropdown-item.missing-data{background-color:#fff9e6}.ingredient-dropdown-item.missing-data:hover{background-color:#fff3cd}.ingredient-item-name{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#333}.ingredient-item-name-en{font-size:.85rem;color:#666;font-weight:400}.ingredient-warning{font-size:.8rem;color:#856404;margin-top:.25rem}.selected-ingredients-section{display:flex;flex-direction:column;gap:.5rem}.no-ingredients-message{padding:1.5rem;text-align:center;color:#666;background-color:#f8f9fa;border:2px dashed #ddd;border-radius:8px;font-size:.95rem}.selected-ingredients-list{display:flex;flex-direction:column;gap:.75rem}.selected-ingredient-item{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:start;padding:1rem;background-color:#f8f5f2;border:2px solid #e0d5c7;border-radius:8px;transition:border-color .2s}.selected-ingredient-item:hover{border-color:#8b7355}.ingredient-info{display:flex;flex-direction:column;gap:.25rem}.ingredient-name-row{display:flex;align-items:center;gap:.5rem}.ingredient-name{font-weight:600;font-size:1rem;color:#333}.ingredient-category{font-size:.75rem;padding:.2rem .5rem;background-color:#8b7355;color:#fff;border-radius:4px;text-transform:uppercase}.ingredient-missing-warning{font-size:.8rem;color:#856404;background-color:#fff3cd;padding:.25rem .5rem;border-radius:4px;margin-top:.25rem}.ingredient-weight-input{display:flex;align-items:center;gap:.5rem}.weight-input{width:100px;padding:.5rem .75rem;font-size:1rem;border:2px solid #ddd;border-radius:6px;transition:border-color .2s;background-color:#fff!important}.weight-input:focus{outline:none;border-color:#8b7355}.weight-input.error{border-color:#dc3545;background-color:#fff5f5}.weight-unit{font-size:.9rem;color:#666;font-weight:500}.remove-ingredient-btn{padding:.5rem .75rem;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1.1rem;font-weight:700;transition:background-color .2s;line-height:1}.remove-ingredient-btn:hover{background-color:#c82333}.remove-ingredient-btn:active{transform:scale(.95)}.validation-error{grid-column:1 / -1;font-size:.85rem;color:#dc3545;background-color:#fff5f5;padding:.5rem;border-radius:4px;margin-top:.25rem}@media (max-width: 768px){.selected-ingredient-item{grid-template-columns:1fr;gap:.75rem}.ingredient-weight-input{justify-content:space-between}.weight-input{flex:1;max-width:150px}.remove-ingredient-btn{width:100%;padding:.75rem}.ingredient-dropdown{max-height:250px}}@media (max-width: 480px){.ingredient-search-input,.weight-input{font-size:16px}}.compliance-indicator{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border-radius:8px;border:2px solid;margin:1rem 0}.compliance-badge{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1.1rem}.compliance-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background-color:#ffffff4d;font-size:.9rem}.compliance-label{text-transform:uppercase;letter-spacing:.5px}.compliance-value{font-size:1.5rem;font-weight:700;margin:.25rem 0}.compliance-thresholds{display:flex;flex-wrap:wrap;gap:1rem;font-size:.85rem;opacity:.9;margin-top:.5rem;padding-top:.75rem;border-top:1px solid rgba(0,0,0,.1)}.threshold-item{white-space:nowrap}.compliance-excellent{background-color:#d4edda;border-color:#28a745;color:#155724}.compliance-excellent .compliance-icon{background-color:#28a745;color:#fff}.compliance-good{background-color:#d1ecf1;border-color:#17a2b8;color:#0c5460}.compliance-good .compliance-icon{background-color:#17a2b8;color:#fff}.compliance-warning{background-color:#fff3cd;border-color:#ffc107;color:#856404}.compliance-warning .compliance-icon{background-color:#ffc107;color:#333}.compliance-low{background-color:#d4edda;border-color:#28a745;color:#155724}.compliance-low .compliance-icon{background-color:#28a745;color:#fff}.compliance-medium{background-color:#fff3cd;border-color:#ffc107;color:#856404}.compliance-medium .compliance-icon{background-color:#ffc107;color:#333}.compliance-high{background-color:#f8d7da;border-color:#dc3545;color:#721c24}.compliance-high .compliance-icon{background-color:#dc3545;color:#fff}@media (max-width: 768px){.compliance-indicator{padding:.875rem}.compliance-badge{font-size:1rem}.compliance-value{font-size:1.25rem}.compliance-thresholds{flex-direction:column;gap:.5rem}}.educational-content{margin-top:2rem;border-top:1px solid #e0e0e0;padding-top:1.5rem}.educational-section{margin-bottom:1rem;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.section-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background-color:#f8f9fa;border:none;cursor:pointer;transition:background-color .2s;font-size:1rem;font-weight:500}.section-header:hover{background-color:#e9ecef}.section-header:focus{outline:2px solid #007bff;outline-offset:-2px}.section-title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#333}.section-toggle{color:#666;font-size:.875rem}.section-content{padding:1.25rem;background-color:#fff;animation:slideDown .2s ease-out}.content-block{margin-bottom:1.5rem}.content-block:last-child{margin-bottom:0}.content-block h4{font-size:.95rem;font-weight:600;color:#495057;margin-bottom:.5rem}.content-block p{font-size:.9rem;line-height:1.6;color:#666;margin:0}.content-block ul{margin:0;padding-left:1.5rem;list-style-type:disc}.content-block li{font-size:.9rem;line-height:1.6;color:#666;margin-bottom:.5rem}.content-block li:last-child{margin-bottom:0}.content-block a{color:#007bff;text-decoration:none;transition:color .2s}.content-block a:hover{color:#0056b3;text-decoration:underline}@media (max-width: 768px){.section-header{padding:.875rem 1rem;font-size:.95rem}.section-content{padding:1rem}.content-block h4{font-size:.9rem}.content-block p,.content-block li{font-size:.85rem}}.aw-calculator{max-width:900px;margin:0 auto;padding:1.5rem}.result-breakdown{margin-top:2rem}.breakdown-title{font-size:1.1rem;font-weight:600;color:#495057;margin-bottom:1rem}.breakdown-table{border:1px solid #dee2e6;border-radius:6px;overflow:hidden}.breakdown-header,.breakdown-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:.875rem 1rem;align-items:center}.breakdown-header{background-color:#f8f9fa;font-weight:600;font-size:.875rem;color:#495057;border-bottom:1px solid #dee2e6}.breakdown-row{font-size:.9rem;color:#666;border-bottom:1px solid #f1f3f5}@media (max-width: 768px){.aw-calculator{padding:1rem}.calculator-title{font-size:1.5rem}.calculator-description{font-size:.9rem}.calculator-body{padding:1rem}.result-value{font-size:2rem}.breakdown-header,.breakdown-row{grid-template-columns:1fr;gap:.5rem;padding:.75rem}.breakdown-header{display:none}.breakdown-row{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.breakdown-row>span:not(.breakdown-ingredient){font-size:.85rem}.breakdown-row>span:not(.breakdown-ingredient):before{content:attr(data-label);font-weight:600;margin-right:.5rem}}@media (max-width: 480px){.calculator-title{font-size:1.25rem}.result-value{font-size:1.75rem}}.df-calculator{max-width:900px;margin:0 auto;padding:1.5rem}.result-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1.5rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px}.detail-item{display:flex;flex-direction:column;gap:.5rem}.detail-label{font-size:.875rem;color:#666;font-weight:500}.detail-value{font-size:1.25rem;font-weight:600;color:#2c3e50}@media (max-width: 768px){.df-calculator{padding:1rem}.calculator-title{font-size:1.5rem}.calculator-description{font-size:.9rem}.calculator-body{padding:1rem}.result-value{font-size:2rem}.result-details{grid-template-columns:1fr;padding:1rem}.detail-value{font-size:1.1rem}}@media (max-width: 480px){.calculator-title{font-size:1.25rem}.result-value{font-size:1.75rem}.detail-value{font-size:1rem}}.wac-calculator{max-width:900px;margin:0 auto;padding:1.5rem}.calculator-title{font-size:1.75rem;font-weight:700;color:#2c3e50;margin-bottom:.5rem}.calculator-description{font-size:1rem;color:#666;line-height:1.5}.calculator-error{background-color:#fee;border:1px solid #fcc;border-radius:6px;padding:1rem;margin-bottom:1.5rem;color:#c33;font-size:.95rem}.calculator-warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:1rem;margin-bottom:1.5rem;color:#856404;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.calculator-warning:before{content:"⚠";font-size:1.25rem}.calculator-body{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.wac-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-label{font-size:.95rem;font-weight:600;color:#495057}.input-field{padding:.75rem 1rem;font-size:1rem;border:2px solid #dee2e6;border-radius:6px;transition:border-color .2s ease}.input-field:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.input-field:hover{border-color:#adb5bd}.input-hint{font-size:.85rem;color:#6c757d}.input-hint.error{color:#c33}.calculator-results{margin-top:2rem;padding-top:2rem;border-top:2px solid #e9ecef}.result-main{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.result-value-display{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background-color:#f8f9fa;border-radius:8px}.result-label{font-size:.9rem;color:#666;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.result-value{font-size:2.5rem;font-weight:700;color:#2c3e50}.flour-type-info{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff}.flour-type-badge{display:flex;align-items:center;gap:.5rem}.flour-type-icon{font-size:1.5rem}.flour-type-name{font-size:1.25rem;font-weight:600}.flour-type-range{font-size:.95rem;opacity:.9}.typical-ranges{margin-top:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px}.ranges-title{font-size:1.1rem;font-weight:600;color:#495057;margin-bottom:1rem;text-align:center}.ranges-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.range-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background-color:#fff;border:2px solid #dee2e6;border-radius:6px;transition:all .2s ease}.range-item:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 8px #667eea33}.range-type{font-size:.9rem;font-weight:600;color:#495057;text-align:center}.range-value{font-size:1.1rem;font-weight:700;color:#667eea}@media (max-width: 768px){.wac-calculator{padding:1rem}.calculator-title{font-size:1.5rem}.calculator-description{font-size:.9rem}.calculator-body{padding:1rem}.wac-inputs{grid-template-columns:1fr;gap:1rem}.result-value{font-size:2rem}.flour-type-name{font-size:1.1rem}.ranges-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.range-item{padding:.75rem}}@media (max-width: 480px){.calculator-title{font-size:1.25rem}.result-value{font-size:1.75rem}.ranges-grid{grid-template-columns:1fr}}.gl-calculator{width:100%;max-width:900px;margin:0 auto}.calculator-description{font-size:1rem;color:#7f8c8d;line-height:1.6}.calculator-body{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014;margin-bottom:2rem}.calculator-results{margin-top:2rem;padding-top:2rem;border-top:2px solid #ecf0f1}.results-title{font-size:1.25rem;font-weight:600;color:#2c3e50;margin-bottom:1.5rem}.result-main{display:flex;align-items:center;gap:2rem;margin-bottom:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px}.result-value-display{flex:1;display:flex;flex-direction:column;gap:.5rem}.result-label{font-size:.9rem;color:#7f8c8d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.result-category{font-size:1rem;font-weight:600;color:#3498db;margin-top:.25rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.detail-label{font-size:.9rem;color:#7f8c8d;font-weight:500}.detail-value{font-size:1.1rem;font-weight:600;color:#2c3e50}.gl-standards{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.standards-title{font-size:1.1rem;font-weight:600;color:#2c3e50;margin-bottom:1rem}.standards-list{list-style:none;padding:0;margin:0 0 1rem}.standards-list li{padding:.75rem 1rem;margin-bottom:.5rem;border-radius:6px;font-size:.95rem;line-height:1.5}.standard-low{background:#d4edda;border-left:4px solid #28a745;color:#155724}.standard-medium{background:#fff3cd;border-left:4px solid #ffc107;color:#856404}.standard-high{background:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.idia-standard{margin-top:1rem;padding:1rem;background:#e3f2fd;border-left:4px solid #2196f3;border-radius:6px;font-size:.95rem;color:#0d47a1}@media (max-width: 768px){.calculator-body{padding:1.5rem}.calculator-title{font-size:1.5rem}.result-main{flex-direction:column;gap:1rem}.result-value{font-size:2rem}.result-details{grid-template-columns:1fr}.detail-item{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 480px){.calculator-title{font-size:1.25rem}.calculator-description{font-size:.9rem}.result-value{font-size:1.75rem}}.pdcaas-calculator{width:100%;max-width:900px;margin:0 auto}.calculator-info-box{background-color:#e8f4f8;border-left:4px solid #3498db;padding:1rem;margin-bottom:1.5rem;border-radius:4px}.info-text{margin:0 0 .5rem;font-size:.95rem;color:#2c3e50}.info-note{margin:0;font-size:.875rem;color:#5a6c7d;line-height:1.5}.calculator-error{background-color:#fee;border-left:4px solid #e74c3c;padding:1rem;margin-bottom:1.5rem;border-radius:4px;color:#c0392b;font-size:.95rem}.calculator-results{margin-top:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.results-title{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0 0 1.5rem}.result-main{display:flex;align-items:center;gap:2rem;margin-bottom:1.5rem;padding:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.result-value{font-size:2.5rem;font-weight:700;color:#2c3e50;line-height:1}.result-quality{font-size:1rem;color:#3498db;font-weight:600}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#fff;border-radius:6px;border:1px solid #e9ecef}.result-breakdown{margin-top:1.5rem}.breakdown-title{font-size:1rem;font-weight:600;color:#2c3e50;margin:0 0 1rem}.breakdown-table{background-color:#fff;border-radius:6px;overflow:hidden;border:1px solid #e9ecef}.breakdown-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:.75rem 1rem;background-color:#f8f9fa;font-size:.875rem;font-weight:600;color:#5a6c7d;border-bottom:1px solid #e9ecef}.breakdown-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:.75rem 1rem;font-size:.875rem;color:#2c3e50;border-bottom:1px solid #f1f3f5}.breakdown-row:hover{background-color:#f8f9fa}.breakdown-ingredient{font-weight:500}@media (max-width: 768px){.calculator-title{font-size:1.5rem}.result-main{flex-direction:column;align-items:flex-start;gap:1rem}.result-value{font-size:2rem}.breakdown-header,.breakdown-row{grid-template-columns:1.5fr 1fr .8fr 1fr;gap:.5rem;padding:.5rem;font-size:.8rem}.detail-item{padding:.75rem}}@media (max-width: 480px){.breakdown-header,.breakdown-row{grid-template-columns:1fr;gap:.25rem}.breakdown-header span,.breakdown-row span{padding:.25rem 0}.breakdown-header span:not(:first-child):before,.breakdown-row span:not(:first-child):before{content:attr(data-label);font-weight:600;margin-right:.5rem}}.co2e-calculator{width:100%;max-width:1200px;margin:0 auto}.calculator-header{margin-bottom:1.5rem}.calculator-title{font-size:1.75rem;font-weight:600;color:#2c3e50;margin-bottom:.5rem}.calculator-description{font-size:1rem;color:#7f8c8d;margin:0}.calculator-info-box{background-color:#e8f5e9;border-left:4px solid #4caf50;padding:1rem;margin-bottom:1.5rem;border-radius:4px}.info-text{margin:0 0 .5rem;color:#2e7d32;font-size:.95rem}.info-note{margin:0;color:#558b2f;font-size:.875rem;line-height:1.5}.calculator-error{background-color:#ffebee;border-left:4px solid #f44336;padding:1rem;margin-bottom:1.5rem;border-radius:4px;color:#c62828}.calculator-body{margin-bottom:2rem}.calculator-results{margin-top:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px}.results-title{font-size:1.25rem;font-weight:600;color:#2c3e50;margin-bottom:1rem}.result-main{display:flex;align-items:center;gap:2rem;margin-bottom:1.5rem;padding:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.result-label{font-size:.875rem;color:#7f8c8d;font-weight:500}.result-value{font-size:1.5rem;font-weight:700;color:#2c3e50}.result-quality{font-size:.875rem;color:#4caf50;font-weight:600}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a}.detail-label{font-size:.875rem;color:#7f8c8d;font-weight:500}.detail-value{font-size:1.125rem;font-weight:600;color:#2c3e50}.result-breakdown{margin-top:1.5rem;padding:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.breakdown-title{font-size:1.125rem;font-weight:600;color:#2c3e50;margin-bottom:1rem}.breakdown-table{display:flex;flex-direction:column;gap:.5rem}.breakdown-header{display:grid;grid-template-columns:2fr 1fr 1.2fr 1fr .8fr;gap:1rem;padding:.75rem 1rem;background-color:#f8f9fa;border-radius:4px;font-weight:600;font-size:.875rem;color:#495057}.breakdown-row{display:grid;grid-template-columns:2fr 1fr 1.2fr 1fr .8fr;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #e9ecef;font-size:.875rem;align-items:center}.breakdown-row:last-child{border-bottom:none}.breakdown-ingredient{font-weight:500;color:#2c3e50}.category-breakdown{display:flex;flex-direction:column;gap:1rem}.category-item{display:grid;grid-template-columns:120px 1fr 150px;gap:1rem;align-items:center}.category-name{font-weight:500;color:#2c3e50;font-size:.875rem}.category-bar-container{height:24px;background-color:#e9ecef;border-radius:12px;overflow:hidden}.category-bar{height:100%;background:linear-gradient(90deg,#4caf50,#66bb6a);transition:width .3s ease}.category-value{font-size:.875rem;color:#495057;text-align:right}@media (max-width: 768px){.result-main{flex-direction:column;gap:1rem}.breakdown-header,.breakdown-row{grid-template-columns:1.5fr .8fr 1fr .8fr .6fr;gap:.5rem;padding:.5rem;font-size:.75rem}.category-item{grid-template-columns:100px 1fr 120px;gap:.5rem}.result-details{grid-template-columns:1fr}}.pcratio-calculator{width:100%;max-width:900px;margin:0 auto}.result-recommendation{background-color:#fff;border-radius:8px;padding:1.25rem;border-left:4px solid var(--primary-color, #8b4513)}.recommendation-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:.75rem}.recommendation-text{font-size:.95rem;color:var(--text-secondary, #666);line-height:1.6;white-space:pre-line}@media (max-width: 768px){.calculator-title{font-size:1.5rem}.result-main{flex-direction:column;align-items:flex-start;gap:1rem}.result-value{font-size:1.75rem}.result-details{grid-template-columns:1fr}}.lipisync-calculator{width:100%;max-width:900px;margin:0 auto}.calculator-header{margin-bottom:2rem;text-align:center}.calculator-title{font-size:1.75rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:.5rem}.calculator-description{font-size:1rem;color:var(--text-secondary, #666);line-height:1.6}.calculator-error{background-color:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#c33;font-size:.95rem}.calculator-body{display:flex;flex-direction:column;gap:2rem}.fat-selector{background-color:var(--bg-secondary, #f8f9fa);border-radius:12px;padding:1.5rem}.selector-title{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:1rem}.selector-controls{display:flex;gap:1rem;align-items:center}.fat-select{flex:1;padding:.75rem 1rem;border:1px solid var(--border-color, #e0e0e0);border-radius:8px;font-size:1rem;background-color:#fff;cursor:pointer}.fat-select:focus{outline:none;border-color:var(--primary-color, #8b4513);box-shadow:0 0 0 3px #8b45131a}.add-button{padding:.75rem 1.5rem;background-color:var(--primary-color, #8b4513);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-button:hover:not(:disabled){background-color:var(--primary-dark, #6d3610)}.add-button:disabled{background-color:#ccc;cursor:not-allowed}.selected-fats{background-color:var(--bg-secondary, #f8f9fa);border-radius:12px;padding:1.5rem}.list-title{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:1rem}.fats-list{display:flex;flex-direction:column;gap:.75rem}.fat-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#fff;border-radius:8px;border:1px solid var(--border-color, #e0e0e0)}.fat-info{display:flex;flex-direction:column;gap:.25rem}.fat-name{font-size:1rem;font-weight:500;color:var(--text-primary, #1a1a1a)}.fat-category{font-size:.85rem;color:var(--text-secondary, #666);padding:.25rem .5rem;background-color:var(--bg-tertiary, #f0f0f0);border-radius:4px;width:fit-content}.fat-controls{display:flex;align-items:center;gap:.5rem}.weight-input{width:100px;padding:.5rem;border:1px solid var(--border-color, #e0e0e0);border-radius:6px;font-size:.95rem;text-align:right}.weight-input:focus{outline:none;border-color:var(--primary-color, #8b4513);box-shadow:0 0 0 2px #8b45131a}.unit{font-size:.9rem;color:var(--text-secondary, #666);font-weight:500}.remove-button{padding:.5rem .75rem;background-color:#fee;color:#c33;border:1px solid #fcc;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s}.remove-button:hover{background-color:#fcc;border-color:#faa}.calculator-results{background-color:var(--bg-secondary, #f8f9fa);border-radius:12px;padding:1.5rem;margin-top:1.5rem}.results-title{font-size:1.25rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:1.5rem}.result-main{display:flex;align-items:center;gap:2rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color, #e0e0e0)}.result-value-display{display:flex;flex-direction:column;gap:.5rem}.result-label{font-size:.9rem;color:var(--text-secondary, #666);font-weight:500}.result-value{font-size:2rem;font-weight:700;color:var(--primary-color, #8b4513)}.result-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#fff;border-radius:8px;border:1px solid var(--border-color, #e0e0e0)}.detail-label{font-size:.9rem;color:var(--text-secondary, #666);font-weight:500}.detail-value{font-size:1.1rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.result-health-impact{background-color:#fff;border-radius:8px;padding:1.25rem;margin-bottom:1.5rem;border-left:4px solid var(--primary-color, #8b4513)}.health-impact-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:.75rem}.health-impact-text{font-size:.95rem;color:var(--text-secondary, #666);line-height:1.6}.result-recommendations{background-color:#fff;border-radius:8px;padding:1.25rem}.recommendations-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:.75rem}.recommendations-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.recommendation-item{font-size:.95rem;color:var(--text-secondary, #666);line-height:1.6;padding-left:1.5rem;position:relative}.recommendation-item:before{content:"•";position:absolute;left:.5rem;color:var(--primary-color, #8b4513);font-weight:700}@media (max-width: 768px){.calculator-title{font-size:1.5rem}.selector-controls{flex-direction:column}.fat-select,.add-button{width:100%}.fat-item{flex-direction:column;align-items:flex-start;gap:1rem}.fat-controls{width:100%;justify-content:space-between}.result-main{flex-direction:column;align-items:flex-start;gap:1rem}.result-value{font-size:1.75rem}.result-details{grid-template-columns:1fr}}.calculator-selector{width:100%;margin:0 auto}.calculator-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.calculator-card{position:relative;display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 1px 3px #0000001a}.calculator-card:hover{border-color:#8b7355;box-shadow:0 4px 12px #8b735526;transform:translateY(-2px)}.calculator-card:focus{outline:2px solid #8b7355;outline-offset:2px}.calculator-card.active{border-color:#8b7355;background:linear-gradient(135deg,#faf8f5,#fff);box-shadow:0 4px 16px #8b735533}.calculator-card.locked{opacity:.6;cursor:not-allowed;background:#f9fafb}.calculator-card.locked:hover{transform:none;box-shadow:0 1px 3px #0000001a;border-color:#e5e7eb}.calculator-card-icon{font-size:3rem;margin-bottom:1rem;line-height:1}.calculator-card-content{text-align:center;width:100%}.calculator-card-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.calculator-card-code{font-size:1rem;font-weight:500;color:#8b7355}.calculator-card-description{font-size:.875rem;color:#6b7280;margin:0;line-height:1.5}.calculator-card-active-indicator{position:absolute;top:.75rem;right:.75rem;width:28px;height:28px;background:#8b7355;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;box-shadow:0 2px 8px #8b73554d}.active-calculator-container{margin-top:2rem;padding:2rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000d}.calculator-placeholder{padding:3rem 2rem;text-align:center;color:#6b7280;font-size:1.125rem;background:#f9fafb;border-radius:8px;border:2px dashed #d1d5db}@media (max-width: 1023px){.calculator-cards-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.calculator-card{padding:1.25rem}.calculator-card-icon{font-size:2.5rem}.calculator-card-title{font-size:1.125rem}.active-calculator-container{padding:1.5rem}}@media (max-width: 767px){.calculator-cards-grid{grid-template-columns:1fr;gap:1rem}.calculator-card{padding:1rem;flex-direction:row;text-align:left;gap:1rem}.calculator-card-icon{font-size:2rem;margin-bottom:0;flex-shrink:0}.calculator-card-content{text-align:left;flex:1}.calculator-card-title{font-size:1rem;justify-content:flex-start;flex-wrap:nowrap}.calculator-card-code{font-size:.875rem}.calculator-card-description{font-size:.8125rem}.calculator-card-active-indicator{top:.5rem;right:.5rem;width:24px;height:24px;font-size:.875rem}.active-calculator-container{padding:1rem;margin-top:1.5rem}.calculator-placeholder{padding:2rem 1rem;font-size:1rem}}@media (max-width: 767px){.calculator-card-description{font-size:max(.8125rem,14px)}}.certification-calculators-section{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}.brand-header{text-align:center;margin-bottom:3rem;padding:2rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;box-shadow:0 2px 8px #0000000d}.system-title{font-size:2rem;font-weight:700;color:#2c3e50;margin:0 0 1.5rem;letter-spacing:.5px}.attribution-container{display:flex;flex-direction:column;gap:.5rem;align-items:center}.ownership-attribution{font-size:1.125rem;color:#34495e;margin:0;font-weight:500}.ownership-attribution strong{font-weight:700;color:#2c3e50;font-size:1.25rem}.idia-authorization{font-size:.95rem;color:#7f8c8d;margin:0;font-style:italic}.calculator-interface{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 12px #00000014}.calculator-selector-placeholder,.active-calculator-placeholder{padding:3rem 2rem;text-align:center;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.calculator-selector-placeholder p,.active-calculator-placeholder p{margin:.5rem 0;color:#495057;font-size:1rem}.placeholder-note{font-size:.875rem;color:#6c757d;margin-top:1rem;line-height:1.6}@media (max-width: 768px){.certification-calculators-section{padding:1.5rem 1rem}.brand-header{padding:1.5rem 1rem;margin-bottom:2rem}.system-title{font-size:1.5rem;margin-bottom:1rem}.ownership-attribution{font-size:1rem}.ownership-attribution strong{font-size:1.125rem}.idia-authorization{font-size:.875rem}.calculator-interface{padding:1.5rem 1rem}.calculator-selector-placeholder,.active-calculator-placeholder{padding:2rem 1rem}}@media (max-width: 480px){.system-title{font-size:1.25rem;line-height:1.4}.ownership-attribution{font-size:.9rem}.ownership-attribution strong{font-size:1rem}.idia-authorization{font-size:.8rem}}.research{max-width:1400px;margin:0 auto;padding:0;background:#fff;padding-top:var(--spacing-md)}.research-magazine-header{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg) var(--spacing-2xl);border-bottom:1px solid rgba(139,69,19,.1);background:linear-gradient(180deg,#fafaf8,#fff)}.research-magazine-title h1{font-family:"Playfair Display",var(--font-family-heading);font-size:4rem;font-weight:700;color:var(--color-coffee-darker);letter-spacing:-.02em;margin-bottom:var(--spacing-sm);text-transform:uppercase}.research-magazine-subtitle{font-family:var(--font-family-base);font-size:var(--font-size-lg);color:var(--color-gold);font-style:italic;font-weight:300;letter-spacing:.05em}.research-magazine-meta{margin-top:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-coffee-dark);letter-spacing:.1em;text-transform:uppercase}.research-issue{font-weight:600}.research-divider{margin:0 var(--spacing-md);color:var(--color-gold)}.research-publisher{font-weight:300}.research-featured{position:relative;height:70vh;min-height:500px;max-height:800px;cursor:pointer;overflow:hidden;margin-bottom:var(--spacing-3xl)}.research-featured-image{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.research-featured-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}.research-featured:hover .research-featured-image img{transform:scale(1.05)}.research-featured-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#f5f1ed,#e8dfd5);display:flex;align-items:center;justify-content:center}.research-featured-placeholder span{font-size:8rem;opacity:.3}.research-featured-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,#0000,#000000b3);display:flex;align-items:flex-start;justify-content:flex-end;padding:var(--spacing-xl)}.research-featured-label{background:var(--color-gold);color:#fff;padding:var(--spacing-xs) var(--spacing-lg);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.15em;text-transform:uppercase}.research-featured-content{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-3xl);color:#fff;z-index:2}.research-featured-title{font-family:"Playfair Display",var(--font-family-heading);font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:var(--spacing-lg);text-shadow:0 2px 20px rgba(0,0,0,.3)}.research-featured-excerpt{font-size:var(--font-size-lg);line-height:1.6;margin-bottom:var(--spacing-lg);max-width:700px;font-weight:300;text-shadow:0 1px 10px rgba(0,0,0,.3)}.research-featured-meta{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:300;letter-spacing:.05em;text-transform:uppercase}.research-meta-divider{color:var(--color-gold)}.research-articles{padding:var(--spacing-3xl) var(--spacing-xl);max-width:1200px;margin:0 auto}.research-articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-2xl)}.research-article{cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative}.research-article-large{grid-column:span 2;grid-row:span 2}.research-article:hover{transform:translateY(-4px)}.research-article-image{position:relative;width:100%;padding-bottom:125%;overflow:hidden;background:#f5f1ed;margin-bottom:var(--spacing-md)}.research-article-large .research-article-image{padding-bottom:75%}.research-article-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}.research-article:hover .research-article-image img{transform:scale(1.08)}.research-article-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f1ed,#e8dfd5)}.research-article-placeholder span{font-size:4rem;opacity:.3}.research-article-content{padding:0 var(--spacing-sm)}.research-article-title{font-family:"Playfair Display",var(--font-family-heading);font-size:var(--font-size-xl);font-weight:600;line-height:1.3;color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.research-article-large .research-article-title{font-size:var(--font-size-3xl);-webkit-line-clamp:3}.research-article-excerpt{font-size:var(--font-size-sm);line-height:1.6;color:var(--color-coffee-dark);margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-weight:300}.research-article-large .research-article-excerpt{font-size:var(--font-size-md);-webkit-line-clamp:4}.research-article-meta{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-coffee-dark);font-weight:300;letter-spacing:.05em;text-transform:uppercase}.research-idia-section{padding:var(--spacing-3xl) var(--spacing-xl);max-width:800px;margin:0 auto;background:linear-gradient(180deg,#fff,#fafaf8)}.research-idia-card{text-align:center;padding:var(--spacing-3xl)!important;border:2px solid var(--color-gold)}.research-idia-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.research-idia-icon{font-size:4rem}.research-idia-title{font-family:"Playfair Display",var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:700;color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs)}.research-idia-subtitle{font-size:var(--font-size-md);color:var(--color-gold);font-style:italic;font-weight:300}.research-idia-description{font-size:var(--font-size-md);line-height:1.8;color:var(--color-coffee-dark);margin-bottom:var(--spacing-2xl);font-weight:300}.research-octagon-intro{padding:var(--spacing-3xl) var(--spacing-xl);max-width:800px;margin:0 auto;background:linear-gradient(180deg,#fafaf8,#fff)}.research-octagon-card{text-align:center;padding:var(--spacing-3xl)!important;border:2px solid var(--color-gold);background:linear-gradient(135deg,#fff9f0,#fff)}.research-octagon-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.research-octagon-icon{font-size:4rem}.research-octagon-title{font-family:"Playfair Display",var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:700;color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs)}.research-octagon-subtitle{font-size:var(--font-size-md);color:var(--color-gold);font-style:italic;font-weight:300}.research-octagon-description{font-size:var(--font-size-md);line-height:1.8;color:var(--color-coffee-dark);margin-bottom:var(--spacing-2xl);font-weight:300}.research-octagon-features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg);margin-top:var(--spacing-2xl)}.research-octagon-feature{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:#fff;border-radius:12px;border:1px solid rgba(139,69,19,.1);transition:all .3s ease}.research-octagon-feature:hover{transform:translateY(-4px);box-shadow:0 8px 24px #8b45131a;border-color:var(--color-gold)}.research-octagon-feature-icon{font-size:2.5rem}.research-octagon-feature-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-coffee-darker);text-align:center;line-height:1.4}.research-empty{padding:var(--spacing-5xl) var(--spacing-xl);text-align:center}.research-empty-content{max-width:500px;margin:0 auto}.research-empty-icon{font-size:5rem;display:block;margin-bottom:var(--spacing-xl);opacity:.3}.research-empty h3{font-family:"Playfair Display",var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md)}.research-empty p{font-size:var(--font-size-md);color:var(--color-coffee-dark);line-height:1.6;font-weight:300}.research-loading{padding:var(--spacing-5xl) var(--spacing-xl);text-align:center;font-size:var(--font-size-xl);color:var(--color-coffee-dark);font-weight:300}@media (max-width: 1024px){.research-magazine-title h1{font-size:3rem}.research-featured-title{font-size:2.5rem}.research-articles-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}.research-article-large{grid-column:span 2;grid-row:span 1}}@media (max-width: 768px){.research{padding:0}.research-magazine-header{padding:var(--spacing-2xl) var(--spacing-md) var(--spacing-xl)}.research-magazine-title h1{font-size:2.5rem}.research-magazine-subtitle{font-size:var(--font-size-md)}.research-featured{height:60vh;min-height:400px}.research-featured-content{padding:var(--spacing-xl)}.research-featured-title{font-size:2rem}.research-featured-excerpt{font-size:var(--font-size-md)}.research-articles{padding:var(--spacing-2xl) var(--spacing-md)}.research-articles-grid{grid-template-columns:1fr;gap:var(--spacing-2xl)}.research-article-large{grid-column:span 1;grid-row:span 1}.research-article-title{font-size:var(--font-size-lg)}.research-article-large .research-article-title{font-size:var(--font-size-2xl)}.research-idia-section{padding:var(--spacing-2xl) var(--spacing-md)}.research-idia-card{padding:var(--spacing-2xl)!important}.research-idia-header{flex-direction:column;gap:var(--spacing-md)}.research-idia-icon{font-size:3rem}.research-idia-title{font-size:var(--font-size-2xl)}.research-octagon-intro{padding:var(--spacing-2xl) var(--spacing-md)}.research-octagon-card{padding:var(--spacing-2xl)!important}.research-octagon-header{flex-direction:column;gap:var(--spacing-md)}.research-octagon-icon{font-size:3rem}.research-octagon-title{font-size:var(--font-size-2xl)}.research-octagon-features{grid-template-columns:1fr;gap:var(--spacing-md)}}.research-formo-section{padding:var(--spacing-3xl) var(--spacing-xl);max-width:800px;margin:0 auto;background:linear-gradient(180deg,#fff,#fafaf8)}.research-formo-card{text-align:center;padding:var(--spacing-3xl)!important;border:2px solid var(--color-gold);background:linear-gradient(135deg,#fff9f0,#fff)}.research-formo-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.research-formo-icon{font-size:4rem}.research-formo-title{font-family:"Playfair Display",var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:700;color:var(--color-coffee-darker);margin-bottom:var(--spacing-xs)}.research-formo-subtitle{font-size:var(--font-size-md);color:var(--color-gold);font-style:italic;font-weight:300}.research-formo-description{font-size:var(--font-size-md);line-height:1.8;color:var(--color-coffee-dark);margin-bottom:var(--spacing-2xl);font-weight:300}.research-formo-products{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);text-align:left}.research-formo-product{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#fff;border-radius:8px;border:1px solid rgba(139,69,19,.1);transition:all .3s ease}.research-formo-product:hover{transform:translate(8px);box-shadow:0 4px 12px #8b45131a;border-color:var(--color-gold)}.research-formo-element{font-family:"Noto Serif TC",serif;font-size:var(--font-size-xl);font-weight:700;min-width:100px}.research-formo-name{font-size:var(--font-size-md);color:var(--color-coffee-darker);font-weight:400}@media (max-width: 768px){.research-formo-section{padding:var(--spacing-2xl) var(--spacing-md)}.research-formo-card{padding:var(--spacing-2xl)!important}.research-formo-header{flex-direction:column;gap:var(--spacing-md)}.research-formo-icon{font-size:3rem}.research-formo-title{font-size:var(--font-size-2xl)}.research-formo-product{flex-direction:column;text-align:center}.research-formo-element{min-width:auto}}.ai-feature-gate{position:relative;min-height:300px}.ai-feature-gate-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:12px;border:2px solid #e0e0e0}.ai-feature-gate-content{text-align:center;padding:40px;max-width:500px}.ai-feature-gate-icon{font-size:48px;margin-bottom:20px}.ai-feature-gate-title{font-size:24px;font-weight:600;color:#333;margin-bottom:16px}.ai-feature-gate-description{font-size:16px;color:#666;margin-bottom:8px;line-height:1.5}.ai-feature-gate-description-en{font-size:14px;color:#888;margin-bottom:24px;line-height:1.5}.ai-feature-gate-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 32px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.ai-feature-gate-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.ai-feature-gate-preview{filter:blur(4px);opacity:.5;pointer-events:none}.ai-assistant-panel{background:#fff;border-radius:12px;padding:24px;margin-top:24px;box-shadow:0 2px 8px #0000001a}.ai-assistant-welcome{text-align:center}.ai-assistant-welcome h3{font-size:24px;margin-bottom:12px;color:#333}.ai-assistant-welcome p{color:#666;margin-bottom:8px}.ai-assistant-subtitle{font-size:14px;color:#888;margin-bottom:32px}.ai-feature-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:32px 0}.ai-feature-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:24px;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 4px 12px #667eea4d}.ai-feature-btn:hover{transform:translateY(-4px);box-shadow:0 6px 16px #667eea66}.ai-feature-icon{font-size:36px}.ai-feature-label{font-size:16px;font-weight:600;text-align:center;line-height:1.4}.ai-feature-label small{font-size:12px;font-weight:400;opacity:.9}.ai-rate-limit-info{margin-top:24px;padding:16px;background:#f5f5f5;border-radius:8px;text-align:center}.ai-rate-limit-info p{margin:4px 0;color:#666}.ai-rate-limit-subtitle{font-size:14px;color:#888}.ai-feature-content{padding:16px}.ai-back-btn{background:#f5f5f5;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;margin-bottom:16px;color:#666;font-size:14px}.ai-back-btn:hover{background:#e0e0e0}.ai-optimization-goals{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:24px 0}.ai-optimization-goals button{background:#fff;border:2px solid #667eea;color:#667eea;padding:16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.ai-optimization-goals button:hover{background:#667eea;color:#fff}.ai-diagnose-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;margin:24px 0;box-shadow:0 4px 12px #667eea4d}.ai-diagnose-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.ai-diagnose-btn:disabled{opacity:.6;cursor:not-allowed}.ai-loading{text-align:center;padding:32px;color:#667eea;font-size:16px;font-weight:500}.ai-error{background:#fee;border:1px solid #fcc;color:#c33;padding:16px;border-radius:8px;margin:16px 0}.ai-suggestions,.ai-diagnosis{margin-top:24px}.ai-suggestion-card,.ai-problem-card{background:#f9f9f9;border-radius:12px;padding:20px;margin-bottom:16px;border-left:4px solid #667eea}.ai-suggestion-card h5,.ai-problem-card h5{color:#333;margin-bottom:12px;font-size:18px}.ai-suggestion-en,.ai-problem-en{font-size:14px;color:#888;margin-top:4px}.ai-modifications,.ai-impact,.ai-problem-explanation,.ai-problem-outcome,.ai-problem-fixes{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.ai-modifications ul{list-style:none;padding:0;margin:12px 0 0}.ai-modifications li{padding:8px 0;color:#666}.ai-modifications li small{color:#888;font-size:13px}.ai-impact-en{font-size:14px;color:#888;margin-top:4px}.ai-confidence{margin-top:16px;padding:8px 12px;background:#e8f0fe;border-radius:6px;color:#1967d2;font-size:14px;font-weight:500;display:inline-block}.ai-overall-assessment{background:#e8f5e9;padding:20px;border-radius:12px;margin-bottom:24px}.ai-overall-assessment h4{color:#2e7d32;margin-bottom:12px}.ai-assessment-en{font-size:14px;color:#558b2f;margin-top:8px}.ai-problem-card.severity-low{border-left-color:#ffa726}.ai-problem-card.severity-medium{border-left-color:#ff7043}.ai-problem-card.severity-high{border-left-color:#e53935}.ai-problem-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.ai-problem-severity{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;background:#ffa726;color:#fff}.ai-problem-card.severity-medium .ai-problem-severity{background:#ff7043}.ai-problem-card.severity-high .ai-problem-severity{background:#e53935}.ai-fix{background:#fff;padding:12px;border-radius:8px;margin-top:8px}.ai-fix h6{color:#333;margin-bottom:8px;font-size:15px}.ai-fix-difficulty{font-size:12px;color:#888;padding:4px 8px;background:#f5f5f5;border-radius:4px}.ai-subtitle{font-size:14px;color:#888;margin-bottom:24px}.ai-disclaimer{background:linear-gradient(135deg,#fff3cd,#fffbf0);border-left:4px solid #ffc107;padding:16px 20px;border-radius:8px;margin-top:24px}.ai-disclaimer-title{font-weight:600;color:#856404;margin:0 0 12px;font-size:15px}.ai-disclaimer-text{color:#856404;font-size:13px;line-height:1.6;margin:0 0 8px}.ai-disclaimer-text.ai-disclaimer-en{margin-bottom:0}.ai-auth-notice{background:#fee;border:1px solid #fcc;color:#c33;padding:12px 16px;border-radius:8px;margin:16px 0;text-align:center}.ai-auth-notice p{margin:0;font-size:14px}.smart-recipe-analyzer{max-width:1000px;margin:0 auto;padding:var(--spacing-xl)}.analyzer-header{text-align:center;margin-bottom:var(--spacing-2xl);padding:var(--spacing-2xl) var(--spacing-lg);background:linear-gradient(135deg,#fffffff2,#f8f6f3fa,#fffffff2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid rgba(212,175,55,.1);box-shadow:0 8px 32px #0000000f,0 2px 8px #d4af3714,inset 0 1px #fffc;position:relative;overflow:hidden}.analyzer-header:before{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(212,175,55,.05),transparent);animation:shimmer 3s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.analyzer-header h1{font-family:var(--font-family-heading);font-size:var(--font-size-4xl);background:linear-gradient(135deg,var(--color-coffee-darker) 0%,var(--color-gold) 50%,var(--color-coffee-darker) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-md);font-weight:700;letter-spacing:-.02em;position:relative}.analyzer-subtitle{font-size:var(--font-size-lg);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xl);letter-spacing:.05em;font-weight:300;position:relative}.subscription-status{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap;padding:var(--spacing-lg);background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);margin-top:var(--spacing-lg);border:1px solid rgba(212,175,55,.15);box-shadow:0 4px 16px #0000000a;position:relative}.status-left{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.plan-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;letter-spacing:.08em;text-transform:uppercase;position:relative;overflow:hidden;transition:all .3s ease}.plan-badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.plan-badge:hover:before{left:100%}.plan-badge.free{background:linear-gradient(135deg,#8b45131f,#8b45130f);color:var(--color-coffee-darker);border:1.5px solid rgba(139,69,19,.25);box-shadow:0 2px 8px #8b45131a}.plan-badge.premium{background:linear-gradient(135deg,#d4af37,#f4d03f,#d4af37);background-size:200% 200%;animation:gradientShift 3s ease infinite;color:#fff;border:1.5px solid rgba(255,255,255,.3);box-shadow:0 4px 16px #d4af3766,0 2px 8px #d4af374d,inset 0 1px #ffffff4d;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.2)}.plan-badge.premium:after{content:"✨";margin-left:var(--spacing-xs);animation:sparkle 2s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.usage-info{font-size:var(--font-size-sm);color:var(--color-coffee-dark);letter-spacing:var(--letter-spacing-normal);font-weight:500}.upgrade-btn{white-space:nowrap;background:linear-gradient(135deg,#d4af37,#f4d03f,#d4af37);background-size:200% 200%;animation:gradientShift 3s ease infinite;color:#fff;font-weight:700;padding:var(--spacing-sm) var(--spacing-xl);border:none;border-radius:var(--radius-full);box-shadow:0 4px 16px #d4af3759,0 2px 8px #d4af3740,inset 0 1px #ffffff4d;transition:all .3s ease;text-transform:uppercase;letter-spacing:.08em;font-size:var(--font-size-sm);position:relative;overflow:hidden}.upgrade-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.upgrade-btn:hover:before{width:300px;height:300px}.upgrade-btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px #d4af3773,0 4px 12px #d4af3759,inset 0 1px #fff6}.upgrade-btn:active{transform:translateY(-1px)}.analyzer-input{margin-bottom:var(--spacing-2xl)}.form-group{margin-bottom:var(--spacing-xl)}.form-group label{display:block;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm);letter-spacing:var(--letter-spacing-normal)}.recipe-name-input{width:100%;padding:var(--spacing-md);font-size:var(--font-size-md);border:2px solid var(--color-cream-dark);border-radius:var(--radius-md);background:var(--color-cream);color:var(--color-coffee-darker);transition:all .3s ease}.recipe-name-input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px #d4af371a}.ingredient-row{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);align-items:center}.ingredient-select{flex:2;padding:var(--spacing-md);font-size:var(--font-size-md);border:2px solid var(--color-cream-dark);border-radius:var(--radius-md);background:var(--color-cream);color:var(--color-coffee-darker);transition:all .3s ease}.ingredient-select:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px #d4af371a}.ingredient-weight{flex:1;padding:var(--spacing-md);font-size:var(--font-size-md);border:2px solid var(--color-cream-dark);border-radius:var(--radius-md);background:var(--color-cream);color:var(--color-coffee-darker);transition:all .3s ease}.ingredient-weight:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px #d4af371a}.remove-btn{padding:var(--spacing-sm) var(--spacing-md);background:#dc26261a;color:#dc2626;border:1px solid rgba(220,38,38,.3);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.remove-btn:hover{background:#dc262633;border-color:#dc2626}.action-buttons{margin-top:var(--spacing-xl);display:flex;gap:var(--spacing-md)}.analyzer-results{margin-bottom:var(--spacing-2xl)}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.results-header h2{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);color:var(--color-coffee-darker);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight)}.analysis-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl);background:linear-gradient(135deg,#d4af3714,#8b451308);border-radius:var(--radius-lg);border:1px solid rgba(212,175,55,.2)}.summary-item{text-align:center;padding:var(--spacing-md);background:var(--color-cream);border-radius:var(--radius-md);transition:all .3s ease}.summary-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #d4af3726}.summary-item .label{display:block;font-size:var(--font-size-sm);color:var(--color-coffee-dark);margin-bottom:var(--spacing-xs);letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-medium)}.summary-item .value{display:block;font-size:var(--font-size-2xl);color:var(--color-gold);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight)}.detailed-analysis{margin-bottom:var(--spacing-2xl)}.detailed-analysis h3{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-lg);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight)}.analysis-table{width:100%;border-collapse:collapse;background:var(--color-cream);border-radius:var(--radius-lg);overflow:hidden}.analysis-table thead{background:linear-gradient(135deg,#d4af3726,#d4af370d)}.analysis-table th{padding:var(--spacing-md);text-align:left;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);letter-spacing:var(--letter-spacing-wide)}.analysis-table td{padding:var(--spacing-md);border-top:1px solid var(--color-cream-dark);font-size:var(--font-size-md);color:var(--color-coffee-dark);letter-spacing:var(--letter-spacing-normal)}.analysis-table .total-row{background:linear-gradient(135deg,#d4af371a,#d4af3708);font-weight:var(--font-weight-semibold)}.analysis-table .total-row td{color:var(--color-coffee-darker);border-top:2px solid var(--color-gold)}.upgrade-prompt{margin-top:var(--spacing-2xl);padding:var(--spacing-xl) var(--spacing-lg);background:linear-gradient(135deg,#d4af3714,#f4d03f1f,#d4af3714);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid;border-image:linear-gradient(135deg,#d4af3780,#f4d03fb3,#d4af3780) 1;border-radius:var(--radius-xl);text-align:center;position:relative;overflow:hidden;box-shadow:0 8px 32px #d4af3726,0 4px 16px #d4af371a,inset 0 1px #ffffff80}.upgrade-prompt:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(212,175,55,.1) 0%,transparent 70%);animation:rotate 20s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.upgrade-prompt p{font-size:var(--font-size-lg);background:linear-gradient(135deg,var(--color-coffee-darker) 0%,var(--color-gold) 50%,var(--color-coffee-darker) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-md);font-weight:700;letter-spacing:-.01em;position:relative;z-index:1}.upgrade-prompt ul{list-style:none;padding:0;margin:var(--spacing-md) 0;text-align:left;max-width:600px;margin-left:auto;margin-right:auto;position:relative;z-index:1}.upgrade-prompt li{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-coffee-darker);letter-spacing:var(--letter-spacing-normal);background:#fff9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs);border-left:3px solid var(--color-gold);transition:all .3s ease;font-weight:500}.upgrade-prompt li:hover{transform:translate(8px);background:#fffc;box-shadow:0 4px 12px #d4af3733}.upgrade-prompt button{margin-top:var(--spacing-md);position:relative;z-index:1}@media (max-width: 768px){.smart-recipe-analyzer{padding:var(--spacing-md)}.analyzer-header h1{font-size:var(--font-size-3xl)}.ingredient-row{flex-direction:column}.ingredient-select,.ingredient-weight{width:100%}.analysis-summary{grid-template-columns:repeat(2,1fr)}.results-header{flex-direction:column;align-items:flex-start}.analysis-table{font-size:var(--font-size-sm)}.analysis-table th,.analysis-table td{padding:var(--spacing-sm)}}.header-actions{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.header-actions button{white-space:nowrap}.login-prompt{text-align:center;padding:var(--spacing-xl);background:linear-gradient(135deg,#ffffffe6,#f8f6f3f2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-xl);margin-top:var(--spacing-md);border:1px solid rgba(212,175,55,.2);box-shadow:0 8px 24px #0000000f,0 2px 8px #d4af371a;position:relative;overflow:hidden}.login-prompt:before{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(212,175,55,.08),transparent);animation:shimmer 3s infinite}.login-prompt p{font-size:var(--font-size-lg);color:var(--color-coffee-darker);font-weight:500;letter-spacing:.02em;position:relative;z-index:1;margin:0}.saved-recipes-section,.comparison-section,.comparison-results{margin:var(--spacing-xl) 0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.recipe-card{padding:var(--spacing-lg);border:1px solid var(--color-beige);border-radius:var(--radius-lg);background-color:var(--color-cream);transition:all var(--transition-normal)}.recipe-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.recipe-card h3{font-size:var(--font-size-lg);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm)}.recipe-meta{color:var(--color-coffee-dark);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.recipe-date{color:var(--color-gray-dark);font-size:var(--font-size-xs);margin-bottom:var(--spacing-md)}.recipe-actions{display:flex;gap:var(--spacing-sm)}.empty-message{text-align:center;color:var(--color-gray-dark);padding:var(--spacing-xl);font-style:italic}.comparison-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.recipe-selector label{display:block;font-weight:var(--font-weight-semibold);color:var(--color-coffee-darker);margin-bottom:var(--spacing-sm)}.recipe-selector select{width:100%;padding:var(--spacing-md);border:1px solid var(--color-beige);border-radius:var(--radius-md);font-size:var(--font-size-base);background-color:var(--color-white);color:var(--color-coffee-darker)}.comparison-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.comparison-column h3{font-size:var(--font-size-xl);color:var(--color-coffee-darker);margin-bottom:var(--spacing-lg);text-align:center}.comparison-diff{display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-lg);background-color:var(--color-cream);border-radius:var(--radius-lg);min-width:200px}.comparison-diff h3{font-size:var(--font-size-lg);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md);text-align:center}.diff-item{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-beige)}.diff-item:last-child{border-bottom:none}.diff-item span:first-child{color:var(--color-coffee-dark);font-weight:var(--font-weight-medium)}.diff-item .positive{color:#4caf50;font-weight:var(--font-weight-semibold)}.diff-item .negative{color:#f44336;font-weight:var(--font-weight-semibold)}.comparison-recommendations{background-color:var(--color-cream);padding:var(--spacing-lg);border-radius:var(--radius-lg)}.comparison-recommendations h3{font-size:var(--font-size-lg);color:var(--color-coffee-darker);margin-bottom:var(--spacing-md)}.comparison-recommendations ul{list-style:none;padding:0}.comparison-recommendations li{padding:var(--spacing-sm) 0;color:var(--color-coffee-dark);line-height:1.6}.comparison-recommendations li:before{content:"💡 ";margin-right:var(--spacing-sm)}@media (max-width: 768px){.header-actions{flex-direction:column;width:100%}.recipes-grid,.comparison-selector,.comparison-grid{grid-template-columns:1fr}.comparison-diff{order:3}}.ai-assistant-section{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border-color, #e0e0e0)}.ai-assistant-section h3{color:var(--primary-color, #8B4513);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.ai-assistant-section h3:before{content:"🤖";font-size:1.5rem}.recipe-save-button-container{margin:2rem 0;padding:1.5rem;background-color:var(--cream-light, #FFF8DC);border-radius:12px;border:2px solid var(--primary-brown, #8B4513)}.recipe-save-button{width:100%;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;color:#fff;background-color:var(--primary-brown, #8B4513);border:none;border-radius:8px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.recipe-save-button:hover:not(:disabled){background-color:var(--primary-brown-dark, #6B3410);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.recipe-save-button:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.recipe-save-button.saving{background-color:#f39c12;cursor:wait}.recipe-save-button.success{background-color:#27ae60}.recipe-save-button.upgrade-required{background-color:#95a5a6}.save-hint{margin-top:.75rem;text-align:center;color:var(--text-secondary, #666);font-size:.9rem}.upgrade-prompt{margin-top:1rem;padding:1rem;background-color:#fff;border-radius:8px;text-align:center}.upgrade-message{font-size:1rem;font-weight:600;color:var(--primary-brown, #8B4513);margin-bottom:.5rem}.upgrade-benefits{font-size:.9rem;color:var(--text-secondary, #666);line-height:1.6;margin-bottom:1rem}.upgrade-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#f39c12,#e67e22);border:none;border-radius:6px;cursor:pointer;transition:all .3s}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f39c1266}.storage-full-message{margin-top:1rem;padding:1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;text-align:center}.warning-text{font-size:1rem;font-weight:600;color:#856404;margin-bottom:.5rem}.hint-text{font-size:.9rem;color:#856404}.upgrade-link{background:none;border:none;color:var(--primary-brown, #8B4513);text-decoration:underline;cursor:pointer;font-weight:600;padding:0;margin-left:.25rem}.upgrade-link:hover{color:var(--primary-brown-dark, #6B3410)}.storage-info{margin-top:.75rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.count-display{font-size:.9rem;color:var(--text-secondary, #666);font-weight:500}.tier-badge{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;color:#fff}.tier-badge.basic{background:linear-gradient(135deg,#3498db,#2980b9)}.tier-badge.business{background:linear-gradient(135deg,#9b59b6,#8e44ad)}@media (max-width: 768px){.recipe-save-button-container{padding:1rem}.recipe-save-button{font-size:1rem;padding:.875rem 1.25rem}.upgrade-benefits{font-size:.85rem}.storage-info{flex-direction:column;align-items:flex-start}}.ai-nutrition-panel{margin-top:2rem;padding:2rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:2px solid #2196F3;box-shadow:0 4px 12px #2196f326}.ai-panel-header{text-align:center;margin-bottom:1.5rem}.ai-panel-header h3{font-size:1.5rem;color:#2196f3;margin:0 0 .5rem;font-weight:600}.ai-subtitle{font-size:.9rem;color:var(--text-secondary, #666);margin:0;font-style:italic}.ai-login-prompt,.ai-loading{text-align:center;padding:2rem;color:var(--text-secondary, #666)}.ai-upgrade-prompt{text-align:center;padding:2rem;background-color:#fff;border-radius:8px}.upgrade-message{font-size:1.1rem;color:var(--text-primary, #333);font-weight:600;margin:0 0 1rem}.upgrade-benefits{font-size:1rem;line-height:1.8;color:var(--text-secondary, #666);margin:0 0 1.5rem}.upgrade-button{padding:.75rem 2rem;background-color:#2196f3;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.upgrade-button:hover{background-color:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #2196f34d}.ai-error,.ai-error-message{padding:1rem;background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;text-align:center;margin-bottom:1rem}.ai-analyze-button{width:100%;padding:1.25rem;font-size:1.2rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#2196f3,#1976d2);border:none;border-radius:8px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #2196f34d}.ai-analyze-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #2196f366}.ai-analyze-button:disabled{background:#ccc;cursor:not-allowed;box-shadow:none}.ai-analyzing{text-align:center;padding:2rem}.ai-spinner{width:50px;height:50px;margin:0 auto 1rem;border:4px solid #f3f3f3;border-top:4px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite}.ai-analyzing p{margin:.5rem 0;color:var(--text-primary, #333)}.ai-wait-time{font-size:.9rem;color:var(--text-secondary, #666);font-style:italic}.ai-analysis-results{display:flex;flex-direction:column;gap:1rem}.ai-section{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:box-shadow .3s}.ai-section:hover{box-shadow:0 4px 12px #00000026}.ai-section-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#f8f9fa;cursor:pointer;transition:background-color .3s}.ai-section-header:hover{background-color:#e9ecef}.ai-section-header h4{margin:0;font-size:1.1rem;color:var(--text-primary, #333);font-weight:600}.toggle-icon{color:#2196f3;font-size:.9rem;transition:transform .3s}.ai-section-content{padding:1.5rem;animation:slideDown .3s ease-out}.analysis-text{line-height:1.8;color:var(--text-primary, #333);margin:0;white-space:pre-line}.recommendations-list{margin:0;padding-left:1.5rem;line-height:1.8;color:var(--text-primary, #333)}.recommendations-list li{margin-bottom:.75rem}.recommendations-list li:last-child{margin-bottom:0}.comparison-intro{font-size:.95rem;color:var(--text-secondary, #666);margin:0 0 1.5rem;text-align:center}.comparison-grid{display:grid;gap:1rem;margin-bottom:1.5rem}.comparison-item{display:grid;grid-template-columns:100px 1fr 60px;align-items:center;gap:1rem}.comparison-item .label{font-weight:500;color:var(--text-primary, #333)}.progress-bar{height:24px;background-color:#e9ecef;border-radius:12px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#66bb6a);transition:width .5s ease-out;border-radius:12px}.comparison-item .percentage{font-weight:600;color:#4caf50;text-align:right}.comparison-notes{margin:0;padding-left:1.5rem;line-height:1.8;color:var(--text-secondary, #666);font-size:.95rem}.comparison-notes li{margin-bottom:.5rem}.benefits-list{list-style:none;margin:0;padding:0}.benefit-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;padding:.75rem;background-color:#e8f5e9;border-radius:6px;line-height:1.6;color:var(--text-primary, #333)}.benefit-item:last-child{margin-bottom:0}.benefit-icon{color:#4caf50;font-weight:700;flex-shrink:0}.warning-section{border-left:4px solid #FF9800}.warnings-list{list-style:none;margin:0;padding:0}.warning-item{padding:.75rem;margin-bottom:.75rem;background-color:#fff3e0;border-radius:6px;line-height:1.6;color:var(--text-primary, #333)}.warning-item:last-child{margin-bottom:0}.isofh-disclaimer{margin-top:1.5rem;padding:1.5rem;background-color:#e8f5e9;border:2px solid #4CAF50;border-radius:8px;text-align:center}.disclaimer-icon{font-size:2rem;margin:0 0 .5rem}.disclaimer-text{font-size:.9rem;line-height:1.6;color:var(--text-primary, #333);margin:0 0 1rem}.isofh-link{display:inline-block;color:#4caf50;text-decoration:none;font-weight:600;border-bottom:2px solid transparent;transition:border-color .3s}.isofh-link:hover{border-bottom-color:#4caf50}.ai-reanalyze-button{width:100%;padding:1rem;margin-top:1rem;font-size:1rem;font-weight:600;color:#2196f3;background-color:#fff;border:2px solid #2196F3;border-radius:8px;cursor:pointer;transition:all .3s}.ai-reanalyze-button:hover:not(:disabled){background-color:#2196f3;color:#fff;transform:translateY(-2px)}.ai-reanalyze-button:disabled{border-color:#ccc;color:#ccc;cursor:not-allowed}@media (max-width: 768px){.ai-nutrition-panel{padding:1.5rem}.ai-panel-header h3{font-size:1.3rem}.comparison-item{grid-template-columns:80px 1fr 50px;gap:.5rem}.comparison-item .label,.comparison-item .percentage{font-size:.9rem}}.language-switcher{display:flex;align-items:center;gap:.5rem}.language-switcher-label{font-size:1.2rem;margin-right:.25rem}.language-buttons{display:flex;gap:.5rem;background:var(--color-background-secondary, #f5f5f5);border-radius:.5rem;padding:.25rem}.language-button{padding:.5rem 1rem;border:none;background:transparent;color:var(--color-text-secondary, #666);font-size:.9rem;font-weight:500;border-radius:.375rem;cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px}.language-button:hover:not(:disabled){background:var(--color-background-hover, #e0e0e0);color:var(--color-text-primary, #333)}.language-button:focus{outline:2px solid var(--color-primary, #4CAF50);outline-offset:2px}.language-button.active{background:var(--color-primary, #4CAF50);color:#fff;font-weight:600}.language-button:disabled{cursor:not-allowed;opacity:.6}.language-switcher.compact{display:inline-block}.language-select{padding:.5rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:.375rem;background:#fff;color:var(--color-text-primary, #333);font-size:.9rem;cursor:pointer;min-width:120px;min-height:44px}.language-select:hover:not(:disabled){border-color:var(--color-primary, #4CAF50)}.language-select:focus{outline:2px solid var(--color-primary, #4CAF50);outline-offset:2px;border-color:var(--color-primary, #4CAF50)}.language-select:disabled{cursor:not-allowed;opacity:.6;background:var(--color-background-disabled, #f5f5f5)}@media (max-width: 768px){.language-switcher{gap:.25rem}.language-buttons{gap:.25rem;padding:.125rem}.language-button{padding:.375rem .75rem;font-size:.85rem}.language-select{font-size:.85rem;min-width:100px}}@media (prefers-contrast: high){.language-button{border:2px solid currentColor}.language-button.active{border-color:#fff}.language-select{border-width:2px}}.nutrition-calculator{max-width:1200px;margin:0 auto;padding:2rem;font-family:Noto Sans TC,sans-serif}.calculator-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;gap:2rem}.calculator-header .header-title{flex:1;text-align:center}.calculator-header h1{font-size:2.5rem;color:var(--primary-brown, #8B4513);margin-bottom:.5rem}.subtitle{font-size:1.1rem;color:var(--text-secondary, #666)}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:var(--text-secondary, #666)}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#c33;text-align:center}.search-section{margin-bottom:2rem;scroll-margin-top:2rem}.search-section h2{font-size:1.5rem;color:var(--primary-brown, #8B4513);margin:0}.scroll-to-ingredients-button{padding:.5rem 1rem;background-color:var(--primary-brown, #8B4513);border:none;border-radius:6px;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.scroll-to-ingredients-button:hover{background-color:var(--primary-brown-dark, #6B3410);transform:translateY(-2px)}.search-box{position:relative}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;font-size:1rem;border:2px solid var(--border-color, #ddd);border-radius:8px;transition:border-color .3s}.search-input:focus{outline:none;border-color:var(--primary-brown, #8B4513)}.clear-search-button{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary, #666);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.clear-search-button:hover{color:var(--primary-brown, #8B4513)}.search-results{margin-top:.5rem;background:#fff;border:2px solid var(--primary-brown, #8B4513);border-radius:8px;max-height:400px;overflow-y:auto;box-shadow:0 4px 12px #00000026}.search-results-header{padding:.75rem 1rem;background-color:var(--primary-brown, #8B4513);color:#fff;font-weight:600;font-size:.9rem;border-radius:6px 6px 0 0;position:sticky;top:0;z-index:1}.search-result-item{padding:1rem;cursor:pointer;display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center;transition:background-color .2s;border-bottom:1px solid var(--border-color, #eee)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:var(--cream-light, #FFF8DC)}.search-result-item .add-icon{color:var(--primary-brown, #8B4513);font-size:1.5rem;font-weight:700;opacity:.6;transition:opacity .2s}.search-result-item:hover .add-icon{opacity:1}.no-results{margin-top:.5rem;padding:2rem;text-align:center;color:var(--text-secondary, #666);background-color:var(--cream-light, #FFF8DC);border-radius:8px;font-style:italic}.ingredient-name{font-weight:500;color:var(--text-primary, #333)}.ingredient-category{font-size:.9rem;color:var(--text-secondary, #666);background-color:var(--cream-light, #FFF8DC);padding:.25rem .75rem;border-radius:12px}.selected-ingredients{margin-bottom:2rem;scroll-margin-top:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.selected-ingredients h2{font-size:1.5rem;color:var(--primary-brown, #8B4513);margin:0}.scroll-to-search-button{padding:.5rem 1rem;background-color:var(--cream-light, #FFF8DC);border:2px solid var(--primary-brown, #8B4513);border-radius:6px;color:var(--primary-brown, #8B4513);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.scroll-to-search-button:hover{background-color:var(--primary-brown, #8B4513);color:#fff;transform:translateY(-2px)}.empty-message{text-align:center;padding:2rem;color:var(--text-secondary, #666);font-style:italic}.ingredients-list{display:flex;flex-direction:column;gap:1rem}.ingredient-item{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:1rem;align-items:center;padding:1rem;background-color:var(--cream-light, #FFF8DC);border-radius:8px;transition:transform .2s}.ingredient-item:hover{transform:translate(4px)}.ingredient-item .ingredient-name{font-weight:500}.quantity-input,.unit-select{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:1rem}.quantity-input:focus,.unit-select:focus{outline:none;border-color:var(--primary-brown, #8B4513)}.remove-button{background-color:#f44336;color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1.2rem;transition:background-color .2s}.remove-button:hover{background-color:#d32f2f}.servings-section{margin-bottom:2rem;padding:1rem;background-color:var(--cream-light, #FFF8DC);border-radius:8px}.servings-section label{display:flex;align-items:center;gap:1rem;font-size:1.1rem;font-weight:500;color:var(--text-primary, #333)}.servings-input{padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:1rem;width:100px}.calculate-button{width:100%;padding:1.25rem;font-size:1.2rem;font-weight:600;color:#fff;background-color:var(--primary-brown, #8B4513);border:none;border-radius:8px;cursor:pointer;transition:background-color .3s,transform .2s;margin-bottom:2rem}.calculate-button:hover:not(:disabled){background-color:var(--primary-brown-dark, #6B3410);transform:translateY(-2px)}.calculate-button:disabled{background-color:#ccc;cursor:not-allowed}.results-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem}.result-card{background-color:#fff;border:2px solid var(--primary-brown, #8B4513);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.result-card h3{font-size:1.3rem;color:var(--primary-brown, #8B4513);margin-bottom:1rem;text-align:center}.nutrition-grid{display:grid;gap:1rem}.nutrition-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:var(--cream-light, #FFF8DC);border-radius:6px}.nutrition-item .label{font-weight:500;color:var(--text-primary, #333)}.nutrition-item .value{font-weight:600;color:var(--primary-brown, #8B4513);font-size:1.1rem}.calculator-footer{margin-top:3rem;padding:2rem 0;border-top:2px solid var(--primary-brown, #8B4513)}.authority-section{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2rem}.authority-badge{display:flex;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,#fff8dc,beige);border-radius:12px;border:2px solid var(--primary-brown, #8B4513);box-shadow:0 4px 12px #8b45131a}.badge-icon{font-size:3rem;line-height:1;flex-shrink:0}.badge-content h4{font-size:1.3rem;color:var(--primary-brown, #8B4513);margin:0 0 .75rem;font-weight:600}.authority-text{font-size:1rem;line-height:1.7;color:var(--text-primary, #333);margin:0 0 .75rem}.authority-text strong{color:var(--primary-brown, #8B4513);font-weight:600}.isofh-link{color:#2196f3;text-decoration:none;font-weight:600;border-bottom:2px solid transparent;transition:border-color .3s}.isofh-link:hover{border-bottom-color:#2196f3}.authority-subtext{font-size:.95rem;line-height:1.6;color:var(--text-secondary, #666);font-style:italic;margin:0}.founder-credential{display:flex;gap:1.5rem;padding:1.5rem;background-color:#fff;border-radius:12px;border:2px solid #4CAF50;box-shadow:0 4px 12px #4caf501a}.credential-icon{font-size:2.5rem;line-height:1;flex-shrink:0}.credential-title{font-size:.9rem;color:#4caf50;font-weight:600;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px}.credential-text{font-size:1rem;color:var(--text-primary, #333);margin:0;line-height:1.8}.founder-link{color:var(--primary-brown, #8B4513);text-decoration:none;font-weight:600;font-size:1.1rem;border-bottom:2px solid transparent;transition:border-color .3s}.founder-link:hover{border-bottom-color:var(--primary-brown, #8B4513)}.credential-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.credential-badges .badge{display:inline-block;padding:.25rem .75rem;background-color:#4caf50;color:#fff;font-size:.85rem;border-radius:12px;font-weight:500}.medical-disclaimer{text-align:center;padding:1rem;background-color:#fff3cd;border:1px solid #FFE69C;border-radius:8px;color:#856404;font-size:.9rem;margin:0}.disclaimer{color:var(--text-secondary, #666);font-size:.9rem}@media (max-width: 768px){.nutrition-calculator{padding:1rem}.calculator-header h1{font-size:2rem}.ingredient-item{grid-template-columns:1fr;gap:.5rem}.results-section{grid-template-columns:1fr}.authority-badge{flex-direction:column;gap:1rem;padding:1.5rem}.badge-icon{font-size:2.5rem}.badge-content h4{font-size:1.1rem}.authority-text{font-size:.95rem}.founder-credential{flex-direction:column;gap:1rem;padding:1.25rem}.credential-icon{font-size:2rem}.credential-badges{flex-direction:column}.credential-badges .badge{display:block;text-align:center}}.recipe-name-input{grid-column:1 / -1;margin:2rem 0 1rem;padding:1rem;background-color:var(--cream-light, #FFF8DC);border-radius:8px}.recipe-name-input label{display:flex;flex-direction:column;gap:.5rem;font-weight:500;color:var(--text-primary, #333)}.recipe-name-field{padding:.75rem;font-size:1rem;border:2px solid var(--border-color, #ddd);border-radius:6px;transition:border-color .3s}.recipe-name-field:focus{outline:none;border-color:var(--primary-brown, #8B4513)}.recipe-save-button.locked{background-color:#9e9e9e;cursor:not-allowed;opacity:.7}.upgrade-prompt-nutrition{margin-top:1rem;padding:1.5rem;background:linear-gradient(135deg,#fff8dc,#ffe4b5);border:2px solid var(--primary-brown, #8B4513);border-radius:12px;text-align:center}.upgrade-prompt-nutrition .upgrade-message{font-size:1rem;color:var(--text-primary, #333);margin:0 0 1rem;line-height:1.6}.upgrade-button-nutrition{padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#8b4513,sienna);border:none;border-radius:8px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #8b45134d}.upgrade-button-nutrition:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b451366}.upgrade-button-nutrition:active{transform:translateY(0)}.tdee-calculator{max-width:1200px;margin:0 auto;padding:2rem 1rem}.tdee-calculator-header{text-align:center;margin-bottom:3rem}.tdee-calculator-header h1{font-size:2.5rem;color:var(--color-primary);margin-bottom:.5rem}.tdee-calculator-subtitle{font-size:1.1rem;color:var(--color-text-secondary)}.tdee-calculator-content{display:flex;flex-direction:column;gap:2rem}.tdee-form{display:flex;flex-direction:column;gap:1.5rem}.tdee-form-group{display:flex;flex-direction:column;gap:.5rem}.tdee-form-group label{font-weight:600;color:var(--color-text);font-size:1rem}.tdee-radio-group{display:flex;gap:2rem}.tdee-radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem}.tdee-radio-label input[type=radio]{width:1.2rem;height:1.2rem;cursor:pointer}.tdee-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.tdee-input-with-unit{display:flex;align-items:center;gap:.5rem;border:2px solid #d0d0d0;border-radius:8px;padding:.75rem 1rem;background:#fff;transition:all .3s;box-shadow:0 1px 3px #0000001a}.tdee-input-with-unit:hover{border-color:#a0a0a0}.tdee-input-with-unit:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #ff6b351a}.tdee-input-with-unit input{flex:1;border:none;outline:none;font-size:1rem;padding:0;background:transparent}.tdee-unit{color:var(--color-text-secondary);font-weight:500;white-space:nowrap}.tdee-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid #d0d0d0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .3s;box-shadow:0 1px 3px #0000001a;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.tdee-select:hover{border-color:#a0a0a0}.tdee-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ff6b351a}.tdee-activity-description{font-size:.9rem;color:var(--color-text-secondary);margin-top:.25rem;font-style:italic}.tdee-errors{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem}.tdee-error{color:#c00;margin:.25rem 0;font-size:.9rem}.tdee-calculate-button{background:linear-gradient(135deg,#ff6b35,#d4af37);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:700;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;margin-top:1rem;text-align:center;letter-spacing:.5px;box-shadow:0 2px 8px #ff6b354d}.tdee-calculate-button:hover{transform:translateY(-2px);box-shadow:0 4px 16px #ff6b3566;background:linear-gradient(135deg,#ff7a47,#ddb945)}.tdee-calculate-button:active{transform:translateY(0);box-shadow:0 2px 8px #ff6b354d}.tdee-tabs{display:flex;gap:1rem;border-bottom:2px solid var(--color-border);margin-bottom:2rem}.tdee-tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .3s}.tdee-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tdee-tab:hover{color:var(--color-primary)}.tdee-tab-content{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tdee-result-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.tdee-result-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem;border-radius:12px;text-align:center}.tdee-result-card-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff}.tdee-result-card h3{font-size:1.2rem;margin-bottom:1rem;opacity:.9}.tdee-result-card-primary h3{color:#fff}.tdee-result-value{font-size:2.5rem;font-weight:700;margin:0}.tdee-result-value span{font-size:1.2rem;font-weight:400;opacity:.8}.tdee-calorie-goals{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.tdee-calorie-goal{background:#fff;border:2px solid var(--color-border);padding:1.5rem;border-radius:12px;text-align:center;transition:transform .2s,box-shadow .2s}.tdee-calorie-goal:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.tdee-calorie-goal-maintain{border-color:var(--color-primary);background:linear-gradient(135deg,#fff,#f0f8ff)}.tdee-calorie-goal h4{font-size:1rem;color:var(--color-text-secondary);margin-bottom:.5rem}.tdee-calorie-goal p{font-size:1.8rem;font-weight:700;color:var(--color-primary);margin:0}.tdee-servings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem}.tdee-serving-item{background:#fff;border:2px solid var(--color-border);padding:1.5rem;border-radius:12px;text-align:center;transition:transform .2s,box-shadow .2s}.tdee-serving-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.tdee-serving-item span{font-size:2.5rem;display:block;margin-bottom:.5rem}.tdee-serving-item h4{font-size:.95rem;color:var(--color-text);margin-bottom:.5rem}.tdee-serving-item p{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin:0}@media (max-width: 768px){.tdee-calculator-header h1{font-size:2rem}.tdee-form-row{grid-template-columns:1fr}.tdee-tabs{flex-direction:column;gap:0}.tdee-tab{border-bottom:1px solid var(--color-border);border-left:3px solid transparent}.tdee-tab.active{border-bottom-color:var(--color-border);border-left-color:var(--color-primary)}.tdee-result-section,.tdee-calorie-goals{grid-template-columns:1fr}.tdee-servings-grid{grid-template-columns:repeat(2,1fr)}}.dietary-guide-page{max-width:1200px;margin:0 auto;padding:2rem 1rem}.dietary-guide-header{text-align:center;margin-bottom:3rem}.dietary-guide-header h1{font-size:2.5rem;color:var(--color-primary);margin-bottom:.5rem}.dietary-guide-subtitle{font-size:1rem;color:var(--color-text-secondary);font-style:italic}.dietary-guide-content{display:flex;flex-direction:column;gap:2rem}.dietary-guide-intro{font-size:1.1rem;line-height:1.8;color:var(--color-text)}.dietary-guide-note{font-size:1rem;line-height:1.6;color:var(--color-text-secondary);margin-bottom:1.5rem}.food-category{display:flex;flex-direction:column;gap:1.5rem}.food-category-header{display:flex;align-items:center;gap:1rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.food-category-icon{font-size:3rem}.food-category-name{font-size:1.8rem;color:var(--color-primary);margin:0}.food-category-description{font-size:1.05rem;line-height:1.7;color:var(--color-text)}.food-category-details{display:flex;flex-direction:column;gap:1.5rem}.food-category-section h4{font-size:1.1rem;color:var(--color-text);margin-bottom:.75rem;font-weight:600}.food-examples{display:flex;flex-wrap:wrap;gap:.5rem}.food-example-tag{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:.5rem 1rem;border-radius:20px;font-size:.95rem;color:var(--color-text)}.serving-description{font-size:.95rem;color:var(--color-text-secondary);margin-bottom:1rem;font-style:italic}.serving-examples{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.serving-example{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff;border:1px solid var(--color-border);border-radius:8px}.serving-food{font-weight:500;color:var(--color-text)}.serving-amount{color:var(--color-primary);font-weight:600}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.nutrition-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:8px}.nutrition-label{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:.25rem}.nutrition-value{font-size:1.3rem;font-weight:700;color:var(--color-primary)}.serving-table{overflow-x:auto;margin-top:1.5rem}.serving-table table{width:100%;border-collapse:collapse;background:#fff}.serving-table th,.serving-table td{padding:1rem;text-align:center;border:1px solid var(--color-border)}.serving-table th{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;font-weight:600;font-size:.95rem;vertical-align:middle}.serving-table td{font-size:1rem;color:var(--color-text)}.serving-table tbody tr:nth-child(2n){background:#f9f9f9}.serving-table tbody tr:hover{background:#f0f8ff}.serving-table td:first-child{font-weight:700;color:var(--color-primary)}.nutritionist-section{display:flex;flex-direction:column;gap:1rem}.nutritionist-section p{font-size:1rem;line-height:1.7;color:var(--color-text)}.reference-note{font-size:.9rem;color:var(--color-text-secondary);font-style:italic;padding:1rem;background:#f5f7fa;border-left:4px solid var(--color-primary);border-radius:4px}@media (max-width: 768px){.dietary-guide-header h1{font-size:2rem}.food-category-icon{font-size:2.5rem}.food-category-name{font-size:1.5rem}.serving-examples{grid-template-columns:1fr}.nutrition-grid{grid-template-columns:repeat(2,1fr)}.serving-table{font-size:.85rem}.serving-table th,.serving-table td{padding:.5rem}}@media (max-width: 480px){.dietary-guide-page{padding:1rem .5rem}.food-category-header{flex-direction:column;align-items:flex-start}.nutrition-grid{grid-template-columns:1fr}}@font-face{font-family:Unisono;src:url(/fonts/Unisono%20Lowercase.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}.brand-story{max-width:900px;margin:0 auto;padding:2rem 1rem}.brand-story-hero{text-align:center;margin-bottom:3rem;padding:3rem 1rem;background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 100%);border-radius:12px;border:2px solid var(--color-gold);box-shadow:0 8px 32px #d4af3726}.brand-story-title{font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:1rem}.brand-story-subtitle{font-size:1.1rem;color:var(--color-text-secondary);font-style:italic}.brand-story-content{display:flex;flex-direction:column;gap:2rem}.brand-story-content h2{font-size:1.8rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem;border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}.brand-story-content p{font-size:1.1rem;line-height:1.8;color:var(--color-text-secondary)}.brand-story-values{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.brand-story-values li{padding:1.5rem;background:var(--color-background-secondary);border-radius:8px;transition:transform .3s ease,box-shadow .3s ease}.brand-story-values li:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.brand-story-values strong{display:block;font-size:1.2rem;color:var(--color-primary);margin-bottom:.5rem}.brand-story-values p{font-size:.95rem;margin:0}@media (max-width: 768px){.brand-story-title{font-size:2rem}.brand-story-subtitle{font-size:1rem}.brand-story-content h2{font-size:1.5rem}.brand-story-values{grid-template-columns:1fr}}.brand-story-4c-section h2{font-family:Unisono,Poppins,sans-serif}@font-face{font-family:Unisono;src:url(/fonts/Unisono%20Lowercase.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}.atelier-page{max-width:1000px;margin:0 auto;padding:2rem 1rem}.atelier-hero{text-align:center;margin-bottom:3rem;padding:3rem 1rem 2.5rem;background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 100%);border-radius:16px;color:var(--color-coffee-darker);border:2px solid var(--color-gold);box-shadow:0 8px 32px #d4af3726}.atelier-hero-logo{display:flex;justify-content:center;align-items:center;margin-bottom:1rem}.atelier-hero-logo-image{width:180px;height:180px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(139,69,19,.15));display:block;margin:0 auto}.atelier-hero-title{margin-bottom:.75rem}.atelier-hero-brand{display:block;font-size:3rem;font-weight:700;font-style:italic;margin-bottom:.5rem;font-family:Unisono,Qurova,Poppins,sans-serif;color:var(--color-coffee-darker);letter-spacing:.02em}.atelier-hero-subtitle{display:block;font-size:1.5rem;font-weight:400;color:var(--color-gold);letter-spacing:.05em}.atelier-hero-description{font-size:1.1rem;color:var(--color-coffee-dark);font-style:italic;font-weight:300}.atelier-content{display:flex;flex-direction:column;gap:2rem}.atelier-content h2{font-size:1.8rem;font-weight:600;color:var(--color-coffee-darker);margin-bottom:1rem;border-bottom:2px solid var(--color-gold);padding-bottom:.5rem}.atelier-content p{font-size:1.1rem;line-height:1.8;color:var(--color-text-secondary)}.atelier-research-areas{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:1.5rem}.atelier-research-item{text-align:center;padding:2rem 1rem;background:var(--color-background-secondary);border-radius:12px;transition:transform .3s ease,box-shadow .3s ease}.atelier-research-item:hover{transform:translateY(-8px);box-shadow:0 8px 20px #d4af3733}.atelier-research-item h3{font-size:1.3rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.75rem}.atelier-research-item p{font-size:.95rem;line-height:1.6;margin:0}.atelier-4c-intro{font-size:1.1rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:2rem;text-align:center;font-style:italic}.atelier-4c-item{background:linear-gradient(135deg,#d4af370d,#8b451308);border:2px solid transparent;transition:all .3s ease}.atelier-4c-item:hover{border-color:var(--color-gold);background:linear-gradient(135deg,#d4af371a,#8b45130d);box-shadow:0 12px 30px #d4af3740}.atelier-4c-item h3{color:var(--color-gold);font-size:1.3rem;font-weight:700;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase;background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-coffee-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.atelier-4c-item h3:before,.atelier-4c-item h3:after{display:none!important}.atelier-features{list-style:none;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:1.5rem}.atelier-features li{padding:1.5rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:8px;transition:transform .3s ease}.atelier-features li:hover{transform:translateY(-4px)}.atelier-features strong{display:block;font-size:1.2rem;color:var(--color-gold);margin-bottom:.5rem}.atelier-features p{font-size:.95rem;margin:0}@media (max-width: 768px){.atelier-hero{padding:2.5rem 1rem 2rem}.atelier-hero-logo{margin-bottom:.75rem}.atelier-hero-logo-image{width:140px;height:140px}.atelier-hero-brand{font-size:2rem}.atelier-hero-subtitle{font-size:1.2rem}.atelier-hero-description{font-size:1rem}.atelier-content h2{font-size:1.5rem}.atelier-research-areas{grid-template-columns:1fr}.atelier-4c-intro{font-size:1rem}.atelier-features{grid-template-columns:1fr}}.research-system{margin-top:1.5rem}.research-subtitle{font-size:1.3rem;color:var(--primary-color);margin-bottom:1rem;font-weight:600}.research-pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin:2rem 0}.research-pillar{background:linear-gradient(135deg,#f8f9fa,#fff);padding:1.5rem;border-radius:12px;border:1px solid #e9ecef;text-align:center;transition:all .3s ease}.research-pillar:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001a;border-color:var(--primary-color)}.pillar-icon{font-size:2.5rem;margin-bottom:1rem}.research-pillar h4{color:var(--primary-color);font-size:1.1rem;margin-bottom:.5rem;font-weight:600}.research-pillar p{color:#6c757d;font-size:.95rem;line-height:1.6}.founder-profile{background:linear-gradient(135deg,#fff5f5,#fff);padding:2rem;border-radius:12px;border:2px solid var(--primary-color);margin-top:2rem}.founder-title{color:var(--primary-color);font-size:1.2rem;margin-bottom:.5rem;font-weight:600}.founder-name{font-size:1.3rem;font-weight:700;margin-bottom:1rem}.founder-link{color:var(--primary-color);text-decoration:none;transition:all .3s ease}.founder-link:hover{color:var(--secondary-color);text-decoration:underline}.founder-credentials{list-style:none;padding:0;margin:1rem 0 0}.founder-credentials li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#495057;font-size:.95rem}.founder-credentials li:before{content:"✓";position:absolute;left:0;color:var(--primary-color);font-weight:700}.atelier-cta-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.atelier-cta-button{padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;font-family:var(--font-family-base);letter-spacing:.5px}.atelier-cta-button.primary{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-coffee-dark) 100%);color:var(--color-white);box-shadow:0 4px 12px #8b451333}.atelier-cta-button.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b45134d}.atelier-cta-button.secondary{background:var(--color-white);color:var(--color-coffee-dark);border:2px solid var(--color-gold)}.atelier-cta-button.secondary:hover{background:var(--color-cream-dark);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}@media (max-width: 768px){.atelier-cta-buttons{flex-direction:column}.atelier-cta-button{width:100%}}.atelier-core-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.core-value-item{text-align:center;padding:1.5rem;background:#d4af370d;border-radius:12px;transition:all .3s ease;border:2px solid transparent}.core-value-item:hover{background:#d4af371a;transform:translateY(-5px);border-color:var(--color-gold);box-shadow:0 8px 20px #d4af3733}.core-value-icon{font-size:3rem;margin-bottom:1rem}.core-value-item h3{font-size:1.2rem;margin-bottom:.75rem;color:var(--color-gold);font-weight:600}.core-value-item p{font-size:.95rem;line-height:1.6;color:var(--color-text-secondary);margin:0}@media (max-width: 768px){.atelier-core-values{grid-template-columns:1fr}}.atelier-blog-section{margin-top:3rem;padding-top:2rem;border-top:2px solid var(--color-gold)}.atelier-blog-title{font-size:2rem;font-weight:600;color:var(--color-coffee-darker);margin-bottom:1rem;text-align:center}.atelier-blog-description{font-size:1.1rem;line-height:1.8;color:var(--color-text-secondary);text-align:center;margin-bottom:2rem;font-style:italic}@media (max-width: 768px){.atelier-blog-section{margin-top:2rem;padding-top:1.5rem}.atelier-blog-title{font-size:1.5rem}.atelier-blog-description{font-size:1rem}}.contact-page{max-width:1000px;margin:0 auto;padding:2rem 1rem}.contact-hero{text-align:center;margin-bottom:3rem;padding:3rem 1rem;background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-cream-dark) 100%);border-radius:16px;color:var(--color-coffee-darker);border:2px solid var(--color-gold);box-shadow:0 8px 32px #d4af3726}.contact-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.contact-subtitle{font-size:1.2rem;opacity:.95}.contact-content{display:flex;flex-direction:column;gap:2rem}.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.contact-info-section{text-align:center;padding:1rem;display:flex;flex-direction:column;align-items:center}.contact-icon{font-size:3rem;margin-bottom:1rem}.contact-info-section h2{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem}.contact-detail{font-size:1.1rem;color:var(--color-text-primary);margin-bottom:.5rem;text-align:center;width:100%}.contact-detail a{color:var(--color-gold);text-decoration:none;transition:color .3s ease;display:inline-block}.contact-detail a:hover{color:var(--color-coffee-dark);text-decoration:underline}.contact-description{font-size:.95rem;color:var(--color-text-secondary);margin-top:.5rem}.contact-social-links{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.contact-social-link{padding:.5rem 1.5rem;background:var(--color-gold);color:#fff;text-decoration:none;border-radius:6px;transition:background .3s ease,transform .3s ease}.contact-social-link:hover{background:var(--color-gold);transform:translateY(-2px)}.contact-form-section{padding:1rem}.contact-form-section h2{font-size:1.8rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1.5rem;border-bottom:2px solid var(--color-gold);padding-bottom:.5rem}.contact-faq{display:flex;flex-direction:column;gap:1.5rem}.contact-faq-item{padding:1.5rem;background:var(--color-background-secondary);border-radius:8px;border-left:4px solid var(--color-gold)}.contact-faq-item h3{font-size:1.2rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.75rem}.contact-faq-item p{font-size:1rem;line-height:1.6;color:var(--color-text-secondary);margin:0}@media (max-width: 768px){.contact-title{font-size:2rem}.contact-subtitle{font-size:1rem}.contact-grid{grid-template-columns:1fr}.contact-social-links{flex-direction:column}}.faq-page{min-height:100vh;background:linear-gradient(135deg,#fff8e7,#f5e6d3);padding:2rem 0}.faq-container{max-width:900px;margin:0 auto;padding:0 2rem}.faq-header{text-align:center;margin-bottom:3rem;padding:3rem 2rem;background:linear-gradient(135deg,#fff8e7,#f5e6d3);border:2px solid #D4AF37;border-radius:12px}.faq-title{font-family:Playfair Display,serif;font-size:2.5rem;font-weight:700;color:#2c3e50;margin:0 0 1rem;letter-spacing:.05em}.faq-subtitle{font-size:1.1rem;color:#5d4e37;margin:0}.faq-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.faq-item{background:#fff;border:1px solid #E8D5B7;border-radius:8px;overflow:hidden;transition:all .3s ease}.faq-item.active{border-color:#d4af37;box-shadow:0 4px 12px #d4af3726}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:transparent;border:none;cursor:pointer;font-family:Montserrat,sans-serif;font-size:1.05rem;font-weight:600;color:#2c3e50;text-align:left;transition:all .3s ease}.faq-question:hover{background:#fff8e7}.faq-icon{font-size:1.5rem;color:#d4af37;font-weight:300;transition:transform .3s ease}.faq-item.active .faq-icon{transform:rotate(180deg)}.faq-answer{padding:0 1.5rem 1.5rem;animation:slideDown .3s ease}.faq-answer p{font-size:.95rem;line-height:1.7;color:#5d4e37;margin:0 0 1rem}.faq-subscribe-link{display:inline-block;margin-top:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#d4af37,#b8941f);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .3s ease;box-shadow:0 2px 8px #d4af374d}.faq-subscribe-link:hover{background:linear-gradient(135deg,#b8941f,#d4af37);transform:translateY(-2px);box-shadow:0 4px 12px #d4af3766}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.faq-contact{text-align:center;padding:2rem;background:#fff;border:2px solid #D4AF37;border-radius:12px}.faq-contact h2{font-family:Playfair Display,serif;font-size:1.5rem;color:#2c3e50;margin:0 0 1rem}.faq-contact p{font-size:1rem;color:#5d4e37;margin:0}.faq-contact a{color:#d4af37;text-decoration:none;font-weight:600;transition:color .3s ease}.faq-contact a:hover{color:#b8941f;text-decoration:underline}@media (max-width: 768px){.faq-container{padding:0 1rem}.faq-header{padding:2rem 1rem}.faq-title{font-size:2rem}.faq-subtitle{font-size:1rem}.faq-question{font-size:.95rem;padding:1rem}.faq-answer{padding:0 1rem 1rem}}.privacy-page{min-height:100vh;background:linear-gradient(135deg,#fff8e7,#f5e6d3);padding:2rem 0}.privacy-container{max-width:900px;margin:0 auto;padding:0 2rem}.privacy-header{text-align:center;margin-bottom:3rem;padding:3rem 2rem;background:linear-gradient(135deg,#fff8e7,#f5e6d3);border:2px solid #D4AF37;border-radius:12px}.privacy-title{font-family:Playfair Display,serif;font-size:2.5rem;font-weight:700;color:#2c3e50;margin:0 0 .5rem;letter-spacing:.05em}.privacy-date{font-size:.9rem;color:#5d4e37;margin:0;font-style:italic}.privacy-content{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 4px 20px #00000014}.privacy-intro{margin-bottom:2.5rem;padding:1.5rem;background:#fff8e7;border-left:4px solid #D4AF37;border-radius:0 8px 8px 0}.privacy-intro p{font-size:1.05rem;line-height:1.8;color:#5d4e37;margin:0;font-weight:500}.privacy-section{margin-bottom:2.5rem}.privacy-section:last-child{margin-bottom:0}.privacy-section h2{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600;color:#2c3e50;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #D4AF37}.privacy-section h3{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:600;color:#3e2723;margin:1.5rem 0 .75rem}.privacy-section p{font-size:1rem;line-height:1.8;color:#5d4e37;margin:0 0 1rem}.privacy-section ul{list-style:none;padding:0;margin:1rem 0}.privacy-section li{font-size:1rem;line-height:1.8;color:#5d4e37;padding-left:1.5rem;position:relative;margin-bottom:.5rem}.privacy-section li:before{content:"•";color:#d4af37;font-weight:700;position:absolute;left:0}.privacy-contact{background:#fff8e7;padding:1.5rem;border-radius:8px;border-left:4px solid #D4AF37}.privacy-contact a{color:#d4af37;text-decoration:none;font-weight:600;transition:color .3s ease}.privacy-contact a:hover{color:#b8941f;text-decoration:underline}@media (max-width: 768px){.privacy-container{padding:0 1rem}.privacy-header{padding:2rem 1rem}.privacy-title{font-size:2rem}.privacy-content{padding:2rem 1.5rem}.privacy-section h2{font-size:1.3rem}.privacy-section p,.privacy-section li{font-size:.95rem}}.dr-zenie-container{display:flex;flex-direction:column;align-items:center;gap:1rem;position:relative}.dr-zenie-position-top{position:fixed;top:1rem;right:1rem;z-index:1000}.dr-zenie-position-bottom{position:fixed;bottom:1rem;right:1rem;z-index:1000}.dr-zenie-position-floating{position:fixed;bottom:2rem;right:2rem;z-index:1000;animation:gentle-float 3s ease-in-out infinite}.dr-zenie-position-inline{position:relative;margin:1rem auto}.dr-zenie-character{position:relative;display:flex;align-items:center;justify-content:center}.dr-zenie-image{display:block;width:100%;height:auto;object-fit:contain;transition:opacity .3s ease-in-out}.dr-zenie-size-small .dr-zenie-character{width:80px;height:80px}.dr-zenie-size-medium .dr-zenie-character{width:120px;height:120px}.dr-zenie-size-large .dr-zenie-character{width:160px;height:160px}.dr-zenie-animating .dr-zenie-image{opacity:0}.dr-zenie-animated .dr-zenie-image{animation:gentle-breathing 2s ease-in-out infinite}.dr-zenie-container{animation:character-entrance .5s ease-out}@keyframes character-entrance{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes gentle-breathing{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes gentle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.dr-zenie-speech-bubble{position:relative;background:#fff;border:2px solid #e0e0e0;border-radius:16px;padding:.75rem 1rem;max-width:250px;box-shadow:0 2px 8px #0000001a;animation:bubble-appear .3s ease-out}.speech-bubble-content{font-size:.9rem;line-height:1.4;color:#333;text-align:center}.speech-bubble-tail{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:10px solid white}.speech-bubble-tail:before{content:"";position:absolute;bottom:2px;left:-11px;width:0;height:0;border-left:11px solid transparent;border-right:11px solid transparent;border-top:11px solid #e0e0e0}@keyframes bubble-appear{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 768px){.dr-zenie-position-top,.dr-zenie-position-bottom{right:.5rem}.dr-zenie-position-floating{bottom:1rem;right:1rem}.dr-zenie-size-small .dr-zenie-character{width:60px;height:60px}.dr-zenie-size-medium .dr-zenie-character{width:90px;height:90px}.dr-zenie-size-large .dr-zenie-character{width:120px;height:120px}.dr-zenie-speech-bubble{max-width:200px;padding:.5rem .75rem}.speech-bubble-content{font-size:.85rem}}@media (prefers-reduced-motion: reduce){.dr-zenie-animated .dr-zenie-image,.dr-zenie-position-floating,.dr-zenie-container,.dr-zenie-speech-bubble{animation:none}.dr-zenie-animating .dr-zenie-image{transition:none}}@media (prefers-contrast: high){.dr-zenie-speech-bubble{border:3px solid #000}.speech-bubble-content{color:#000}}.food-analyzer{max-width:800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.image-preview{margin:20px 0;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.image-preview img{width:100%;height:auto;display:block}.action-buttons{display:flex;gap:12px;justify-content:center;margin:24px 0}.btn-primary,.btn-secondary,.btn-retry,.btn-new-analysis{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.btn-secondary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #f5576c66}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-retry{background:#10b981;color:#fff;margin-top:16px}.btn-retry:hover{background:#059669;transform:translateY(-2px)}.btn-new-analysis{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:100%;margin-top:24px}.btn-new-analysis:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.loading-state{text-align:center;padding:40px 20px}.spinner{width:50px;height:50px;margin:0 auto 20px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-state p{color:#6b7280;font-size:16px}.error-state{text-align:center;padding:20px;background:#fef2f2;border:2px solid #fecaca;border-radius:12px;margin:20px 0}.error-message{color:#dc2626;margin-bottom:16px}.error-message p{margin:0;font-size:16px}.analysis-results{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px #0000001a;margin-top:20px}.analysis-results h3{margin:0 0 20px;color:#1f2937;font-size:24px}.analysis-results h4{margin:20px 0 12px;color:#374151;font-size:18px;border-bottom:2px solid #e5e7eb;padding-bottom:8px}.detected-foods{margin-bottom:24px}.food-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9fafb;border-radius:8px;margin-bottom:8px}.food-name{font-weight:600;color:#1f2937}.confidence{font-size:14px;color:#6b7280;font-weight:400;margin-left:8px}.food-weight{color:#6b7280;font-size:14px}.nutrition-summary{margin-bottom:24px}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.nutrition-item{display:flex;flex-direction:column;padding:12px;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:8px;text-align:center}.nutrition-item .label{font-size:14px;color:#6b7280;margin-bottom:4px}.nutrition-item .value{font-size:20px;font-weight:700;color:#1f2937}.daily-progress{margin-bottom:24px}.progress-item{margin-bottom:16px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-label{font-weight:600;color:#374151}.progress-value{font-size:14px;color:#6b7280}.progress-bar{width:100%;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.progress-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:6px}.quota-display{text-align:center;margin-top:24px;padding:12px;background:#f9fafb;border-radius:8px;color:#6b7280;font-size:14px}.quota-display p{margin:0}@media (max-width: 768px){.food-analyzer{padding:12px}.action-buttons{flex-direction:column;gap:10px}.btn-primary,.btn-secondary,.btn-retry,.btn-new-analysis{width:100%;min-height:44px}.nutrition-grid{grid-template-columns:repeat(2,1fr);gap:10px}.analysis-results{padding:16px;border-radius:8px}.analysis-results h3{font-size:20px}.analysis-results h4{font-size:16px}.nutrition-item{padding:10px}.nutrition-item .value{font-size:18px}.food-item{padding:10px;font-size:14px}.analysis-results{max-height:calc(100vh - 250px);overflow-y:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 480px){.food-analyzer{padding:8px}.nutrition-grid{grid-template-columns:1fr;gap:8px}.food-item{flex-direction:column;align-items:flex-start;gap:6px}.analysis-results{padding:12px}.analysis-results h3{font-size:18px}.analysis-results h4{font-size:15px}.nutrition-item .label{font-size:13px}.nutrition-item .value{font-size:16px}}@media (pointer: coarse){.btn-primary,.btn-secondary,.btn-retry,.btn-new-analysis{min-height:44px;padding:12px 20px}}@media (orientation: landscape) and (max-height: 600px){.analysis-results{max-height:calc(100vh - 180px)}}@media (prefers-reduced-motion: reduce){.btn-primary:hover,.btn-secondary:hover,.btn-retry:hover,.btn-new-analysis:hover{transform:none}.spinner{animation:none;border-top-color:transparent;border-right-color:#667eea}.progress-fill{transition:none}}@media (prefers-contrast: high){.analysis-results{border:2px solid #000}.nutrition-item,.progress-bar{border:1px solid #000}}.barcode-scanner{width:100%;max-width:800px;margin:0 auto;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.scanner-interface{display:flex;flex-direction:column;gap:1.5rem}.camera-container{position:relative;width:100%;aspect-ratio:4 / 3;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000026}.video-preview{width:100%;height:100%}.video-preview video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.scanner-frame{width:80%;max-width:400px;aspect-ratio:3 / 2;border:3px solid rgba(255,255,255,.8);border-radius:8px;box-shadow:0 0 0 9999px #00000080;position:relative}.scanner-frame:before,.scanner-frame:after{content:"";position:absolute;width:20px;height:20px;border:3px solid #4CAF50}.scanner-frame:before{top:-3px;left:-3px;border-right:none;border-bottom:none}.scanner-frame:after{top:-3px;right:-3px;border-left:none;border-bottom:none}.scanner-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#4CAF50,transparent);animation:scan 2s linear infinite}@keyframes scan{0%{top:0}to{top:100%}}.scanner-controls{display:flex;flex-direction:column;align-items:center;gap:1rem}.scanner-loading{font-size:1.1rem;color:#666;text-align:center;padding:1rem}.btn-primary,.btn-secondary{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;min-width:200px}.btn-large{padding:1rem 2.5rem;font-size:1.1rem}.btn-primary{background:var(--color-gold);color:#fff;box-shadow:0 4px 12px #d4af3766}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d4af3780}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-cream);color:var(--color-coffee-darker);border:2px solid var(--color-beige)}.btn-secondary:hover{background:var(--color-cream-dark);border-color:var(--color-gold)}.barcode-scanner-result{display:flex;flex-direction:column;gap:1.5rem}.result-content{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.product-info{margin-bottom:1.5rem}.product-info h2{font-size:1.5rem;color:#333;margin:0 0 .5rem}.product-brand{font-size:1rem;color:#666;margin:0 0 1rem}.product-image{width:100%;max-width:300px;height:auto;border-radius:8px;margin-top:1rem}.idia-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--color-gold);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;margin-bottom:1rem;box-shadow:0 2px 8px #d4af374d}.idia-badge-icon{font-size:1.2rem;font-weight:700}.nutrition-label{margin:1.5rem 0;border:2px solid #333;border-radius:8px;padding:1rem;background:#fafafa}.nutrition-label h3{font-size:1.3rem;font-weight:700;margin:0 0 1rem;color:#333;border-bottom:4px solid #333;padding-bottom:.5rem}.nutrition-serving{margin-bottom:1rem;padding:.5rem;background:#fff;border-radius:4px}.nutrition-table{width:100%;border-collapse:collapse}.nutrition-table tr{border-bottom:1px solid #ddd}.nutrition-table tr:last-child{border-bottom:2px solid #333}.nutrition-table td{padding:.75rem .5rem}.nutrition-table td:first-child{font-weight:500;color:#333}.nutrition-table td:last-child{text-align:right;font-weight:600;color:#000}.nutrition-indent td:first-child{padding-left:1.5rem;font-weight:400;color:#666}.idia-features{margin:1.5rem 0;padding:1rem;background:linear-gradient(135deg,#d4af371a,#8b73550d);border-radius:8px;border:2px solid rgba(212,175,55,.3)}.idia-features h3{font-size:1.2rem;color:var(--color-gold);margin:0 0 1rem}.nutrition-highlights{list-style:none;padding:0;margin:0}.nutrition-highlights li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#333}.nutrition-highlights li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:700}.result-actions{display:flex;justify-content:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #eee}.barcode-scanner-error,.barcode-scanner-not-found{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.error-content,.not-found-content{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;max-width:500px}.error-content h3,.not-found-content h3{font-size:1.5rem;color:#d32f2f;margin:0 0 1rem}.error-content p,.not-found-content p{font-size:1rem;color:#666;margin:.5rem 0;line-height:1.6}.error-instructions{margin-top:1.5rem;text-align:left;background:#f5f5f5;padding:1rem;border-radius:8px}.error-instructions h4{font-size:1rem;color:#333;margin:0 0 .5rem}.error-instructions ol{margin:.5rem 0 0 1.5rem;padding:0}.error-instructions li{margin:.5rem 0;color:#666;line-height:1.5}@media (max-width: 768px){.barcode-scanner{padding:.5rem}.camera-container{border-radius:8px}.scanner-frame{width:90%}.result-content{padding:1rem}.product-info h2{font-size:1.3rem}.nutrition-label{padding:.75rem}.nutrition-table td{padding:.5rem .25rem;font-size:.9rem}.btn-primary,.btn-secondary{min-width:150px;padding:.75rem 1.5rem}.btn-large{padding:.875rem 2rem;font-size:1rem}}@media (max-width: 480px){.barcode-scanner{padding:.25rem}.scanner-interface{gap:1rem}.product-info h2{font-size:1.1rem}.product-brand{font-size:.9rem}.nutrition-label h3{font-size:1.1rem}.nutrition-table td{font-size:.85rem}.error-content,.not-found-content{padding:1.5rem}}@media (prefers-reduced-motion: reduce){.scanner-line{animation:none}.btn-primary:hover,.btn-secondary:hover{transform:none}}@media (prefers-contrast: high){.scanner-frame{border-width:4px}.nutrition-label,.btn-primary,.btn-secondary{border-width:3px}}.qr-scanner{display:flex;flex-direction:column;align-items:center;width:100%;max-width:640px;margin:0 auto}.qr-scanner__video-container{position:relative;width:100%;aspect-ratio:4 / 3;background-color:#000;border-radius:12px;overflow:hidden}.qr-scanner__video{width:100%;height:100%;object-fit:cover}.qr-scanner__viewfinder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:250px;height:250px;pointer-events:none}.qr-scanner__corner{position:absolute;width:40px;height:40px;border:3px solid #4CAF50}.qr-scanner__corner--tl{top:0;left:0;border-right:none;border-bottom:none;border-top-left-radius:8px}.qr-scanner__corner--tr{top:0;right:0;border-left:none;border-bottom:none;border-top-right-radius:8px}.qr-scanner__corner--bl{bottom:0;left:0;border-right:none;border-top:none;border-bottom-left-radius:8px}.qr-scanner__corner--br{bottom:0;right:0;border-left:none;border-top:none;border-bottom-right-radius:8px}.qr-scanner__status{margin-top:20px;text-align:center;min-height:60px}.qr-scanner__message{font-size:16px;color:#666;margin:0}.qr-scanner__error{display:flex;flex-direction:column;align-items:center;gap:12px}.qr-scanner__error-message{font-size:16px;color:#d32f2f;margin:0}.qr-scanner__retry-button{padding:10px 24px;font-size:16px;font-weight:500;color:#fff;background-color:#4caf50;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.qr-scanner__retry-button:hover{background-color:#45a049}.qr-scanner__retry-button:active{background-color:#3d8b40}@media (max-width: 768px){.qr-scanner__viewfinder{width:200px;height:200px}.qr-scanner__corner{width:30px;height:30px}.qr-scanner__message,.qr-scanner__error-message{font-size:14px}.qr-scanner__retry-button{font-size:14px;padding:8px 20px}}.scan-mode-selector{display:flex;gap:12px;padding:8px;background-color:#f5f5f5;border-radius:12px;width:fit-content;margin:0 auto 20px}.scan-mode-selector__button{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 20px;background-color:transparent;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;color:#666}.scan-mode-selector__button:hover:not(:disabled){background-color:#e8e8e8}.scan-mode-selector__button--active{background-color:#fff;border-color:#4caf50;color:#4caf50;box-shadow:0 2px 4px #0000001a}.scan-mode-selector__button:disabled{opacity:.5;cursor:not-allowed}.scan-mode-selector__icon{width:32px;height:32px}.scan-mode-selector__label{font-size:14px;font-weight:500}@media (max-width: 768px){.scan-mode-selector{gap:8px;padding:6px}.scan-mode-selector__button{padding:10px 16px;gap:4px}.scan-mode-selector__icon{width:28px;height:28px}.scan-mode-selector__label{font-size:12px}}.scan-history-viewer{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000001a;max-width:900px;margin:0 auto}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.history-header h2{margin:0;color:#333;font-size:1.75rem}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;transition:color .2s ease;padding:.25rem;line-height:1}.close-button:hover{color:#333}.retention-info{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;color:#555}.info-icon{font-size:1.2rem}.upgrade-hint{color:#667eea;font-weight:600;margin-left:.25rem}.date-range-filter{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.date-range-filter button{flex:1;min-width:120px;padding:.75rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease}.date-range-filter button:hover:not(:disabled){border-color:#667eea;color:#667eea;transform:translateY(-2px)}.date-range-filter button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.date-range-filter button:disabled{opacity:.4;cursor:not-allowed}.loading-state{text-align:center;padding:3rem 1rem;color:#666}.spinner-large{font-size:3rem;animation:spin 1s linear infinite;margin-bottom:1rem}.error-state{text-align:center;padding:3rem 1rem;color:#721c24;background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px}.error-state span{font-size:2rem;display:block;margin-bottom:1rem}.btn-retry{margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s ease}.btn-retry:hover{transform:translateY(-2px)}.empty-state{text-align:center;padding:3rem 1rem;color:#666}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem;opacity:.5}.empty-state h3{margin:0 0 .5rem;color:#333;font-size:1.5rem}.empty-state p{margin:0;color:#666;line-height:1.6}.history-list{display:flex;flex-direction:column;gap:1rem}.history-item{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e0e0e0;border-radius:12px;padding:1.25rem;transition:all .3s ease}.history-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e0e0e0}.item-date{font-size:.9rem;color:#666;font-weight:600}.item-type-badge{padding:.25rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.item-nutrition{margin-bottom:.75rem}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.nutrition-item{display:flex;flex-direction:column;gap:.25rem}.nutrition-label{font-size:.75rem;color:#999;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.nutrition-value{font-size:1.1rem;color:#333;font-weight:700}.item-footer{padding-top:.75rem;border-top:1px solid #e0e0e0}.scan-count{font-size:.85rem;color:#666;font-style:italic}.history-summary{margin-top:1.5rem;padding-top:1rem;border-top:2px solid #f0f0f0;text-align:center;color:#666;font-size:.9rem}@media (max-width: 768px){.scan-history-viewer{padding:1.5rem;border-radius:0}.history-header h2{font-size:1.5rem}.date-range-filter{flex-direction:column}.date-range-filter button{width:100%}.nutrition-grid{grid-template-columns:repeat(2,1fr)}.history-item{padding:1rem}}@media (max-width: 480px){.nutrition-grid{grid-template-columns:1fr}}.ai-health-advisor{width:100%;max-width:800px;margin:0 auto;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.ai-health-advisor.loading,.ai-health-advisor.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:40px 20px}.advisor-header{display:flex;justify-content:center;margin-bottom:24px}.product-name{text-align:center;margin-bottom:20px}.product-name h3{font-size:1.5rem;font-weight:600;color:#2c3e50;margin:0}.loading-text{text-align:center;margin-top:16px}.loading-text p{font-size:1rem;color:#7f8c8d;margin:8px 0}.error-message{text-align:center;margin-top:16px}.error-message p{font-size:1rem;color:#e74c3c;margin:8px 0}.error-detail{font-size:.875rem;color:#95a5a6}.recommendation-summary{margin-bottom:24px;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.recommendation-summary h4{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0 0 12px}.recommendation-summary p{font-size:1rem;line-height:1.6;color:#34495e;margin:0}.fallback-notice{display:flex;align-items:center;gap:8px;margin-top:12px;padding:12px;background:#fff3cd;border-radius:6px;font-size:.875rem;color:#856404}.notice-icon{font-size:1.25rem}.health-concerns{margin-bottom:24px}.health-concerns h4{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0 0 16px}.concerns-list{display:flex;flex-direction:column;gap:12px}.concern-card{padding:16px;border-radius:8px;border-left:4px solid;background:#fff;box-shadow:0 1px 3px #0000001a}.concern-card.concern-severity-low{border-left-color:#f39c12;background:#fef9e7}.concern-card.concern-severity-medium{border-left-color:#e67e22;background:#fef5e7}.concern-card.concern-severity-high{border-left-color:#e74c3c;background:#fdedec}.concern-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.concern-type{font-size:1rem;font-weight:600;color:#2c3e50}.concern-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.concern-badge.concern-severity-low{background:#f39c12;color:#fff}.concern-badge.concern-severity-medium{background:#e67e22;color:#fff}.concern-badge.concern-severity-high{background:#e74c3c;color:#fff}.concern-description{font-size:.875rem;line-height:1.5;color:#34495e;margin:0 0 8px}.concern-metrics{display:flex;gap:16px;font-size:.75rem;color:#7f8c8d}.metric-current,.metric-threshold{font-weight:500}.suggestions{margin-bottom:24px}.suggestions h4{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0 0 16px}.suggestions-list{display:flex;flex-direction:column;gap:12px}.suggestion-card{padding:16px;border-radius:8px;background:#e8f5e9;border-left:4px solid #27ae60;box-shadow:0 1px 3px #0000001a}.suggestion-card.suggestion-priority-high{background:#fff3e0;border-left-color:#f39c12}.suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.suggestion-category{font-size:.875rem;font-weight:600;color:#27ae60}.suggestion-card.suggestion-priority-high .suggestion-category{color:#f39c12}.priority-badge{padding:4px 8px;border-radius:12px;font-size:.625rem;font-weight:600;text-transform:uppercase;background:#f39c12;color:#fff}.suggestion-text{font-size:.875rem;line-height:1.5;color:#34495e;margin:0}.product-alternatives{margin-bottom:24px}.product-alternatives h4{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0 0 16px}.alternatives-list{display:flex;flex-direction:column;gap:16px}.alternative-card{padding:20px;border-radius:8px;background:#fff;border:2px solid #3498db;box-shadow:0 2px 4px #0000001a}.alternative-header{margin-bottom:12px}.alternative-name{font-size:1.125rem;font-weight:600;color:#2c3e50;margin:0 0 4px}.alternative-brand{font-size:.875rem;color:#7f8c8d}.alternative-reason{font-size:.875rem;line-height:1.5;color:#34495e;margin:0 0 16px}.nutrition-comparison{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.comparison-metric{display:flex;flex-direction:column;align-items:center;padding:12px;border-radius:6px;background:#f8f9fa}.comparison-metric.better{background:#e8f5e9}.comparison-metric.worse{background:#ffebee}.metric-label{font-size:.75rem;font-weight:600;color:#7f8c8d;text-transform:uppercase;margin-bottom:4px}.metric-change{font-size:1rem;font-weight:700}.comparison-metric.better .metric-change{color:#27ae60}.comparison-metric.worse .metric-change{color:#e74c3c}.detailed-analysis{margin-bottom:24px;padding:24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.detailed-analysis h4{font-size:1.25rem;font-weight:600;color:#fff;margin:0 0 20px;display:flex;align-items:center;gap:8px}.detailed-analysis h4:before{content:"⭐";font-size:1.5rem}.detailed-analysis-content{display:flex;flex-direction:column;gap:20px}.analysis-section{padding:16px;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.analysis-section h5{font-size:1rem;font-weight:600;color:#fff;margin:0 0 12px}.analysis-section p{font-size:.875rem;line-height:1.6;color:#ffffffe6;margin:0}.trend-direction{margin-bottom:12px}.trend-badge{display:inline-block;padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;text-transform:uppercase}.trend-badge.trend-improving{background:#27ae60;color:#fff}.trend-badge.trend-stable{background:#f39c12;color:#fff}.trend-badge.trend-declining{background:#e74c3c;color:#fff}.key-metrics,.trend-recommendations{margin-top:12px}.metrics-label,.recommendations-label{font-size:.875rem;font-weight:600;color:#ffffffe6;margin:0 0 8px}.key-metrics ul,.trend-recommendations ul{margin:0;padding-left:20px}.key-metrics li,.trend-recommendations li{font-size:.875rem;line-height:1.5;color:#ffffffd9;margin-bottom:4px}.goals-list{display:flex;flex-direction:column;gap:12px}.goal-card{padding:12px;background:#ffffff26;border-radius:6px;border-left:3px solid rgba(255,255,255,.5)}.goal-card.goal-priority-high{border-left-color:#f39c12}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.goal-nutrient{font-size:.875rem;font-weight:600;color:#fff}.goal-timeframe{font-size:.75rem;color:#ffffffb3}.goal-metrics{display:flex;align-items:center;gap:8px;font-size:.75rem;color:#ffffffd9}.goal-current,.goal-target{font-weight:500}.goal-arrow{font-size:1rem;color:#ffffff80}@media (max-width: 768px){.ai-health-advisor{padding:16px;border-radius:8px}.product-name h3{font-size:1.25rem}.recommendation-summary,.health-concerns,.suggestions,.product-alternatives,.detailed-analysis{margin-bottom:20px}.recommendation-summary{padding:16px}.recommendation-summary h4,.health-concerns h4,.suggestions h4,.product-alternatives h4,.detailed-analysis h4{font-size:1.125rem}.concern-header,.suggestion-header,.alternative-header{flex-direction:column;align-items:flex-start;gap:8px}.concern-card,.suggestion-card,.alternative-card{padding:14px}.nutrition-comparison{grid-template-columns:repeat(2,1fr);gap:10px}.detailed-analysis{padding:16px}.analysis-section{padding:12px}.ai-health-advisor{max-height:calc(100vh - 250px);overflow-y:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 480px){.ai-health-advisor{padding:12px}.product-name h3{font-size:1.1rem}.recommendation-summary{padding:12px}.recommendation-summary h4,.health-concerns h4,.suggestions h4,.product-alternatives h4{font-size:1rem}.concern-card,.suggestion-card,.alternative-card{padding:12px}.concern-type,.suggestion-category{font-size:.9rem}.concern-description,.suggestion-text,.alternative-reason{font-size:.85rem}.nutrition-comparison{grid-template-columns:1fr}.comparison-metric{padding:10px}.detailed-analysis{padding:12px}.detailed-analysis h4{font-size:1rem}.analysis-section{padding:10px}.analysis-section h5{font-size:.95rem}.analysis-section p{font-size:.85rem}}@media (pointer: coarse){.concern-card,.suggestion-card,.alternative-card{min-height:44px;cursor:pointer}.concern-card:active,.suggestion-card:active,.alternative-card:active{background-color:#f5f5f5}}@media (orientation: landscape) and (max-height: 600px){.ai-health-advisor{max-height:calc(100vh - 180px)}}.ai-health-advisor *:focus{outline:2px solid #3498db;outline-offset:2px}@media (prefers-contrast: high){.concern-card,.suggestion-card,.alternative-card{border-width:2px}.concern-badge,.priority-badge,.trend-badge{border:1px solid currentColor}.recommendation-summary{border-left-width:6px}}@media (prefers-reduced-motion: reduce){.ai-health-advisor *{animation:none!important;transition:none!important}}.idia-recipe-display{max-width:800px;margin:0 auto;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.recipe-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f0f0f0}.recipe-title{font-size:1.75rem;font-weight:700;color:#2c3e50;margin:0 0 .75rem}.recipe-description{font-size:1rem;color:#5a6c7d;line-height:1.6;margin:0 0 1.5rem}.recipe-meta{display:flex;flex-wrap:wrap;gap:1.5rem}.meta-item{display:flex;align-items:center;gap:.5rem;font-size:.95rem}.meta-icon{font-size:1.25rem}.meta-label{color:#7f8c8d;font-weight:500}.meta-value{color:#2c3e50;font-weight:600}.difficulty-badge{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;text-transform:uppercase}.difficulty-easy{background-color:#d4edda;color:#155724}.difficulty-medium{background-color:#fff3cd;color:#856404}.difficulty-hard{background-color:#f8d7da;color:#721c24}.recipe-step-container{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.step-title{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0}.step-duration{display:flex;align-items:center;gap:.25rem;font-size:.9rem;color:#7f8c8d;padding:.25rem .75rem;background:#fff;border-radius:20px}.step-image-container{margin:1rem 0;border-radius:8px;overflow:hidden;background:#fff}.step-image{width:100%;height:auto;display:block;max-height:400px;object-fit:cover}.step-instruction{margin:1.5rem 0;padding:1.25rem;background:#fff;border-radius:8px;border-left:4px solid #3498db}.step-instruction p{font-size:1.05rem;line-height:1.7;color:#2c3e50;margin:0}.step-navigation{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.5rem}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px;justify-content:center}.nav-button:hover:not(:disabled){background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 8px #3498db4d}.nav-button:active:not(:disabled){transform:translateY(0)}.nav-button:disabled{background:#bdc3c7;cursor:not-allowed;opacity:.6}.nav-icon{font-size:1.25rem;font-weight:700}.nav-text{font-size:.95rem}.step-indicator{display:flex;gap:.5rem;align-items:center;flex:1;justify-content:center}.step-dot{width:12px;height:12px;border-radius:50%;background:#bdc3c7;border:2px solid #bdc3c7;cursor:pointer;transition:all .3s ease;padding:0}.step-dot:hover{transform:scale(1.2);background:#95a5a6;border-color:#95a5a6}.step-dot.active{background:#3498db;border-color:#3498db;transform:scale(1.3)}.step-dot.completed{background:#27ae60;border-color:#27ae60}.recipe-progress{margin-top:1.5rem}.progress-bar{width:100%;height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease;border-radius:4px}.progress-text{text-align:center;font-size:.9rem;color:#7f8c8d;margin:0}@media (max-width: 768px){.idia-recipe-display{padding:1rem;border-radius:8px}.recipe-title{font-size:1.5rem}.recipe-description{font-size:.95rem}.recipe-meta{flex-direction:column;gap:.75rem}.meta-item{font-size:.9rem}.recipe-step-container{padding:1rem}.step-title{font-size:1.1rem}.step-instruction{padding:1rem}.step-instruction p{font-size:1rem}.step-navigation{flex-direction:column;gap:1rem}.nav-button{width:100%;min-width:unset;padding:1rem;font-size:1.05rem}.step-indicator{order:-1;width:100%;padding:.5rem 0}.step-dot{width:10px;height:10px}.nav-previous{order:1}.nav-next{order:2}}@media (max-width: 480px){.idia-recipe-display{padding:.75rem}.recipe-title{font-size:1.25rem}.recipe-description{font-size:.9rem}.meta-icon{font-size:1.1rem}.meta-item{font-size:.85rem}.step-image{max-height:250px}.step-instruction p{font-size:.95rem}.nav-button{padding:.875rem}.nav-icon{font-size:1.1rem}.nav-text{font-size:.9rem}}@media (prefers-contrast: high){.idia-recipe-display{border:2px solid #000000}.recipe-header{border-bottom-color:#000}.difficulty-badge{border:2px solid currentColor}.step-instruction{border-left-width:6px}.nav-button:disabled{border:2px solid #7f8c8d}}@media (prefers-reduced-motion: reduce){.nav-button,.step-dot,.progress-fill{transition:none}.nav-button:hover:not(:disabled){transform:none}.step-dot:hover,.step-dot.active{transform:none}}.nav-button:focus-visible,.step-dot:focus-visible{outline:3px solid #3498db;outline-offset:2px}@media (hover: none) and (pointer: coarse){.nav-button{min-height:44px;padding:1rem 1.5rem}.step-dot{width:16px;height:16px;margin:0 .25rem}}.idia-equipment-display{max-width:1000px;margin:0 auto;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.equipment-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #f0f0f0;text-align:center}.equipment-title{font-size:1.75rem;font-weight:700;color:#2c3e50;margin:0 0 .5rem}.equipment-subtitle{font-size:1rem;color:#7f8c8d;margin:0}.equipment-list{display:grid;gap:1.5rem;margin-bottom:2rem}.equipment-card{display:grid;grid-template-columns:300px 1fr;gap:1.5rem;background:#f8f9fa;border-radius:12px;padding:1.5rem;transition:all .3s ease}.equipment-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.equipment-image-container{position:relative;border-radius:8px;overflow:hidden;background:#fff;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.equipment-image{width:100%;height:100%;object-fit:cover;display:block}.equipment-badge{position:absolute;top:.75rem;right:.75rem;padding:.375rem .875rem;border-radius:20px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0003}.badge-required{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.badge-optional{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.equipment-info{display:flex;flex-direction:column;gap:1rem}.equipment-name{font-size:1.5rem;font-weight:700;color:#2c3e50;margin:0}.equipment-description{font-size:1rem;line-height:1.6;color:#5a6c7d;margin:0}.shopping-links{margin-top:auto}.shopping-title{font-size:1rem;font-weight:600;color:#2c3e50;margin:0 0 .75rem}.links-container{display:flex;flex-direction:column;gap:.75rem}.shopping-link{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;text-decoration:none;color:#2c3e50;transition:all .3s ease;min-height:44px}.shopping-link:hover{border-color:#3498db;background:#f0f8ff;transform:translate(4px);box-shadow:0 2px 8px #3498db33}.shopping-link:active{transform:translate(2px)}.link-official{border-color:#f39c12;background:linear-gradient(135deg,#fff9e6,#fff)}.link-official:hover{border-color:#f39c12;background:linear-gradient(135deg,#fff3cc,#fff9e6);box-shadow:0 2px 8px #f39c124d}.link-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.link-platform{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:#2c3e50}.official-icon{font-size:1.125rem;color:#f39c12}.link-price{font-size:.9rem;font-weight:700;color:#27ae60}.link-arrow{font-size:1.25rem;font-weight:700;color:#3498db;transition:transform .3s ease}.shopping-link:hover .link-arrow{transform:translate(4px)}.equipment-legend{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-badge{padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.legend-icon{font-size:1.25rem}.legend-text{font-size:.9rem;color:#5a6c7d}@media (max-width: 992px){.equipment-card{grid-template-columns:250px 1fr;gap:1.25rem;padding:1.25rem}.equipment-name{font-size:1.35rem}.equipment-description{font-size:.95rem}}@media (max-width: 768px){.idia-equipment-display{padding:1rem;border-radius:8px}.equipment-title{font-size:1.5rem}.equipment-subtitle{font-size:.95rem}.equipment-list{gap:1.25rem}.equipment-card{grid-template-columns:1fr;gap:1rem;padding:1rem}.equipment-image-container{max-width:100%;aspect-ratio:16 / 9}.equipment-badge{top:.5rem;right:.5rem;padding:.3rem .75rem;font-size:.8rem}.equipment-name{font-size:1.25rem}.equipment-description{font-size:.95rem}.shopping-link{padding:1rem}.link-platform{font-size:.95rem}.link-price{font-size:.85rem}.equipment-legend{flex-direction:column;gap:1rem;padding:1rem}.legend-item{justify-content:center}}@media (max-width: 480px){.idia-equipment-display{padding:.75rem}.equipment-title{font-size:1.35rem}.equipment-subtitle{font-size:.9rem}.equipment-card{padding:.875rem}.equipment-badge{padding:.25rem .625rem;font-size:.75rem}.equipment-name{font-size:1.15rem}.equipment-description{font-size:.9rem}.shopping-link{padding:.875rem 1rem}.link-platform{font-size:.9rem}.link-price{font-size:.8rem}.link-arrow{font-size:1.1rem}.legend-badge{font-size:.7rem;padding:.2rem .5rem}.legend-text{font-size:.85rem}}@media (prefers-contrast: high){.idia-equipment-display{border:2px solid #000000}.equipment-header{border-bottom-color:#000}.equipment-card{border:2px solid #000000}.equipment-badge,.legend-badge{border:2px solid currentColor}.shopping-link,.link-official{border-width:3px}}@media (prefers-reduced-motion: reduce){.equipment-card,.shopping-link,.link-arrow{transition:none}.equipment-card:hover,.shopping-link:hover,.shopping-link:hover .link-arrow{transform:none}}.shopping-link:focus-visible{outline:3px solid #3498db;outline-offset:2px}@media (hover: none) and (pointer: coarse){.shopping-link{min-height:48px;padding:1rem 1.25rem}.equipment-badge{padding:.5rem 1rem;font-size:.9rem}}@media print{.idia-equipment-display{box-shadow:none;border:1px solid #000000}.equipment-card{page-break-inside:avoid;box-shadow:none}.shopping-link{border:1px solid #000000}.link-arrow{display:none}}.food-scanner{max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.food-scanner.loading{display:flex;justify-content:center;align-items:center;min-height:400px}.food-scanner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.header-controls{display:flex;align-items:center;gap:16px}.scanner-title{font-size:28px;font-weight:700;color:#1f2937;margin:0;display:flex;align-items:center;gap:12px}.title-icon{font-size:32px}.quota-display-placeholder{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-weight:600;font-size:14px;box-shadow:0 2px 8px #667eea4d}.quota-icon{font-size:18px}.mode-tabs{display:flex;gap:12px;margin-bottom:24px;border-bottom:2px solid #e5e7eb;padding-bottom:0}.mode-tab{flex:1;padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .3s ease;position:relative}.mode-tab:hover:not(:disabled){color:#4f46e5;background:#f3f4f6}.mode-tab.active{color:#4f46e5;border-bottom-color:#4f46e5}.mode-tab:disabled{opacity:.5;cursor:not-allowed}.coming-soon-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:#fbbf24;color:#78350f;font-size:10px;font-weight:700;border-radius:10px;text-transform:uppercase}.scanner-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.photo-mode,.barcode-mode,.history-mode{min-height:400px}.idia-features-section{margin-top:32px;padding:24px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;border:2px solid #fbbf24}.idia-section-title{font-size:24px;font-weight:700;color:#78350f;margin:0 0 20px;display:flex;align-items:center;gap:12px}.idia-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fbbf24;color:#78350f;font-size:14px;font-weight:700;border-radius:20px}.idia-recipes,.idia-equipment{margin-top:24px}.idia-recipes h4,.idia-equipment h4{font-size:18px;font-weight:600;color:#92400e;margin:0 0 16px}.health-advisor-section{margin-top:32px;padding:24px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.daily-tracker-placeholder{margin-top:24px;padding:20px;background:#eff6ff;border-radius:8px;border:1px dashed #3b82f6}.daily-tracker-placeholder h4{font-size:18px;font-weight:600;color:#1e40af;margin:0 0 8px}.tracker-note{font-size:14px;color:#6b7280;margin:0}.history-view-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.placeholder-content{margin-top:24px;max-width:500px}.placeholder-content h3{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 12px}.placeholder-content p{font-size:16px;color:#6b7280;margin:0 0 24px}.feature-list{list-style:none;padding:0;margin:0;text-align:left}.feature-list li{padding:8px 0;font-size:16px;color:#4b5563}.upgrade-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.upgrade-modal{background:#fff;border-radius:16px;padding:32px;max-width:500px;width:100%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;position:relative;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:24px;color:#9ca3af;cursor:pointer;padding:4px;line-height:1;transition:color .2s}.modal-close:hover{color:#4b5563}.upgrade-modal h2{font-size:24px;font-weight:700;color:#1f2937;margin:24px 0 12px}.upgrade-message{font-size:16px;color:#6b7280;margin:0 0 24px;line-height:1.6}.upgrade-benefits{background:#f9fafb;border-radius:8px;padding:20px;margin-bottom:24px}.upgrade-benefits h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 16px}.upgrade-benefits ul{list-style:none;padding:0;margin:0}.upgrade-benefits li{padding:8px 0;font-size:16px;color:#4b5563;display:flex;align-items:center;gap:8px}.modal-actions{display:flex;gap:12px}.modal-actions button{flex:1;padding:12px 24px;font-size:16px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f3f4f6;color:#4b5563}.btn-secondary:hover{background:#e5e7eb}@media (max-width: 768px){.food-scanner{padding:12px}.food-scanner-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}.scanner-title{font-size:22px}.title-icon{font-size:28px}.quota-display-placeholder{width:100%;justify-content:center}.mode-tabs{width:100%;gap:8px;margin-bottom:20px}.mode-tab{padding:12px 16px;font-size:15px;min-height:44px}.scanner-content{padding:16px;border-radius:8px}.upgrade-modal{padding:20px;max-width:calc(100% - 32px)}.upgrade-modal h2{font-size:20px}.upgrade-message{font-size:15px}.modal-actions{flex-direction:column;gap:10px}.modal-actions button{width:100%;min-height:44px}.idia-features-section{padding:16px;margin-top:24px}.idia-section-title{font-size:20px}.health-advisor-section{padding:16px;margin-top:24px}.photo-mode,.barcode-mode{max-height:calc(100vh - 300px);overflow-y:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 480px){.food-scanner{padding:8px}.scanner-title{font-size:18px}.title-icon{font-size:22px}.mode-tab{font-size:14px;padding:10px 12px}.quota-display-placeholder{font-size:12px;padding:6px 10px}.scanner-content{padding:12px}.upgrade-modal{padding:16px}.upgrade-modal h2{font-size:18px;margin:16px 0 8px}.upgrade-benefits{padding:12px}.upgrade-benefits h3{font-size:16px}.upgrade-benefits li{font-size:14px}.idia-section-title{font-size:18px}}@media (orientation: landscape) and (max-height: 600px){.photo-mode,.barcode-mode{max-height:calc(100vh - 200px)}.upgrade-modal{max-height:90vh;overflow-y:auto}}@media (pointer: coarse){.mode-tab{min-height:44px;min-width:44px}.modal-close{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.btn-primary,.btn-secondary{min-height:44px}.calendar-nav-btn{min-width:44px;min-height:44px}}@media (prefers-reduced-motion: reduce){.upgrade-modal{animation:none}.btn-primary:hover,.btn-secondary:hover{transform:none}}@media (prefers-contrast: high){.mode-tab{border-width:2px}.mode-tab.active{border-bottom-width:4px}.scanner-content{border:2px solid #000}}*:focus{outline:3px solid #0066cc;outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:3px solid #0066cc;outline-offset:2px}button:focus-visible,a:focus-visible{outline:3px solid #0066cc;outline-offset:2px;box-shadow:0 0 0 4px #06c3}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid #0066cc;outline-offset:2px;border-color:#06c}@media (prefers-contrast: high){body{background-color:#000;color:#fff}button,.btn-primary,.btn-secondary{border:2px solid currentColor;background-color:transparent;color:inherit}button:hover,.btn-primary:hover,.btn-secondary:hover{background-color:#fff;color:#000}a{color:#0ff;text-decoration:underline}a:hover{color:#ff0}.progress-bar,.nutrition-progress-bar,.quota-progress-fill{background-color:#0f0;border:1px solid currentColor}.status-optimal,.nutrition-progress-optimal{background-color:#0f0;color:#000}.status-under,.nutrition-progress-under{background-color:#ff0;color:#000}.status-over,.nutrition-progress-over{background-color:red;color:#fff}.upgrade-modal-overlay,.membership-upgrade-modal-overlay{background-color:#000000f2}.nutrition-card,.tier-card,.scan-item{border:2px solid currentColor;background-color:transparent}[aria-hidden=true]{opacity:.7}}:root{--color-text-primary: #1a1a1a;--color-text-secondary: #4a4a4a;--color-background: #ffffff;--color-primary: #0066cc;--color-primary-hover: #0052a3;--color-success: #008000;--color-warning: #cc6600;--color-error: #cc0000;--color-border: #cccccc;--color-focus: #0066cc}@media (prefers-color-scheme: dark){:root{--color-text-primary: #ffffff;--color-text-secondary: #cccccc;--color-background: #1a1a1a;--color-primary: #3399ff;--color-primary-hover: #66b3ff;--color-success: #00cc00;--color-warning: #ff9933;--color-error: #ff3333;--color-border: #4a4a4a;--color-focus: #3399ff}body{background-color:var(--color-background);color:var(--color-text-primary)}.food-scanner,.barcode-scanner,.history-viewer,.daily-nutrition-tracker{color:var(--color-text-primary)}.btn-primary{background-color:var(--color-primary);color:#fff;border:2px solid var(--color-primary)}.btn-primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background-color:transparent;color:var(--color-text-primary);border:2px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-border)}.nutrition-card,.tier-card,.scan-item,.dr-zenie-speech-bubble{background-color:#2a2a2a;border-color:var(--color-border)}.progress-bar-container,.nutrition-progress,.quota-progress-bar{background-color:#3a3a3a}.status-optimal,.nutrition-progress-optimal{background-color:var(--color-success);color:#000}.status-under,.nutrition-progress-under{background-color:var(--color-warning);color:#000}.status-over,.nutrition-progress-over{background-color:var(--color-error);color:#fff}}.status-optimal:before{content:"✓ ";font-weight:700}.status-under:before{content:"↓ ";font-weight:700}.status-over:before{content:"↑ ";font-weight:700}.nutrition-progress-optimal{background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,255,255,.1) 10px,rgba(255,255,255,.1) 20px)}.nutrition-progress-under{background-image:repeating-linear-gradient(-45deg,transparent,transparent 10px,rgba(0,0,0,.1) 10px,rgba(0,0,0,.1) 20px)}.nutrition-progress-over{background-image:repeating-linear-gradient(90deg,transparent,transparent 10px,rgba(255,255,255,.2) 10px,rgba(255,255,255,.2) 20px)}.skip-to-main{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:8px 16px;text-decoration:none;z-index:10000}.skip-to-main:focus{top:0}[role=tab]{position:relative}[role=tab][aria-selected=true]:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background-color:var(--color-primary)}.calendar-day:focus-visible{outline:3px solid var(--color-focus);outline-offset:-3px;z-index:1}.sr-only-focusable:focus,.sr-only-focusable:active{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.dr-zenie-animated,.dr-zenie-animating{animation:none!important;transition:none!important}.progress-bar,.nutrition-progress-bar,.quota-progress-fill{transition:none!important}}@media (max-width: 768px){button,a,input[type=button],input[type=submit],.calendar-day{min-width:44px;min-height:44px;padding:12px}.mode-tab{min-height:44px;padding:12px 16px}.calendar-day{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}}[role=alert],.error-message,.quota-warning-message,.quota-limit-message{border-left:4px solid var(--color-error);padding-left:12px;font-weight:600}.quota-warning-message{border-left-color:var(--color-warning)}[role=status][aria-live=polite],.scanner-loading,.quota-loading{display:flex;align-items:center;gap:8px}[role=status][aria-live=polite]:before,.scanner-loading:before,.quota-loading:before{content:"";display:inline-block;width:16px;height:16px;border:2px solid var(--color-primary);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){[role=status][aria-live=polite]:before,.scanner-loading:before,.quota-loading:before{animation:none;border-top-color:var(--color-primary)}}[aria-live=polite],[aria-live=assertive]{position:relative}.quota-display[aria-live=polite]{transition:background-color .3s ease}.quota-display[aria-live=polite].quota-updated{background-color:#0066cc1a}.scan-result-announcement[aria-live=polite]{padding:12px;border-radius:8px;background-color:#0080001a;border-left:4px solid var(--color-success);margin:12px 0}button,a,[role=button],[role=tab],[role=menuitem]{cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease}button:hover:not(:disabled),a:hover,[role=button]:hover,[role=tab]:hover,[role=menuitem]:hover{transform:translateY(-1px)}button:active:not(:disabled),[role=button]:active,[role=tab]:active,[role=menuitem]:active{transform:translateY(0)}button:disabled,[role=button][aria-disabled=true]{opacity:.5;cursor:not-allowed}.modal-overlay[role=dialog]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000}.modal-overlay[role=dialog]:focus{outline:none}.modal-overlay[role=dialog] button:first-of-type:focus,.modal-overlay[role=dialog] button:last-of-type:focus{outline:3px solid var(--color-focus);outline-offset:2px}table[role=table]{border-collapse:collapse;width:100%}table[role=table] th,table[role=table] td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--color-border)}table[role=table] th{font-weight:600;background-color:#0000000d}@media (prefers-color-scheme: dark){table[role=table] th{background-color:#ffffff0d}}label{display:block;margin-bottom:4px;font-weight:500}input[type=text],input[type=email],input[type=number],select,textarea{width:100%;padding:8px 12px;border:2px solid var(--color-border);border-radius:4px;font-size:16px}input[type=text]:focus,input[type=email]:focus,input[type=number]:focus,select:focus,textarea:focus{border-color:var(--color-focus);outline:3px solid rgba(0,102,204,.2);outline-offset:0}input[aria-invalid=true],select[aria-invalid=true],textarea[aria-invalid=true]{border-color:var(--color-error)}input[aria-invalid=true]:focus,select[aria-invalid=true]:focus,textarea[aria-invalid=true]:focus{outline-color:#c003}img:not([alt]){border:3px solid var(--color-error)}img[alt=""],img[role=presentation]{border:none}video[aria-label],.camera-preview[aria-label]{border:2px solid var(--color-border);border-radius:8px}[role=tooltip]{position:absolute;z-index:1000;padding:8px 12px;background-color:#333;color:#fff;border-radius:4px;font-size:14px;max-width:200px}[role=tooltip]:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.idia-badge,.status-badge,.coming-soon-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.idia-badge{background-color:var(--color-success);color:#fff}.coming-soon-badge{background-color:var(--color-warning);color:#000}@media print{button,.mode-tabs,.scanner-controls,.dr-zenie-container{display:none}body{background:#fff;color:#000}a[href]:after{content:" (" attr(href) ")"}.nutrition-label,.daily-nutrition-tracker,.history-viewer{page-break-inside:avoid}}.admin-dashboard{max-width:1400px;margin:0 auto;padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.dashboard-header h1{font-size:2rem;font-weight:600;color:#333;margin:0}.refresh-button{padding:.75rem 1.5rem;background-color:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.refresh-button:hover{background-color:#357abd}.refresh-button:active{transform:scale(.98)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.dashboard-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s}.dashboard-card:hover{box-shadow:0 4px 12px #00000026}.dashboard-card.wide{grid-column:span 2}.dashboard-card h2{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.metrics-list{display:flex;flex-direction:column;gap:1rem}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f8f9fa;border-radius:6px;transition:background-color .2s}.metric-item:hover{background-color:#e9ecef}.metric-label{font-size:1rem;color:#555;font-weight:500}.metric-value{font-size:1.5rem;font-weight:700;color:#4a90e2}.tools-list{overflow-x:auto}.tools-table{width:100%;border-collapse:collapse}.tools-table thead{background-color:#f8f9fa}.tools-table th{padding:.75rem;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #e0e0e0}.tools-table td{padding:.75rem;border-bottom:1px solid #f0f0f0}.tools-table tbody tr:hover{background-color:#f8f9fa}.tools-table tbody tr:last-child td{border-bottom:none}.empty-message{text-align:center;color:#999;padding:2rem;font-style:italic}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.loading-spinner{width:50px;height:50px;border:4px solid #f0f0f0;border-top:4px solid #4a90e2;border-radius:50%;animation:spin 1s linear infinite}.loading-container p{font-size:1.125rem;color:#666}.access-denied{text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.access-denied h1{font-size:2rem;color:#e74c3c;margin-bottom:1rem}.access-denied p{font-size:1.125rem;color:#666}.error-container{text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.error-container h1{font-size:2rem;color:#e74c3c;margin-bottom:1rem}.error-container p{font-size:1.125rem;color:#666;margin-bottom:2rem}.error-container button{padding:.75rem 1.5rem;background-color:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.error-container button:hover{background-color:#357abd}@media (max-width: 768px){.admin-dashboard{padding:1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-grid{grid-template-columns:1fr}.dashboard-card.wide{grid-column:span 1}.metric-value{font-size:1.25rem}.tools-table{font-size:.875rem}}.cms-dashboard{padding:2rem;max-width:1400px;margin:0 auto;background:#f8fafc;min-height:100vh}.cms-dashboard.loading,.cms-dashboard.error{display:flex;align-items:center;justify-content:center;min-height:60vh}.loading-spinner{font-size:1.2rem;color:#6b7280}.error-message{text-align:center;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.error-message h3{color:#dc2626;margin-bottom:1rem}.error-message p{color:#6b7280;margin-bottom:1.5rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.dashboard-header p{font-size:1.1rem;color:#6b7280}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:2.5rem;margin-right:1rem}.stat-info h3{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.stat-info p{font-size:.9rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.stat-card.total-content .stat-icon{color:#3b82f6}.stat-card.published-content .stat-icon{color:#10b981}.stat-card.draft-content .stat-icon{color:#f59e0b}.stat-card.recent-activity .stat-icon{color:#8b5cf6}.quick-actions{margin-bottom:2rem}.quick-actions h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:1.5rem}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.action-btn{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;text-decoration:none;color:inherit}.action-btn:hover{border-color:#3b82f6;background:#f8fafc;transform:translateY(-2px)}.action-icon{font-size:2rem;margin-bottom:.5rem}.action-text{font-size:.9rem;font-weight:500;color:#374151}.dashboard-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.content-types-stats h2,.recent-content h2,.recent-activity h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1.5rem}.content-types-list{space-y:.5rem}.content-type-item{display:flex;align-items:center;padding:.75rem;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.content-type-item:hover{background:#f3f4f6}.type-icon{font-size:1.25rem;margin-right:.75rem}.type-name{flex:1;font-weight:500;color:#374151}.type-count{font-weight:600;color:#6b7280;background:#f3f4f6;padding:.25rem .5rem;border-radius:12px;font-size:.875rem}.content-list{space-y:.75rem}.content-item{display:flex;align-items:center;padding:1rem;border-radius:8px;cursor:pointer;transition:background-color .2s ease;border:1px solid #e5e7eb}.content-item:hover{background:#f9fafb;border-color:#d1d5db}.content-icon{font-size:1.5rem;margin-right:1rem}.content-info{flex:1}.content-info h4{font-size:1rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.content-meta{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.content-status{font-weight:500}.content-date{font-size:.75rem;color:#9ca3af}.content-actions{display:flex;gap:.5rem}.btn-icon{padding:.5rem;background:none;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.btn-icon:hover{background:#f3f4f6}.empty-state{text-align:center;padding:2rem;color:#6b7280}.empty-state p{margin-bottom:1rem}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.btn-primary:hover{background:#2563eb}.activity-list{space-y:.75rem}.activity-item{display:flex;align-items:center;padding:.75rem;border-radius:8px;background:#f9fafb}.activity-icon{font-size:1.25rem;margin-right:.75rem}.activity-info{flex:1}.activity-description{font-size:.875rem;color:#374151;margin-bottom:.25rem}.activity-description strong{font-weight:600}.activity-description em{font-style:italic;color:#6b7280}.activity-time{font-size:.75rem;color:#9ca3af}@media (max-width: 1024px){.dashboard-content{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 768px){.cms-dashboard{padding:1rem}.dashboard-header h1{font-size:2rem}.action-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stats-grid{grid-template-columns:1fr}}@media (max-width: 480px){.action-grid{grid-template-columns:1fr 1fr}.action-btn{padding:1rem}.action-icon{font-size:1.5rem}.action-text{font-size:.8rem}}.content-editor{max-width:1000px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.editor-header h2{font-size:1.75rem;font-weight:600;color:#1f2937}.editor-actions{display:flex;gap:1rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.editor-content{space-y:2rem}.editor-section{margin-bottom:2rem}.editor-section h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.field-group{margin-bottom:1.5rem}.field-group label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem}.field-group input,.field-group textarea,.field-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease}.field-group input:focus,.field-group textarea:focus,.field-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.field-group textarea{resize:vertical;min-height:100px}.bilingual-input{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.bilingual-input input,.bilingual-input textarea{width:100%}.tag-input{border:1px solid #d1d5db;border-radius:8px;padding:.5rem;min-height:2.5rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.tag-input:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-flex;align-items:center;background:#e0e7ff;color:#3730a3;padding:.25rem .5rem;border-radius:6px;font-size:.875rem;font-weight:500}.tag-remove{background:none;border:none;color:#6366f1;margin-left:.25rem;cursor:pointer;font-size:1rem;line-height:1;padding:0;width:1rem;height:1rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.tag-remove:hover{background:#6366f133}.tag-input-field{flex:1;border:none;outline:none;padding:.25rem;min-width:120px}.field-note{color:#6b7280;font-style:italic;padding:1rem;background:#f9fafb;border-radius:8px;border-left:4px solid #e5e7eb}@media (max-width: 768px){.content-editor{padding:1rem;margin:1rem}.editor-header{flex-direction:column;gap:1rem;align-items:stretch}.editor-actions{justify-content:stretch}.btn-primary,.btn-secondary{flex:1}.bilingual-input{grid-template-columns:1fr}}@media (max-width: 480px){.content-editor{margin:.5rem}.editor-header h2{font-size:1.5rem}.editor-actions{flex-direction:column}}.content-list{padding:2rem;max-width:1400px;margin:0 auto}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.list-header h2{font-size:2rem;font-weight:600;color:#1f2937}.bulk-actions{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f3f4f6;border-radius:8px}.selected-count{font-weight:500;color:#374151}.btn-bulk{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-bulk.publish{background:#10b981;color:#fff}.btn-bulk.publish:hover{background:#059669}.btn-bulk.archive{background:#6b7280;color:#fff}.btn-bulk.archive:hover{background:#4b5563}.btn-bulk.delete{background:#dc2626;color:#fff}.btn-bulk.delete:hover{background:#b91c1c}.list-filters{display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.search-box{display:flex;flex:1;max-width:400px}.search-box input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-right:none;border-radius:8px 0 0 8px;font-size:1rem}.search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-btn{padding:.75rem 1rem;background:#3b82f6;color:#fff;border:1px solid #3b82f6;border-radius:0 8px 8px 0;cursor:pointer;transition:background-color .2s ease}.search-btn:hover{background:#2563eb}.filter-controls{display:flex;gap:1rem}.filter-controls select{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer}.filter-controls select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.list-table{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-header{display:grid;grid-template-columns:50px 120px 1fr 100px 80px 120px 150px;gap:1rem;padding:1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.table-row{display:grid;grid-template-columns:50px 120px 1fr 100px 80px 120px 150px;gap:1rem;padding:1rem;border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.table-row:hover{background:#f9fafb}.table-row:last-child{border-bottom:none}.table-cell{display:flex;align-items:center}.checkbox-cell{justify-content:center}.checkbox-cell input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.type-cell{gap:.5rem}.type-icon{font-size:1.25rem}.type-name{font-size:.875rem;color:#6b7280}.title-cell{flex-direction:column;align-items:flex-start}.title-cell h4{font-size:1rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.title-cell .description{font-size:.875rem;color:#6b7280;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.05em}.tier-cell,.date-cell{font-size:.875rem;color:#6b7280}.actions-cell{gap:.5rem}.action-btn{padding:.5rem;background:none;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease;font-size:1rem}.action-btn:hover{background:#f3f4f6}.action-btn.delete:hover{background:#fef2f2}.action-btn.publish:hover{background:#f0fdf4}.load-more{text-align:center;margin-top:2rem}.btn-load-more{padding:.75rem 2rem;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-load-more:hover:not(:disabled){background:#e5e7eb}.btn-load-more:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1200px){.table-header,.table-row{grid-template-columns:50px 100px 1fr 80px 60px 100px 120px}.type-name{display:none}}@media (max-width: 768px){.content-list{padding:1rem}.list-filters{flex-direction:column}.filter-controls{flex-wrap:wrap}.list-table{overflow-x:auto}.table-header,.table-row{min-width:800px}.bulk-actions{flex-wrap:wrap;gap:.5rem}.btn-bulk{font-size:.75rem;padding:.375rem .75rem}}@media (max-width: 480px){.list-header{flex-direction:column;gap:1rem;align-items:stretch}.list-header h2{font-size:1.5rem}.search-box{max-width:none}}.media-manager{padding:2rem;max-width:1400px;margin:0 auto}.media-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.media-header h2{font-size:2rem;font-weight:600;color:#1f2937}.media-actions{display:flex;gap:1rem}.btn-upload,.btn-confirm{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-upload{background:#3b82f6;color:#fff}.btn-upload:hover:not(:disabled){background:#2563eb}.btn-upload:disabled{background:#9ca3af;cursor:not-allowed}.btn-confirm{background:#10b981;color:#fff}.btn-confirm:hover{background:#059669}.media-filters{margin-bottom:2rem}.media-filters select{padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer}.media-filters select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.drop-zone{border:2px dashed #d1d5db;border-radius:12px;padding:3rem;text-align:center;margin-bottom:2rem;transition:all .2s ease;background:#fafafa}.drop-zone.drag-over{border-color:#3b82f6;background:#f0f9ff}.drop-zone-content{pointer-events:none}.drop-icon{font-size:3rem;margin-bottom:1rem}.drop-zone p{color:#6b7280;margin-bottom:.5rem}.drop-hint{font-size:.875rem;color:#9ca3af}.loading-state,.empty-state{text-align:center;padding:3rem;color:#6b7280}.loading-spinner{font-size:1.2rem}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.media-item{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;cursor:pointer;transition:all .2s ease;position:relative}.media-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.media-item.selected{border:2px solid #3b82f6;box-shadow:0 0 0 3px #3b82f61a}.media-preview{position:relative;width:100%;height:150px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;overflow:hidden}.media-preview img{width:100%;height:100%;object-fit:cover}.file-icon{font-size:3rem;color:#6b7280}.selection-indicator{position:absolute;top:.5rem;right:.5rem;width:1.5rem;height:1.5rem;background:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.media-info{padding:1rem}.file-name{font-size:.875rem;font-weight:600;color:#1f2937;margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.file-date{font-size:.75rem;color:#9ca3af}.media-actions{position:absolute;top:.5rem;left:.5rem;display:flex;gap:.25rem;opacity:0;transition:opacity .2s ease}.media-item:hover .media-actions{opacity:1}.action-btn{width:2rem;height:2rem;background:#ffffffe6;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.action-btn:hover{background:#fff;transform:scale(1.1)}.action-btn.delete:hover{background:#fef2f2;color:#dc2626}@media (max-width: 768px){.media-manager{padding:1rem}.media-header{flex-direction:column;gap:1rem;align-items:stretch}.media-actions{justify-content:stretch}.btn-upload,.btn-confirm{flex:1}.media-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.drop-zone{padding:2rem 1rem}.drop-icon{font-size:2rem}}@media (max-width: 480px){.media-header h2{font-size:1.5rem}.media-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.media-preview{height:100px}.file-icon{font-size:2rem}.media-info{padding:.75rem}.media-actions{position:static;opacity:1;justify-content:center;padding:.5rem;background:#f9fafb;border-top:1px solid #e5e7eb}}.cms-container{min-height:100vh;background:#f8fafc}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.access-denied h2{font-size:2rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.access-denied p{font-size:1.1rem;color:#6b7280}.cms-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}.cms-title h1{font-size:1.75rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.cms-title p{font-size:.875rem;color:#6b7280}.cms-nav{display:flex;gap:.5rem}.nav-item{padding:.75rem 1.5rem;background:none;border:none;border-radius:8px;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.nav-item:hover{background:#f3f4f6;color:#374151}.nav-item.active{background:#3b82f6;color:#fff}.nav-item.active:hover{background:#2563eb}.breadcrumb{padding:1rem 2rem;background:#fff;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;gap:.5rem}.breadcrumb-item{background:none;border:none;color:#6b7280;cursor:pointer;font-size:.875rem;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease}.breadcrumb-item:hover:not(.active){background:#f3f4f6;color:#374151}.breadcrumb-item.active{color:#1f2937;font-weight:500;cursor:default}.breadcrumb-separator{color:#d1d5db;font-size:.875rem;-webkit-user-select:none;user-select:none}.cms-main{background:#f8fafc;min-height:calc(100vh - 140px)}@media (max-width: 1024px){.cms-header{flex-direction:column;gap:1rem;align-items:stretch}.cms-nav{justify-content:center}}@media (max-width: 768px){.cms-header{padding:1rem}.cms-title h1{font-size:1.5rem}.breadcrumb{padding:.75rem 1rem;flex-wrap:wrap}.cms-nav{flex-wrap:wrap;gap:.25rem}.nav-item{padding:.5rem 1rem;font-size:.8rem}}@media (max-width: 480px){.cms-header{padding:.75rem}.cms-title h1{font-size:1.25rem}.cms-title p{font-size:.8rem}.breadcrumb{padding:.5rem .75rem}.breadcrumb-item{font-size:.8rem;padding:.125rem .25rem}.nav-item{flex:1;justify-content:center;padding:.5rem .75rem}}.app{min-height:100vh;display:flex;flex-direction:column;position:relative;padding-top:140px}@media (max-width: 768px){.app{padding-top:110px}}.app-main{flex:1;padding:var(--spacing-xl) var(--spacing-lg);position:relative;z-index:0}.app-content{animation:fadeIn .4s ease-in}.app-footer{background-color:var(--color-white);padding:var(--spacing-lg);text-align:center;color:var(--color-gray-dark);border-top:1px solid var(--color-cream-dark);margin-top:var(--spacing-2xl)}.app-footer p{margin:0;font-size:var(--font-size-sm)}.app-footer-link{color:var(--color-gold);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.app-footer-link:hover{color:var(--color-coffee-darker);text-decoration:underline}@font-face{font-family:Qurova;src:url(/fonts/QurovaDEMO-Light.otf) format("opentype");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:Qurova;src:url(/fonts/QurovaDEMO-Regular.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Qurova;src:url(/fonts/QurovaDEMO-Medium.otf) format("opentype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Qurova;src:url(/fonts/QurovaDEMO-SemiBold.otf) format("opentype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Qurova;src:url(/fonts/QurovaDEMO-Bold.otf) format("opentype");font-weight:700;font-style:normal;font-display:swap}:root{--color-cream: #F5F1E8;--color-cream-dark: #EDE7D9;--color-coffee: #8B7355;--color-coffee-dark: #6B5745;--color-coffee-darker: #4B3F35;--color-dark: #2C2C2C;--color-gold: #D4AF37;--color-gold-light: #E5C158;--color-green: #7C9885;--color-red: #C85A54;--color-success: #4CAF50;--color-warning: #FF9800;--color-error: #F44336;--color-info: #2196F3;--gray-50: #FAFAFA;--gray-100: #F5F5F5;--gray-200: #EEEEEE;--gray-300: #E0E0E0;--gray-400: #BDBDBD;--gray-500: #9E9E9E;--gray-600: #757575;--gray-700: #616161;--gray-800: #424242;--gray-900: #212121;--font-family-serif-zh: "Noto Serif TC", "思源宋體", serif;--font-family-sans-zh: "Noto Sans TC", "思源黑體", sans-serif;--font-family-serif-en: "Playfair Display", "Georgia", serif;--font-family-sans-en: "Inter", "Helvetica Neue", sans-serif;--font-family-mono: "Fira Code", "Consolas", monospace;--font-family-heading: var(--font-family-serif-zh);--font-family-base: var(--font-family-sans-zh);--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--letter-spacing-wider: .1em;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 2.5rem;--spacing-3xl: 3rem;--spacing-4xl: 4rem;--spacing-5xl: 5rem;--spacing-6xl: 6rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-hover: 0 12px 20px -5px rgba(139, 115, 85, .2);--shadow-gold: 0 8px 20px rgba(212, 175, 55, .4);--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--duration-fast: .2s;--duration-normal: .3s;--duration-slow: .4s;--ease-out: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-in-out: cubic-bezier(.4, 0, .6, 1);--transition-fast: all var(--duration-fast) var(--ease-out);--transition-normal: all var(--duration-normal) var(--ease-out);--transition-slow: all var(--duration-slow) var(--ease-out);--breakpoint-mobile: 480px;--breakpoint-tablet: 768px;--breakpoint-desktop: 1024px;--breakpoint-wide: 1280px;--z-index-dropdown: 1000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070}@media (min-width: 1024px){:root{--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem}}@media (min-width: 768px) and (max-width: 1023px){:root{--font-size-base: .9375rem;--font-size-lg: 1.0625rem;--font-size-xl: 1.125rem;--font-size-2xl: 1.375rem;--font-size-3xl: 1.625rem;--font-size-4xl: 2rem;--font-size-5xl: 2.5rem}}@media (max-width: 767px){:root{--font-size-base: .875rem;--font-size-lg: 1rem;--font-size-xl: 1.0625rem;--font-size-2xl: 1.25rem;--font-size-3xl: 1.5rem;--font-size-4xl: 1.75rem;--font-size-5xl: 2.25rem}}@media (min-width: 1024px){:root{--spacing-section: var(--spacing-3xl);--spacing-card: var(--spacing-xl)}}@media (min-width: 768px) and (max-width: 1023px){:root{--spacing-section: var(--spacing-2xl);--spacing-card: var(--spacing-lg)}}@media (max-width: 767px){:root{--spacing-section: var(--spacing-xl);--spacing-card: var(--spacing-md)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{margin:0;padding:0;min-height:100vh;line-height:1.5}h1,h2,h3,h4,h5,h6{margin:0;padding:0;font-size:inherit;font-weight:inherit}p{margin:0;padding:0}ul,ol{margin:0;padding:0;list-style:none}a{color:inherit;text-decoration:none;background-color:transparent}a:hover{text-decoration:none}button,input,optgroup,select,textarea{margin:0;padding:0;font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;background:transparent;border:none;outline:none}button{cursor:pointer;background:none;border:none;padding:0}button:disabled{cursor:not-allowed}input:focus,textarea:focus,select:focus{outline:none}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}img{border-style:none}table{border-collapse:collapse;border-spacing:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:focus-visible{outline:2px solid var(--color-gold);outline-offset:2px}:focus:not(:focus-visible){outline:none}::selection{background-color:var(--color-gold);color:#fff}::-moz-selection{background-color:var(--color-gold);color:#fff}.container-fluid{width:100%;padding:0 var(--spacing-lg)}.container-narrow{width:100%;max-width:800px;margin:0 auto;padding:0 var(--spacing-lg)}.d-none{display:none}.d-block{display:block}.d-inline{display:inline}.d-inline-block{display:inline-block}.d-flex{display:flex}.d-inline-flex{display:inline-flex}.d-grid{display:grid}.flex-row{flex-direction:row}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.align-start{align-items:flex-start}.align-end{align-items:flex-end}.align-center{align-items:center}.align-stretch{align-items:stretch}.flex-1{flex:1}.flex-auto{flex:auto}.flex-none{flex:none}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.gap-2xl{gap:var(--spacing-2xl)}.m-0{margin:0}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.m-2xl{margin:var(--spacing-2xl)}.m-3xl{margin:var(--spacing-3xl)}.mt-0{margin-top:0}.mt-xs{margin-top:var(--spacing-xs)}.mt-2xl{margin-top:var(--spacing-2xl)}.mt-3xl{margin-top:var(--spacing-3xl)}.mb-0{margin-bottom:0}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-2xl{margin-bottom:var(--spacing-2xl)}.mb-3xl{margin-bottom:var(--spacing-3xl)}.ml-0{margin-left:0}.ml-xs{margin-left:var(--spacing-xs)}.ml-sm{margin-left:var(--spacing-sm)}.ml-md{margin-left:var(--spacing-md)}.ml-lg{margin-left:var(--spacing-lg)}.ml-xl{margin-left:var(--spacing-xl)}.ml-auto{margin-left:auto}.mr-0{margin-right:0}.mr-xs{margin-right:var(--spacing-xs)}.mr-sm{margin-right:var(--spacing-sm)}.mr-md{margin-right:var(--spacing-md)}.mr-lg{margin-right:var(--spacing-lg)}.mr-xl{margin-right:var(--spacing-xl)}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-xs{padding:var(--spacing-xs)}.p-2xl{padding:var(--spacing-2xl)}.p-3xl{padding:var(--spacing-3xl)}.pt-0{padding-top:0}.pt-xs{padding-top:var(--spacing-xs)}.pt-sm{padding-top:var(--spacing-sm)}.pt-md{padding-top:var(--spacing-md)}.pt-lg{padding-top:var(--spacing-lg)}.pt-xl{padding-top:var(--spacing-xl)}.pt-2xl{padding-top:var(--spacing-2xl)}.pt-3xl{padding-top:var(--spacing-3xl)}.pb-0{padding-bottom:0}.pb-xs{padding-bottom:var(--spacing-xs)}.pb-sm{padding-bottom:var(--spacing-sm)}.pb-md{padding-bottom:var(--spacing-md)}.pb-lg{padding-bottom:var(--spacing-lg)}.pb-xl{padding-bottom:var(--spacing-xl)}.pb-2xl{padding-bottom:var(--spacing-2xl)}.pb-3xl{padding-bottom:var(--spacing-3xl)}.pl-0{padding-left:0}.pl-xs{padding-left:var(--spacing-xs)}.pl-sm{padding-left:var(--spacing-sm)}.pl-md{padding-left:var(--spacing-md)}.pl-lg{padding-left:var(--spacing-lg)}.pl-xl{padding-left:var(--spacing-xl)}.pr-0{padding-right:0}.pr-xs{padding-right:var(--spacing-xs)}.pr-sm{padding-right:var(--spacing-sm)}.pr-md{padding-right:var(--spacing-md)}.pr-lg{padding-right:var(--spacing-lg)}.pr-xl{padding-right:var(--spacing-xl)}.text-left{text-align:left}.text-justify{text-align:justify}.font-light{font-weight:var(--font-weight-light)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.text-5xl{font-size:var(--font-size-5xl)}.italic{font-style:italic}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.text-cream{color:var(--color-cream)}.text-coffee{color:var(--color-coffee)}.text-coffee-dark{color:var(--color-coffee-dark)}.text-coffee-darker{color:var(--color-coffee-darker)}.text-gold{color:var(--color-gold)}.text-green{color:var(--color-green)}.text-red{color:var(--color-red)}.bg-cream{background-color:var(--color-cream)}.bg-cream-dark{background-color:var(--color-cream-dark)}.bg-coffee{background-color:var(--color-coffee)}.bg-gold{background-color:var(--color-gold)}.bg-white{background-color:#fff}.border{border:1px solid var(--gray-300)}.border-0{border:none}.border-t{border-top:1px solid var(--gray-300)}.border-b{border-bottom:1px solid var(--gray-300)}.border-l{border-left:1px solid var(--gray-300)}.border-r{border-right:1px solid var(--gray-300)}.border-gold{border-color:var(--color-gold)}.border-coffee{border-color:var(--color-coffee)}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-hover{box-shadow:var(--shadow-hover)}.shadow-gold{box-shadow:var(--shadow-gold)}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.inset-0{top:0;right:0;bottom:0;left:0}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.cursor-auto{cursor:auto}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.transition-fast{transition:var(--transition-fast)}.transition-normal{transition:var(--transition-normal)}.transition-slow{transition:var(--transition-slow)}@media (max-width: 767px){.hide-mobile{display:none!important}}@media (min-width: 768px) and (max-width: 1023px){.hide-tablet{display:none!important}}@media (min-width: 1024px){.hide-desktop{display:none!important}}@media (min-width: 768px){.show-mobile-only{display:none!important}}@media (max-width: 767px),(min-width: 1024px){.show-tablet-only{display:none!important}}@media (max-width: 1023px){.show-desktop-only{display:none!important}}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.touch-target{min-width:44px;min-height:44px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--ease-out)}.animate-slide-up{animation:slideUp var(--duration-normal) var(--ease-out)}.animate-scale-in{animation:scaleIn var(--duration-normal) var(--ease-out)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn var(--duration-normal) var(--ease-out)}.fade-in-fast{animation:fadeIn var(--duration-fast) var(--ease-out)}.fade-in-slow{animation:fadeIn var(--duration-slow) var(--ease-out)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp var(--duration-slow) var(--ease-out)}.slide-up-fast{animation:slideUp var(--duration-normal) var(--ease-out)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.slide-down{animation:slideDown var(--duration-normal) var(--ease-out)}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.slide-in-left{animation:slideInLeft var(--duration-normal) var(--ease-out)}.slide-in-right{animation:slideInRight var(--duration-normal) var(--ease-out)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.scale-in{animation:scaleIn var(--duration-normal) var(--ease-out)}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}.scale-out{animation:scaleOut var(--duration-fast) var(--ease-in)}.card-hoverable{transition:all var(--duration-normal) var(--ease-out);border:2px solid transparent}.card-hoverable:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:var(--color-gold)}.button-hoverable{transition:all var(--duration-fast) var(--ease-out)}.button-hoverable:hover{transform:translateY(-2px);box-shadow:var(--shadow-gold)}.button-hoverable:active{transform:translateY(0);box-shadow:var(--shadow-md)}.icon-hoverable{transition:transform var(--duration-normal) var(--ease-out);display:inline-block}.icon-hoverable:hover{transform:scale(1.15)}.link-hoverable{position:relative;transition:color var(--duration-fast) var(--ease-out)}.link-hoverable:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--color-gold);transition:width var(--duration-normal) var(--ease-out)}.link-hoverable:hover:after{width:100%}.image-hoverable{transition:transform var(--duration-slow) var(--ease-out);overflow:hidden}.image-hoverable img{transition:transform var(--duration-slow) var(--ease-out)}.image-hoverable:hover img{transform:scale(1.1)}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{background:linear-gradient(90deg,var(--gray-200) 0%,var(--gray-100) 50%,var(--gray-200) 100%);background-size:1000px 100%;animation:shimmer 2s infinite linear;border-radius:var(--radius-md)}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-title{height:1.5em;width:60%;margin-bottom:1em}.skeleton-avatar{width:48px;height:48px;border-radius:var(--radius-full)}.skeleton-card{height:200px;border-radius:var(--radius-lg)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite;display:inline-block}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.pulse{animation:pulse 2s ease-in-out infinite}@keyframes dotPulse{0%,80%,to{opacity:.3}40%{opacity:1}}.dots-loading{display:inline-flex;gap:4px}.dots-loading span{width:8px;height:8px;background:var(--color-coffee);border-radius:var(--radius-full);animation:dotPulse 1.4s infinite ease-in-out}.dots-loading span:nth-child(1){animation-delay:0s}.dots-loading span:nth-child(2){animation-delay:.2s}.dots-loading span:nth-child(3){animation-delay:.4s}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:all var(--duration-normal) var(--ease-out)}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.modal-enter{opacity:0;transform:scale(.9)}.modal-enter-active{opacity:1;transform:scale(1);transition:all var(--duration-normal) var(--ease-out)}.modal-exit{opacity:1;transform:scale(1)}.modal-exit-active{opacity:0;transform:scale(.9);transition:all var(--duration-fast) var(--ease-in)}.backdrop-enter{opacity:0}.backdrop-enter-active{opacity:1;transition:opacity var(--duration-normal) var(--ease-out)}.backdrop-exit{opacity:1}.backdrop-exit-active{opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}@keyframes slideInUnderline{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.tab-underline{animation:slideInUnderline var(--duration-normal) var(--ease-out);transform-origin:left}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.bounce{animation:bounce 1s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.shake{animation:shake .5s ease-in-out}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}.ripple-effect{position:relative;overflow:hidden}.ripple-effect:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;background:#ffffff80;border-radius:var(--radius-full);transform:translate(-50%,-50%) scale(0);pointer-events:none}.ripple-effect:active:after{animation:ripple .6s ease-out}@keyframes glow{0%,to{box-shadow:0 0 5px #d4af3780}50%{box-shadow:0 0 20px #d4af37cc}}.glow{animation:glow 2s ease-in-out infinite}.stagger-item{opacity:0;animation:fadeIn var(--duration-normal) var(--ease-out) forwards}.stagger-item:nth-child(1){animation-delay:0ms}.stagger-item:nth-child(2){animation-delay:50ms}.stagger-item:nth-child(3){animation-delay:.1s}.stagger-item:nth-child(4){animation-delay:.15s}.stagger-item:nth-child(5){animation-delay:.2s}.stagger-item:nth-child(6){animation-delay:.25s}.stagger-item:nth-child(7){animation-delay:.3s}.stagger-item:nth-child(8){animation-delay:.35s}.stagger-item:nth-child(9){animation-delay:.4s}.stagger-item:nth-child(10){animation-delay:.45s}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.card-hoverable:hover,.button-hoverable:hover,.icon-hoverable:hover,.image-hoverable:hover img{transform:none}}.animate-none{animation:none!important}.animate-pause{animation-play-state:paused!important}.animate-resume{animation-play-state:running!important}.transition-none{transition:none!important}.transition-fast{transition:var(--transition-fast)!important}.transition-normal{transition:var(--transition-normal)!important}.transition-slow{transition:var(--transition-slow)!important}.origin-center{transform-origin:center}.origin-top{transform-origin:top}.origin-bottom{transform-origin:bottom}.origin-left{transform-origin:left}.origin-right{transform-origin:right}.will-change-transform{will-change:transform}.will-change-opacity{will-change:opacity}.will-change-auto{will-change:auto}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-wide);color:var(--color-coffee-dark);background-color:var(--color-cream);min-height:100vh;font-weight:var(--font-weight-normal)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);color:var(--color-coffee-darker);margin-bottom:var(--spacing-lg)}h1{font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight)}h2{font-size:var(--font-size-4xl);font-weight:var(--font-weight-semibold)}h3{font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold)}h4{font-size:var(--font-size-2xl);font-weight:var(--font-weight-medium)}h5{font-size:var(--font-size-xl);font-weight:var(--font-weight-medium)}h6{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-coffee);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-gold)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-cream-dark)}::-webkit-scrollbar-thumb{background:var(--color-beige);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-coffee-light)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}
