@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=DM+Sans:ital,wght@0,400;0,500;0,700&display=swap');
:root{--bg:#f2ece3;--surface:#ebe4d8;--card:#fff;--border:#d9cfc0;--accent:#e2b84b;--accent2:#c99a1d;--accent-light:#fdf3d7;--text:#2c2418;--text2:#1a1208;--muted:#8c7e6a;--cream:#f5efe6;--green:#25d366;--white:#fff;--shadow:rgba(44,36,24,.08);--shadow2:rgba(44,36,24,.15);--radius:14px;--nav-h:54px;--header-h:52px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-tap-highlight-color:transparent;overflow-x:hidden}
img{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");opacity:.45}

/* ======= SPLASH SCREEN ======= */
.splash{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .4s,visibility .4s}
.splash.done{opacity:0;visibility:hidden;pointer-events:none}
.splash-logo{width:140px;height:auto;animation:splashPulse .7s ease-in-out}
@keyframes splashPulse{0%{opacity:0;transform:scale(.7)}50%{opacity:1;transform:scale(1.08)}100%{opacity:1;transform:scale(1)}}

/* ======= HOMEPAGE ======= */
.home{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:10;transition:opacity .5s,transform .5s}
.home.hidden{opacity:0;transform:scale(1.03);pointer-events:none;position:fixed;inset:0;z-index:-1}

/* Dual video: vertical for mobile, horizontal for desktop */
.home-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.home-video--vertical{display:block}
.home-video--horizontal{display:none}
@media(min-width:768px){.home-video--vertical{display:none}.home-video--horizontal{display:block}}
.home-poster{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.home-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(26,18,8,.25) 0%,rgba(26,18,8,.55) 40%,rgba(26,18,8,.85) 75%,rgba(26,18,8,.95) 100%)}
.home-content{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:480px;width:100%}

/* Logo on homepage instead of text title */
.home-logo{width:160px;height:auto;margin:0 auto 14px;filter:drop-shadow(0 4px 20px rgba(0,0,0,.4));animation:logoFadeIn .8s ease-out}
@keyframes logoFadeIn{0%{opacity:0;transform:translateY(12px)}100%{opacity:1;transform:translateY(0)}}
.home-line{width:50px;height:3px;background:var(--accent);margin:0 auto 12px;border-radius:3px}
.home-slogan{font-weight:600;font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.home-address,.home-hours{font-size:12px;color:rgba(255,255,255,.55)}.home-hours{margin-top:3px}
.home-social{display:flex;justify-content:center;gap:16px;margin:20px 0 28px}
.home-social a{width:38px;height:38px;border-radius:50%;border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all .2s}
.home-social a:hover{border-color:var(--accent);color:var(--accent)}
.home-social svg{width:17px;height:17px}
.home-buttons{display:flex;flex-direction:column;gap:12px}
.home-btn{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:16px;text-align:left;transition:all .25s;border:1.5px solid transparent}
.home-btn:active{transform:scale(.97)}
.home-btn--local{background:rgba(255,255,255,.12);backdrop-filter:blur(10px);border-color:rgba(255,255,255,.15);color:#fff}
.home-btn--local:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}
.home-btn--delivery{background:var(--accent);color:var(--text2);border-color:var(--accent)}
.home-btn--delivery:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 6px 24px rgba(226,184,75,.35)}
.home-btn-icon{font-size:28px;flex-shrink:0}.home-btn-text{display:flex;flex-direction:column;gap:2px}.home-btn-text strong{font-size:16px;font-weight:700}.home-btn-text small{font-size:12px;opacity:.75}

/* ======= MENU PAGE ======= */
.menu-page{display:none;opacity:0;transition:opacity .4s}.menu-page.active{display:block;opacity:1}
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(242,236,227,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);height:var(--header-h)}
.header-inner{max-width:720px;margin:0 auto;padding:0 12px;display:flex;align-items:center;justify-content:space-between;height:100%;gap:8px}
.header-back{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text);transition:background .2s;flex-shrink:0}.header-back:hover{background:var(--surface)}
.header-name{font-family:'Playfair Display',serif;font-weight:700;font-size:16px;color:var(--text2);flex:1;text-align:center}
.header-social{display:flex;gap:12px;align-items:center}.header-social a{color:var(--muted);display:flex;align-items:center;transition:color .2s}.header-social a:hover{color:var(--accent2)}.header-social svg{width:19px;height:19px}
.mode-banner{position:fixed;top:var(--header-h);left:0;right:0;z-index:95;height:40px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600}
.mode-banner[data-mode="local"]{background:var(--surface);color:var(--text);border-bottom:1px solid var(--border)}.mode-banner[data-mode="delivery"]{background:var(--accent);color:var(--text2)}
.mode-banner-icon{font-size:16px}.mode-banner-switch{font-size:11px;font-weight:600;text-decoration:underline;opacity:.7;margin-left:6px}
.nav-sticky{position:sticky;top:calc(var(--header-h) + 40px);z-index:90;background:rgba(242,236,227,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);height:var(--nav-h)}
.nav-scroll{display:flex;gap:8px;padding:0 16px;height:100%;align-items:center;overflow-x:auto;scrollbar-width:none;max-width:720px;margin:0 auto}.nav-scroll::-webkit-scrollbar{display:none}
.nav-pill{flex-shrink:0;padding:8px 16px;border-radius:100px;font-size:13px;font-weight:500;color:var(--muted);border:1.5px solid var(--border);background:var(--white);transition:all .25s;white-space:nowrap}
.nav-pill.active{background:var(--accent);color:var(--text2);border-color:var(--accent);font-weight:700}

/* ======= SECTIONS ======= */
.section{max-width:720px;margin:0 auto;padding:0 16px;opacity:0;transform:translateY(30px);transition:opacity .6s,transform .6s;position:relative;z-index:1}.section.visible{opacity:1;transform:translateY(0)}.menu-main{padding-bottom:100px}
.section-banner{position:relative;height:160px;border-radius:var(--radius);overflow:hidden;margin-bottom:20px;margin-top:32px;box-shadow:0 4px 20px var(--shadow2)}.section-banner img{width:100%;height:100%;object-fit:cover}
.section-banner-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(44,36,24,.82) 0%,rgba(44,36,24,.35) 55%,transparent 100%);display:flex;align-items:flex-end;padding:20px}
.section-banner-title{font-family:'Playfair Display',serif;font-weight:900;font-size:26px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.4)}.section-banner-emoji{font-size:28px;margin-right:10px}
.section-header-simple{display:flex;align-items:center;gap:10px;margin:32px 0 20px;padding-top:8px}.section-emoji{font-size:28px}.section-title{font-family:'Playfair Display',serif;font-weight:900;font-size:24px;color:var(--text2)}

/* ======= GRID / LIST ITEMS ======= */
.items-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media(max-width:340px){.items-grid{grid-template-columns:1fr}}
.item-card{background:var(--card);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .25s,box-shadow .25s;border:1px solid var(--border);box-shadow:0 2px 12px var(--shadow);position:relative}.item-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px var(--shadow2)}.item-card:active{transform:scale(.96)}
.item-img-wrap{position:relative;aspect-ratio:1;overflow:hidden;background:var(--surface);display:flex;align-items:center;justify-content:center}.item-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s}.item-card:hover .item-img-wrap img{transform:scale(1.06)}
.shimmer{position:absolute;inset:0;background:linear-gradient(90deg,var(--surface) 25%,var(--cream) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.2s infinite}.shimmer.loaded{display:none}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.item-badge{position:absolute;bottom:8px;right:8px;background:var(--accent);color:var(--text2);font-size:10px;font-weight:700;padding:4px 10px;border-radius:100px}
.item-info{padding:12px}.item-name{font-weight:600;font-size:13px;line-height:1.3;color:var(--text2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px}
.item-price{font-family:'Playfair Display',serif;font-weight:700;font-size:15px;color:var(--accent2)}.item-tag{font-size:11px;color:var(--accent2);font-weight:600}
.items-list{display:flex;flex-direction:column;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:4px 16px;box-shadow:0 2px 12px var(--shadow)}
.list-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border);gap:8px}.list-item:last-child{border-bottom:none}
.list-item-name{font-size:14px;font-weight:500;flex:1}.list-item-price{font-family:'Playfair Display',serif;font-weight:700;font-size:15px;color:var(--accent2);flex-shrink:0}
.list-item-add{display:none;width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--text2);font-size:18px;font-weight:700;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.list-item-add:active{transform:scale(.9)}.menu-page[data-mode="delivery"] .list-item-add{display:flex}

/* ======= PIZZA BUILDER ======= */
.pizza-builder-section{padding-top:8px;position:relative;z-index:1}.pizza-builder{display:flex;flex-direction:column;gap:6px}
.pb-step{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 16px;box-shadow:0 2px 10px var(--shadow)}
.pb-step-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.pb-step-num{width:30px;height:30px;border-radius:50%;background:var(--accent);color:var(--text2);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pb-step-header h3{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--text2)}.pb-or{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--muted);font-weight:400}
.pb-sizes{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.pb-size-card{background:var(--cream);border:2px solid var(--border);border-radius:12px;padding:14px 12px;text-align:center;cursor:pointer;transition:all .2s}.pb-size-card:hover{border-color:var(--accent)}.pb-size-card.active{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 3px rgba(226,184,75,.2)}
.pb-size-icon{font-size:28px;margin-bottom:6px}.pb-size-name{font-family:'Playfair Display',serif;font-weight:700;font-size:15px;color:var(--text2);margin-bottom:2px}.pb-size-detail{font-size:11px;color:var(--muted);line-height:1.4}.pb-size-price{font-family:'Playfair Display',serif;font-weight:700;font-size:16px;color:var(--accent2);margin-top:6px}
.pb-options{display:flex;flex-wrap:wrap;gap:8px}.pb-opt{padding:10px 16px;border:1.5px solid var(--border);border-radius:100px;font-size:13px;font-weight:500;color:var(--muted);background:var(--cream);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:2px}.pb-opt:hover{border-color:var(--accent);color:var(--text)}.pb-opt.active{border-color:var(--accent);background:var(--accent);color:var(--text2);font-weight:600}.pb-opt.active .pb-opt-desc{color:var(--text2);opacity:.7}.pb-opt-desc{font-size:10px;color:var(--muted);font-weight:400}
.pb-tab-bar{display:flex;gap:4px;margin-bottom:14px;background:var(--surface);border-radius:10px;padding:4px}.pb-tab{flex:1;padding:10px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);transition:all .2s}.pb-tab.active{background:var(--accent);color:var(--text2)}.pb-tab-content{display:none}.pb-tab-content.active{display:block}
.pb-classics{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.pb-classic{padding:12px;border:1.5px solid var(--border);border-radius:10px;background:var(--cream);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--text)}.pb-classic:hover{border-color:var(--accent)}.pb-classic.active{border-color:var(--accent);background:var(--accent-light);color:var(--text2);font-weight:600;box-shadow:0 0 0 3px rgba(226,184,75,.15)}.pb-classic.disabled{opacity:.35;cursor:not-allowed}.pb-classic-emoji{font-size:20px}
.pb-flavor-hint{font-size:12px;color:var(--accent2);font-weight:600;margin-bottom:12px;padding:8px 12px;background:var(--accent-light);border-radius:8px;text-align:center}.pb-flavor-hint:empty{display:none}
.pb-flavor-group{margin-bottom:16px}.pb-flavor-group-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:8px}.pb-special-limit{font-size:10px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--accent2);background:var(--accent-light);padding:2px 8px;border-radius:100px}
.pb-specials{display:grid;grid-template-columns:1fr;gap:8px}.pb-special{padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;background:var(--cream);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:12px}.pb-special:hover{border-color:var(--accent)}.pb-special.active{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 3px rgba(226,184,75,.15)}.pb-special.disabled{opacity:.35;cursor:not-allowed}.pb-special-emoji{font-size:22px;flex-shrink:0}.pb-special-info{flex:1;min-width:0}.pb-special-name{font-size:14px;font-weight:600;color:var(--text2);margin-bottom:2px}.pb-special-desc{font-size:11px;color:var(--muted);line-height:1.4}
.pb-selected-flavors{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.pb-selected-flavors:empty{display:none}.pb-sel-flavor{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:100px;font-size:12px;font-weight:600}.pb-sel-flavor.classic{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent2)}.pb-sel-flavor.special{background:#fce4ec;border:1px solid #e57373;color:#c62828}.pb-sel-flavor-x{cursor:pointer;font-size:14px;line-height:1;opacity:.7}.pb-sel-flavor-x:hover{opacity:1}
.pb-special-note{font-size:11px;color:var(--accent2);margin-bottom:8px;padding:6px 10px;background:var(--accent-light);border-radius:6px;line-height:1.4}.pb-special-note:empty{display:none}
.pb-ing-hint{font-size:13px;color:var(--muted);margin-bottom:14px}.pb-ing-hint strong{color:var(--accent2)}
.pb-extra-section{margin-top:16px;text-align:center;padding-top:14px;border-top:1px dashed var(--border)}.pb-extra-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;border-radius:100px;background:var(--accent-light);border:1.5px solid var(--accent);color:var(--accent2);font-weight:700;font-size:13px;transition:all .2s}.pb-extra-btn:hover{background:var(--accent);color:var(--text2)}.pb-extra-cost{font-size:11px;color:var(--muted);margin-top:6px}
.pb-extra-ings{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.pb-extra-title{font-size:13px;font-weight:700;color:var(--accent2);margin-bottom:10px;display:flex;align-items:center;gap:8px}.pb-extra-price-tag{font-size:11px;font-weight:600;background:#fce4ec;color:#c62828;padding:2px 10px;border-radius:100px}.pb-extra-groups .pb-ing.active{background:#e57373;border-color:#e57373;color:#fff}
.pb-surcharge{font-size:11px;color:#c62828;font-weight:600;margin-top:2px}
.pb-ing-group{margin-bottom:14px}.pb-ing-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:8px}.pb-ing-list{display:flex;flex-wrap:wrap;gap:6px}
.pb-ing{padding:8px 14px;border:1.5px solid var(--border);border-radius:100px;font-size:12px;font-weight:500;color:var(--text);background:var(--cream);cursor:pointer;transition:all .2s}.pb-ing:hover{border-color:var(--accent)}.pb-ing.active{border-color:var(--accent);background:var(--accent);color:var(--text2);font-weight:600}.pb-ing.disabled{opacity:.35;cursor:not-allowed}
.pb-selected-ings{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.pb-sel-ing{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--accent-light);border:1px solid var(--accent);border-radius:100px;font-size:12px;color:var(--accent2);font-weight:600}.pb-sel-ing-x{cursor:pointer;font-size:14px;line-height:1;opacity:.7}.pb-sel-ing-x:hover{opacity:1}
.pb-summary{background:var(--card);border:2px solid var(--accent);border-radius:var(--radius);padding:18px 16px;margin-top:4px;box-shadow:0 4px 20px rgba(226,184,75,.12)}.pb-summary-top{display:flex;gap:14px;margin-bottom:16px}.pb-summary-visual{width:52px;height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.pb-pizza-icon{font-size:42px}.pb-summary-details{flex:1}.pb-summary-placeholder{color:var(--muted);font-size:13px;font-style:italic}.pb-summary-line{font-size:13px;color:var(--text);margin-bottom:3px}.pb-summary-line strong{color:var(--accent2);font-weight:600}
.pb-summary-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px}.pb-price-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;display:block}.pb-price-value{font-family:'Playfair Display',serif;font-weight:900;font-size:26px;color:var(--accent2)}
.pb-order-btn{display:flex;align-items:center;gap:8px;background:var(--accent);color:var(--text2);font-weight:700;font-size:14px;padding:12px 22px;border-radius:100px;transition:all .2s;flex-shrink:0}.pb-order-btn:disabled{opacity:.4;cursor:not-allowed}.pb-order-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(226,184,75,.35)}
.pb-additional-note{font-size:11px;color:var(--muted);margin-top:12px;text-align:center;font-style:italic}
.menu-page[data-mode="local"] .pb-order-btn svg{display:none}

/* ======= MODAL ======= */
.modal-backdrop{position:fixed;inset:0;z-index:200;background:rgba(44,36,24,.4);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:24px 16px;opacity:0;pointer-events:none;transition:opacity .3s}.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal{background:var(--card);border-radius:20px;overflow:hidden;width:100%;max-width:380px;max-height:85vh;overflow-y:auto;transform:scale(.88);opacity:0;transition:transform .4s cubic-bezier(.34,1.38,.64,1),opacity .3s;box-shadow:0 20px 60px rgba(44,36,24,.2)}.modal-backdrop.open .modal{transform:scale(1);opacity:1}
.modal-gallery{position:relative;height:58vw;max-height:300px;overflow:hidden}.modal-slides{display:flex;height:100%;transition:transform .3s ease;will-change:transform}.modal-slides.dragging{transition:none}.modal-slide{flex:0 0 100%;height:100%}.modal-slide img{width:100%;height:100%;object-fit:cover}
.modal-dots{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:7px}.modal-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.5);transition:all .25s}.modal-dot.active{background:#fff;transform:scale(1.3)}
.modal-btn-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.92);color:#333;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.modal-info{background:var(--cream);padding:22px 20px 26px}.modal-title{font-family:'Playfair Display',serif;font-weight:900;font-size:20px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.modal-desc{font-size:13px;line-height:1.6;color:var(--muted);margin-bottom:18px}
.modal-bottom{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-price{font-family:'Playfair Display',serif;font-weight:900;font-size:24px;color:var(--text2)}
.modal-qty{display:flex;align-items:center;background:var(--surface);border-radius:100px;border:1.5px solid var(--border)}.modal-qty-btn{width:36px;height:36px;font-size:18px;font-weight:700;color:var(--text2);display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-qty-btn:hover{background:var(--border)}.modal-qty-num{width:32px;text-align:center;font-weight:700;font-size:16px;color:var(--text2)}
.modal-add-btn{width:100%;padding:14px;border-radius:12px;background:var(--accent);color:var(--text2);font-weight:700;font-size:15px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.modal-add-btn:hover{background:var(--accent2);transform:translateY(-1px)}.modal-add-btn:active{transform:scale(.97)}
.menu-page[data-mode="local"] .modal-qty{display:none}.menu-page[data-mode="local"] .modal-add-btn{display:none}

/* ======= CART FLOAT ======= */
.cart-float{position:fixed;bottom:0;left:0;right:0;z-index:160;background:var(--accent);color:var(--text2);padding:14px 20px;display:none;align-items:center;justify-content:space-between;cursor:pointer;box-shadow:0 -4px 20px rgba(226,184,75,.3)}.cart-float.show{display:flex}.cart-float:active{transform:scale(.98)}
.cart-float-info{display:flex;align-items:center;gap:10px}.cart-float-count{width:28px;height:28px;border-radius:50%;background:var(--text2);color:var(--accent);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center}.cart-float-label{font-size:13px;font-weight:600}
.cart-float-right{text-align:right}.cart-float-total{display:block;font-family:'Playfair Display',serif;font-weight:800;font-size:18px}.cart-float-arrow{font-size:11px;opacity:.7}
@keyframes cartPop{0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}}.cart-float-count.pop{animation:cartPop .3s ease}

/* ======= CART DRAWER ======= */
.cart-backdrop{position:fixed;inset:0;z-index:300;background:rgba(44,36,24,.45);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .3s}.cart-backdrop.open{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;bottom:0;left:0;right:0;z-index:301;max-height:92vh;background:var(--bg);border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,1,.5,1);box-shadow:0 -8px 40px rgba(44,36,24,.2)}.cart-backdrop.open .cart-drawer{transform:translateY(0)}
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.cart-header-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--text2)}
.cart-header-close{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text)}.cart-header-close:hover{background:var(--surface)}
.cart-body{flex:1;overflow-y:auto;padding:16px 20px}.cart-empty{text-align:center;padding:32px 0;color:var(--muted)}.cart-empty-icon{font-size:40px;display:block;margin-bottom:10px}.cart-empty p{font-weight:600;font-size:15px;margin-bottom:4px}.cart-empty small{font-size:12px}
.cart-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.cart-item:last-of-type{border-bottom:none}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-weight:600;font-size:14px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-detail{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-price{font-family:'Playfair Display',serif;font-weight:700;font-size:14px;color:var(--accent2);flex-shrink:0}
.cart-item-qty{display:flex;align-items:center;background:var(--surface);border-radius:100px;border:1px solid var(--border);flex-shrink:0}.cart-item-qty button{width:30px;height:30px;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;color:var(--text2);border-radius:50%}.cart-item-qty button:hover{background:var(--border)}.cart-item-qty span{width:24px;text-align:center;font-weight:700;font-size:13px}
.cart-item-remove{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:16px;flex-shrink:0}.cart-item-remove:hover{background:#f5d5d5;color:#c0392b}
.cart-comments-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.cart-comments-label{font-size:13px;font-weight:600;color:var(--text2);display:block;margin-bottom:8px}
.cart-comments{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:12px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--muted);background:var(--card);resize:none;transition:border-color .2s,color .2s;line-height:1.5}.cart-comments:focus{outline:none;border-color:var(--accent);color:var(--text)}.cart-comments.has-content{color:var(--text)}
.cart-footer{padding:16px 20px 24px;border-top:1px solid var(--border);flex-shrink:0;background:var(--card)}.cart-footer-note{font-size:11px;color:var(--muted);text-align:center;margin-bottom:10px}
.cart-footer-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:14px;font-weight:600;color:var(--text)}.cart-total-value{font-family:'Playfair Display',serif;font-weight:900;font-size:22px;color:var(--accent2)}
.cart-send-btn{width:100%;padding:15px;border-radius:14px;background:var(--green);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s}.cart-send-btn:disabled{opacity:.4;cursor:not-allowed}.cart-send-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 18px rgba(37,211,102,.4)}

/* ======= FOOTER ======= */
.site-footer{background:var(--surface);border-top:1px solid var(--border);padding:40px 16px 32px;position:relative;z-index:1}.footer-inner{max-width:720px;margin:0 auto;text-align:center}
.footer-brand{font-family:'Playfair Display',serif;font-weight:900;font-size:24px;color:var(--text2);margin-bottom:16px}.footer-social{display:flex;justify-content:center;gap:16px;margin-bottom:20px}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s}.footer-social a:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-light)}.footer-social svg{width:18px;height:18px}
.footer-info p{font-size:13px;color:var(--muted);margin-bottom:4px}.footer-line{width:60px;height:1px;background:var(--border);margin:20px auto}.footer-copy{font-size:11px;color:var(--muted);opacity:.6}
.delivery-note{display:none;max-width:720px;margin:24px auto 0;padding:14px 20px;text-align:center;font-size:11px;font-weight:500;color:var(--muted);background:var(--surface);border:1px dashed var(--border);border-radius:10px}.menu-page[data-mode="delivery"] .delivery-note{display:block}
.pasta-note{background:var(--accent-light);border:1px solid var(--accent);border-radius:10px;padding:12px 16px;margin-bottom:16px;font-size:12px;color:var(--muted);line-height:1.5}
@media(min-width:480px){.pb-sizes{grid-template-columns:repeat(4,1fr)}.pb-classics{grid-template-columns:repeat(4,1fr)}.home-buttons{flex-direction:row}.home-btn{flex:1}}

/* ======= PORTION SELECTOR (modal) ======= */
.modal-portions{display:flex;gap:8px;margin-bottom:16px}
.modal-portion{flex:1;padding:12px 10px;border:2px solid var(--border);border-radius:12px;text-align:center;cursor:pointer;transition:all .2s;background:var(--card)}
.modal-portion:hover{border-color:var(--accent)}
.modal-portion.active{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 3px rgba(226,184,75,.2)}
.modal-portion-label{font-size:13px;font-weight:700;color:var(--text2);display:block;margin-bottom:2px}
.modal-portion-price{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;color:var(--accent2)}