*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #F97316;--primary-dk: #ea6a0a;--teal: #00BCD4;--dark: #1a1a2e;--bg: #ffffff;--surface: #ffffff;--surface-2: #f8f8fc;--border: #eeeeee;--muted: #8b8fa8;--danger: #ef4444;--success: #22c55e;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-pill: 50px;--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow-md: 0 4px 20px rgba(0,0,0,.1);--shadow-orange: 0 4px 16px rgba(249,115,22,.35);--nav-h: 68px;--header-h: 60px}html{height:100%;font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,sans-serif;background:var(--bg);color:var(--dark);min-height:100%;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}#root{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative;background:var(--bg)}.clouds-bg{position:fixed;top:0;right:0;bottom:0;pointer-events:none;z-index:0;overflow:hidden;max-width:480px;left:50%;transform:translate(-50%)}.clouds-bg img{position:absolute;width:200%;opacity:.18}.clouds-bg img:first-child{top:-20px;left:-50%}.clouds-bg img:last-child{bottom:-20px;left:-10%;transform:scaleX(-1)}.clouds-bg.prominent img{opacity:.55}.page{flex:1;padding:16px 16px calc(var(--nav-h) + 12px);position:relative;z-index:1}.page-scroll{overflow-y:auto}.app-header{position:sticky;top:0;height:var(--header-h);background:#ffffffeb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;z-index:50}.app-header .logo{flex:1}.app-header-actions{display:flex;gap:4px}.logo{display:inline-flex;align-items:center;gap:8px;text-decoration:none;cursor:default}.logo-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--teal);overflow:hidden;flex-shrink:0;background:#e8f9fc;display:flex;align-items:center;justify-content:center}.logo-avatar img{width:100%;height:100%;object-fit:cover}.logo-text{font-size:1.2rem;font-weight:800;line-height:1;letter-spacing:-.3px}.logo-text span:first-child{color:var(--dark)}.logo-text span:last-child{color:var(--primary);font-style:italic}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--nav-h);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:100;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 20px #0000000f}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;text-decoration:none;color:var(--muted);font-size:.68rem;font-weight:600;transition:color .15s;-webkit-tap-highlight-color:transparent;padding-top:4px}.bottom-nav a.active{color:var(--primary)}.bottom-nav a svg{width:24px;height:24px}.bottom-nav a.active svg{stroke:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-pill);font-size:.95rem;font-weight:700;border:none;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:active{transform:scale(.96)}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-orange)}.btn-primary:hover{background:var(--primary-dk)}.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary);box-shadow:none}.btn-ghost{background:var(--surface-2);color:var(--dark);box-shadow:none}.btn-ghost:hover{background:#efefef}.btn-danger{background:var(--danger);color:#fff}.btn-full{width:100%}.btn-sm{padding:8px 16px;font-size:.82rem}.btn-icon{padding:0;width:36px;height:36px;border-radius:50%;background:var(--surface-2);color:var(--dark);display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;flex-shrink:0;transition:background .15s,transform .1s}.btn-icon:active{transform:scale(.9)}.btn-icon svg{width:18px;height:18px}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap .input-icon{position:absolute;left:14px;color:var(--muted);pointer-events:none;display:flex;align-items:center}.input-wrap .input-icon svg{width:18px;height:18px}input,textarea,select{width:100%;padding:12px 16px;background:var(--surface-2);border:1.5px solid transparent;border-radius:var(--radius-sm);font-size:.95rem;color:var(--dark);outline:none;transition:border-color .15s,background .15s;font-family:inherit}.input-wrap input{padding-left:42px}input:focus,textarea:focus,select:focus{border-color:var(--primary);background:#fff}input::placeholder,textarea::placeholder{color:var(--muted)}textarea{resize:vertical;min-height:80px}.card{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border)}.recipe-card{cursor:pointer;transition:transform .15s,box-shadow .15s}.recipe-card:active{transform:scale(.97)}.recipe-card__img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--surface-2)}.recipe-card__body{padding:10px 12px 12px}.recipe-card__title{font-size:.88rem;font-weight:700;line-height:1.3;color:var(--dark)}.recipe-card__meta{font-size:.73rem;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:6px}.recipe-card__meta svg{width:12px;height:12px}.recipe-card-h{display:flex;gap:12px;align-items:center;padding:12px;cursor:pointer;border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:transform .15s}.recipe-card-h:active{transform:scale(.97)}.recipe-card-h img{width:64px;height:64px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--surface-2)}.recipe-card-h__info{flex:1;min-width:0}.recipe-card-h__title{font-size:.88rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recipe-card-h__meta{font-size:.72rem;color:var(--muted);margin-top:3px}.recipe-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.fav-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.fav-scroll::-webkit-scrollbar{display:none}.fav-card{flex-shrink:0;width:100px;cursor:pointer;transition:transform .15s}.fav-card:active{transform:scale(.95)}.fav-card img{width:100px;height:80px;border-radius:var(--radius-sm);object-fit:cover;display:block;background:var(--surface-2)}.fav-card p{font-size:.72rem;font-weight:600;text-align:center;margin-top:4px;color:var(--dark)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-header h2{font-size:1rem;font-weight:800;color:var(--dark)}.section-header a,.section-header button{font-size:.8rem;font-weight:700;color:var(--primary);background:none;border:none;cursor:pointer;text-decoration:none}.greeting{margin-bottom:20px}.greeting h1{font-size:1.4rem;font-weight:800;color:var(--dark)}.greeting p{font-size:.88rem;color:var(--muted);margin-top:2px}.add-mode-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:var(--radius-md);background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .1s;text-decoration:none}.add-mode-card:active{transform:scale(.97)}.add-mode-card:hover{border-color:var(--primary);box-shadow:var(--shadow-orange)}.add-mode-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.add-mode-card__text h3{font-size:.95rem;font-weight:700;color:var(--dark)}.add-mode-card__text p{font-size:.78rem;color:var(--muted);margin-top:2px}.shop-section{margin-bottom:20px}.shop-cat-header{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:8px;padding:0 4px}.shop-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.shop-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.shop-item:first-child{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.shop-item:last-child{border-radius:0 0 var(--radius-sm) var(--radius-sm);border-bottom:none}.shop-item:only-child{border-radius:var(--radius-sm)}.shop-item input[type=checkbox]{width:20px;height:20px;border-radius:6px;accent-color:var(--primary);flex-shrink:0;background:none;border:none;padding:0}.shop-item__name{flex:1;font-size:.93rem;font-weight:500;transition:color .15s}.shop-item__qty{font-size:.82rem;color:var(--muted);white-space:nowrap}.shop-item.checked .shop-item__name{text-decoration:line-through;color:var(--muted)}.progress-bar{background:var(--surface-2);border-radius:99px;height:6px;overflow:hidden;margin-bottom:20px}.progress-bar__fill{height:100%;background:var(--primary);border-radius:99px;transition:width .3s ease}.toast{position:fixed;bottom:calc(var(--nav-h) + 16px);left:50%;transform:translate(-50%);background:var(--dark);color:#fff;padding:10px 20px;border-radius:var(--radius-pill);font-size:.85rem;font-weight:600;z-index:999;animation:fadeUp .2s ease;white-space:nowrap;max-width:90vw}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--muted);gap:12px;font-size:.9rem}.loader-spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--primary);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px;color:var(--muted)}.empty-state img{width:120px;margin-bottom:16px;opacity:.7}.empty-state h3{font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:6px}.empty-state p{font-size:.85rem;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.form-section{margin-bottom:28px}.form-section h2{font-size:.9rem;font-weight:800;color:var(--dark);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);padding-bottom:8px;margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-3col{display:grid;grid-template-columns:1fr 70px 80px auto;gap:8px;align-items:start}.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;background:#fff3e8;color:var(--primary)}.pill-filter{padding:6px 16px;border-radius:var(--radius-pill);font-size:.8rem;font-weight:700;background:var(--surface-2);color:var(--muted);border:1.5px solid transparent;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}.pill-filter.active{background:#fff3e8;color:var(--primary);border-color:var(--primary)}.jinn-hint{display:flex;align-items:center;gap:10px;background:#fff8f0;border-radius:var(--radius-md);padding:12px 16px;margin-top:12px;border:1px solid #fde8d0}.jinn-hint img{width:40px;height:40px;object-fit:contain}.jinn-hint p{font-size:.8rem;color:var(--dark);line-height:1.4}.jinn-hint span{color:var(--primary);font-weight:700}.profile-avatar{width:80px;height:80px;border-radius:50%;border:3px solid var(--teal);overflow:hidden;background:#e8f9fc;margin:0 auto 12px}.profile-avatar img{width:100%;height:100%;object-fit:cover}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0}.stat-card{background:var(--surface-2);border-radius:var(--radius-md);padding:16px;text-align:center}.stat-card .stat-val{font-size:1.6rem;font-weight:800;color:var(--primary)}.stat-card .stat-lbl{font-size:.75rem;color:var(--muted);font-weight:600;margin-top:2px}.sticky-cta{position:sticky;bottom:calc(var(--nav-h) + 12px);z-index:10;padding:0 16px}
