:root{--brand: #8b6f47;--brand-dark: #6f5736;--brand-light: #f3ead9;--bg: #f7f4ef;--surface: #ffffff;--surface-2: #f1ece4;--text: #2b2620;--muted: #8a8178;--border: #e4ddd2;--success: #2e9e5b;--danger: #d4574e;--warn: #c98a1e;--radius: 14px;--shadow: 0 2px 10px rgba(0, 0, 0, .06);--maxw: 640px;--nav-h: 64px}[data-theme=dark]{--brand: #c9a66b;--brand-dark: #b3894c;--brand-light: #2e2820;--bg: #16130f;--surface: #211d17;--surface-2: #2a251e;--text: #ede7dd;--muted: #9c948a;--border: #36302704;--border: #363027;--shadow: 0 2px 12px rgba(0, 0, 0, .4)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}html[dir=rtl] body{font-family:Cairo,system-ui,sans-serif}html[dir=ltr] body{font-family:Inter,system-ui,sans-serif}body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;overscroll-behavior-y:none}h1,h2,h3{line-height:1.3}h2{font-size:1.3rem}h3{font-size:1.05rem;margin-bottom:.5rem}a{color:inherit;text-decoration:none}.muted{color:var(--muted);font-size:.85rem}.with-icon{display:inline-flex;align-items:center;gap:6px}.app-shell{max-width:var(--maxw);margin:0 auto;min-height:100vh;min-height:100dvh;position:relative}.boot{display:grid;place-items:center;min-height:100dvh}.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top));background:var(--brand);color:#fff}.brand{display:flex;align-items:center;gap:8px;font-weight:700}.brand-logo{font-size:1.4rem}.brand-name{font-size:1rem}.header-actions{display:flex;align-items:center;gap:6px}.header-login{display:inline-flex;align-items:center;gap:5px;background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:6px 12px;font:inherit;font-size:.82rem;font-weight:600;cursor:pointer}.header-login:hover{background:#ffffff47}.guest-link{margin-top:6px;color:var(--muted)}.app-main{padding:16px;padding-bottom:calc(var(--nav-h) + 24px)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--maxw);height:var(--nav-h);display:grid;grid-auto-flow:column;grid-auto-columns:1fr;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:20}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:.72rem;color:var(--muted)}.nav-item.active{color:var(--brand);font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius);padding:10px 16px;font:inherit;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-dark)}.btn-secondary{background:var(--surface-2);color:var(--text)}.btn-ghost{background:transparent;color:var(--brand);padding:6px 10px}.btn-danger{background:var(--danger);color:#fff}.btn-block{width:100%}.icon-btn{display:inline-flex;align-items:center;gap:3px;background:transparent;border:none;color:inherit;cursor:pointer;padding:8px;border-radius:10px}.icon-btn:hover{background:#0000000f}.icon-btn.danger{color:var(--danger)}.lang-tag{font-size:.7rem;font-weight:700}.link-btn{background:none;border:none;color:var(--brand);cursor:pointer;font:inherit;margin-top:12px}.page{display:flex;flex-direction:column;gap:18px}.page-head{display:flex;align-items:center;justify-content:space-between}section{display:flex;flex-direction:column;gap:8px}.card-list{display:flex;flex-direction:column;gap:10px}.row-card,.recipe-card,.session-card{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}.recipe-info,.session-info{display:flex;flex-direction:column;gap:3px}.row-actions{display:flex;align-items:center;gap:4px}.empty{text-align:center;color:var(--muted);padding:28px 12px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}.hero h2{margin-bottom:2px}.quick-start{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius);padding:18px;font:inherit;font-weight:700;font-size:1.05rem;cursor:pointer;box-shadow:var(--shadow)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;color:var(--brand);box-shadow:var(--shadow)}.stat-num{font-size:1.6rem;font-weight:800;color:var(--text)}.tag{font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--muted);white-space:nowrap}.tag-in_progress{background:#fdf0d8;color:#a9760f}.tag-completed{background:#dcf2e4;color:#1f7d45}.tag-paused{background:#eceef1;color:#6b7280}.tag-problem{background:#fbe2e0;color:#b23b32}.tag-improvement{background:#e1edfb;color:#2f6bbf}.tag-reminder{background:#f3e6fb;color:#8a3fbf}.tag-observation{background:var(--surface-2);color:var(--muted)}.form{display:flex;flex-direction:column;gap:12px}.field{display:flex;flex-direction:column;gap:5px}.field>span{font-size:.82rem;font-weight:600;color:var(--muted)}.field.inline{flex-direction:row;align-items:center;gap:8px}input,select,textarea{font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--brand);border-color:var(--brand)}textarea{resize:vertical}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.search-box{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0 12px;color:var(--muted)}.search-box input{border:none;padding:12px 0;background:transparent}.search-box input:focus{outline:none}.filter-row{display:flex;align-items:flex-end;gap:10px}.section-head{display:flex;align-items:center;justify-content:space-between}.ingredients-editor{display:flex;flex-direction:column;gap:8px;padding-top:6px;border-top:1px solid var(--border)}.ing-row{display:grid;grid-template-columns:1fr 70px 78px 36px;gap:6px;align-items:center}.ing-row input,.ing-row select{padding:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:50}.modal{background:var(--surface);width:100%;max-width:var(--maxw);max-height:92dvh;border-radius:18px 18px 0 0;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}.modal-body{padding:16px;overflow-y:auto}.modal-foot{display:flex;gap:10px;padding:16px;border-top:1px solid var(--border)}.modal-foot .btn{flex:1}.checklist{display:flex;flex-direction:column;gap:12px}.checklist-head{display:flex;flex-direction:column;gap:6px}.progress-bar{height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--success);transition:width .3s}.bulk-actions{display:flex;gap:6px}.check-list{list-style:none;display:flex;flex-direction:column;gap:8px}.check-list li{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px}.check-list li.checked .check-name{text-decoration:line-through;color:var(--muted)}.check-main{display:flex;align-items:center;gap:10px;flex:1;cursor:pointer}.check-main input{width:20px;height:20px;accent-color:var(--brand)}.check-qty{display:flex;align-items:center;gap:8px}.used-input{width:78px;padding:6px 8px}.uploader-controls{display:flex;gap:8px;align-items:center;margin-bottom:12px}.uploader-controls select{width:auto;flex:1}.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.image-card{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--border)}.image-card img{width:100%;height:100%;object-fit:cover;cursor:pointer}.image-stage{position:absolute;bottom:4px;inset-inline-start:4px;background:#0009;color:#fff;font-size:.65rem;padding:2px 6px;border-radius:6px}.image-del{position:absolute;top:4px;inset-inline-end:4px;background:#0009;color:#fff;border:none;border-radius:6px;padding:4px;cursor:pointer;display:grid;place-items:center}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:grid;place-items:center;z-index:60;padding:20px}.lightbox img{max-width:100%;max-height:100%;border-radius:8px}.note-form{display:grid;grid-template-columns:auto 1fr auto;gap:6px;margin-bottom:12px}.note-form select{width:auto}.note-list{list-style:none;display:flex;flex-direction:column;gap:8px}.note{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;padding-inline-end:40px}.note-meta{display:flex;align-items:center;gap:8px;margin-bottom:5px}.note p{font-size:.92rem}.note-del{position:absolute;top:8px;inset-inline-end:6px}.detail-head{display:flex;align-items:center;gap:10px}.detail-title{flex:1}.detail-title h2{font-size:1.15rem}.meta-strip{display:flex;gap:14px;color:var(--muted);font-size:.9rem}.tabs{display:flex;gap:4px;background:var(--surface-2);padding:4px;border-radius:12px}.tab{flex:1;background:transparent;border:none;padding:9px;border-radius:9px;font:inherit;font-weight:600;color:var(--muted);cursor:pointer}.tab.active{background:var(--surface);color:var(--brand);box-shadow:var(--shadow)}.tab-body{min-height:120px}.settings-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;gap:12px}.seg{display:flex;gap:6px;background:var(--surface-2);padding:4px;border-radius:12px}.seg-btn{flex:1;background:transparent;border:none;padding:9px;border-radius:9px;font:inherit;font-weight:600;color:var(--muted);cursor:pointer}.seg-btn.active{background:var(--surface);color:var(--brand);box-shadow:var(--shadow)}.auth-screen{min-height:100dvh;display:grid;place-items:center;padding:20px;background:linear-gradient(160deg,var(--brand-light),var(--bg));position:relative}.lang-switch{position:absolute;top:16px;inset-inline-end:16px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 14px;cursor:pointer;font:inherit;color:var(--text)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px 22px;width:100%;max-width:380px;box-shadow:var(--shadow);text-align:center}.auth-logo{font-size:3rem}.auth-card h1{font-size:1.25rem;margin:8px 0 20px}.auth-card .form{text-align:start}.alert{border-radius:10px;padding:10px 12px;font-size:.85rem;text-align:start}.alert.warn{background:#fdf3df;color:#8a5d12}.alert.error{background:#fbe2e0;color:#b23b32}.alert.success{background:#dcf2e4;color:#1f7d45}.alert.warn p{margin-top:4px;font-weight:400}.toast{position:fixed;bottom:calc(var(--nav-h) + 16px);left:50%;transform:translate(-50%);background:var(--text);color:var(--bg);padding:10px 18px;border-radius:999px;font-size:.85rem;z-index:80;box-shadow:var(--shadow);max-width:90%}.loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;color:var(--muted)}.spinner{width:34px;height:34px;border:3px solid var(--surface-2);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.explore-hero h2{font-size:1.35rem}.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.chips::-webkit-scrollbar{display:none}.chip{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:999px;padding:8px 14px;font:inherit;font-size:.85rem;cursor:pointer}.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}.chip-emoji{font-size:1rem}.hscroll{display:flex;gap:12px;overflow-x:auto;padding:2px 2px 8px;scrollbar-width:none;scroll-snap-type:x mandatory}.hscroll::-webkit-scrollbar{display:none}.hscroll-item{flex:0 0 64%;max-width:220px;scroll-snap-align:start}.recipe-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.rc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;display:flex;flex-direction:column;transition:transform .12s}.rc:active{transform:scale(.98)}.rc-cover{position:relative;aspect-ratio:4 / 3;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand-light),var(--surface-2));overflow:hidden}.rc-cover img{width:100%;height:100%;object-fit:cover}.rc-emoji{font-size:3rem}.rc-emoji.big{font-size:5rem}.rc-cover[data-cat=kunafa]{background:linear-gradient(135deg,#fbe3c5,#f6c98f)}.rc-cover[data-cat=cake]{background:linear-gradient(135deg,#fcdce6,#f7b8cf)}.rc-cover[data-cat=bread]{background:linear-gradient(135deg,#f0e0c4,#ddc191)}.rc-cover[data-cat=cookies]{background:linear-gradient(135deg,#f3e2cb,#e2c79f)}.rc-cover[data-cat=dessert]{background:linear-gradient(135deg,#e9def7,#cdb6ee)}.rc-fav{position:absolute;top:8px;inset-inline-end:8px;background:#ffffffe6;color:var(--brand);border:none;border-radius:50%;width:32px;height:32px;display:grid;place-items:center;cursor:pointer}.rc-fav.on{background:var(--brand);color:#fff}.rc-body{padding:10px 12px;display:flex;flex-direction:column;gap:4px}.rc-cat{font-size:.7rem;font-weight:700;color:var(--brand)}.rc-title{font-size:.95rem;line-height:1.3}.rc-meta{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:2px}.rc-author{font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rc-like{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;color:var(--muted);cursor:pointer;font:inherit;font-size:.82rem}.rc-like.on{color:var(--danger)}.rc-wide{flex-direction:row}.rc-wide .rc-cover{width:120px;aspect-ratio:1;flex:none}.rc-wide .rc-body{flex:1}.toggle-field{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface-2);border-radius:12px;padding:12px}.toggle-field>div{display:flex;flex-direction:column;gap:2px}.switch{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:46px;height:26px;background:var(--border);border-radius:999px;position:relative;cursor:pointer;transition:.2s;flex:none}.switch:after{content:"";position:absolute;top:3px;inset-inline-start:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s}.switch:checked{background:var(--success)}html[dir=ltr] .switch:checked:after{transform:translate(20px)}html[dir=rtl] .switch:checked:after{transform:translate(-20px)}.pub-cover{aspect-ratio:16 / 9;border-radius:var(--radius);display:grid;place-items:center;background:linear-gradient(135deg,var(--brand-light),var(--surface-2));overflow:hidden}.pub-cover img{width:100%;height:100%;object-fit:cover}.pub-meta{display:flex;align-items:center;gap:10px}.pub-actions{display:flex;gap:10px}.pub-actions .btn{flex:1}.pub-desc{color:var(--text);font-size:.92rem;line-height:1.6}.pub-stats{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.9rem}.pub-stats span{display:inline-flex;align-items:center;gap:4px}.pub-ingredients{list-style:none;display:flex;flex-direction:column;gap:6px}.pub-ingredients li{display:flex;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.username-input{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:0 12px}.username-input .at{color:var(--muted);font-weight:700}.username-input input{border:none;padding:10px 0;background:transparent}.username-input input:focus{outline:none}.username-input .ok{color:var(--success);font-size:1.2rem;flex:none}.username-input .bad{color:var(--danger);font-size:1.2rem;flex:none}.admin-card{display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}.admin-recipe{display:flex;align-items:center;gap:12px}.admin-recipe>div{display:flex;flex-direction:column;gap:2px}.admin-emoji{font-size:2rem;width:52px;height:52px;display:grid;place-items:center;background:var(--brand-light);border-radius:12px;flex:none}.admin-actions{display:flex;gap:8px}.admin-actions .btn{flex:1}.badge-count{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;margin-inline-start:6px;background:var(--danger);color:#fff;border-radius:999px;font-size:.7rem;font-weight:700}.reject-reason{font-size:.78rem}.safety-actions{display:flex;gap:16px;justify-content:center;padding:18px 0 4px;border-top:1px solid var(--border);margin-top:8px}.danger-text{display:inline-flex;align-items:center;gap:5px;color:var(--muted)}.danger-text:hover{color:var(--danger)}.settings-link{display:inline-flex;align-items:center;gap:8px;color:var(--brand);font-weight:600;padding:4px 0}.legal .legal-body{display:flex;flex-direction:column;gap:8px;line-height:1.7}.legal-body h3{margin-top:12px}.legal-body ul{padding-inline-start:20px;display:flex;flex-direction:column;gap:4px}.legal-body a{color:var(--brand);text-decoration:underline}
