@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Outfit:wght@400;500;600;700&display=swap";
@font-face{font-family:Playfair Display;font-style:normal;font-weight:500;font-display:swap;src:url(../media/65c558afe41e89d6-s.113htgw8u-emy.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-weight:500;font-display:swap;src:url(../media/14e23f9b59180572-s.08.c8psu~gif9.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-weight:500;font-display:swap;src:url(../media/b49b0d9b851e4899-s.0yfy_qj1.2qn0.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2a65768255d6b625-s.p.14by5b4al-y~f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display;font-style:normal;font-weight:600;font-display:swap;src:url(../media/65c558afe41e89d6-s.113htgw8u-emy.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-weight:600;font-display:swap;src:url(../media/14e23f9b59180572-s.08.c8psu~gif9.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-weight:600;font-display:swap;src:url(../media/b49b0d9b851e4899-s.0yfy_qj1.2qn0.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2a65768255d6b625-s.p.14by5b4al-y~f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display Fallback;src:local(Times New Roman);ascent-override:97.25%;descent-override:22.56%;line-gap-override:0.0%;size-adjust:111.26%}.playfair_display_fe51e3af-module__gDNaMq__className{font-family:Playfair Display,Playfair Display Fallback;font-style:normal}.playfair_display_fe51e3af-module__gDNaMq__variable{--font-display:"Playfair Display", "Playfair Display Fallback"}
@font-face{font-family:DM Sans;font-style:normal;font-weight:300;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:300;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/c3cb240f9c892514-s.163v2i5cux7-c.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.0yo6-5yoeeudq.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Fallback;src:local(Arial);ascent-override:94.9%;descent-override:29.66%;line-gap-override:0.0%;size-adjust:104.53%}.dm_sans_df9c7a03-module__J6ZV0G__className{font-family:DM Sans,DM Sans Fallback;font-style:normal}.dm_sans_df9c7a03-module__J6ZV0G__variable{--font-body:"DM Sans", "DM Sans Fallback"}
:root{--sipo-red:#e8553e;--sipo-red-dark:#d04530;--sipo-red-light:#fdecea;--sipo-black:#1a1410;--sipo-accent:#f2896a;--bg-app:#f9fafb;--bg-card:#fff;--text-1:#1a1410;--text-2:#4d4440;--text-3:#7a6e67;--text-4:#d1d5db;--primary:#e8553e;--primary-dark:#d04530;--primary-light:#fdecea;--dark:#1a1410;--surface:#f5f0eb;--border-color:#1a14100f;--radius-xl:1rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--radius-4xl:2rem;--radius-full:9999px;--shadow-soft:0 2px 15px -3px #00000012, 0 10px 20px -2px #0000000a;--shadow-card:0 4px 25px -5px #00000014;--shadow-elevated:0 10px 40px -10px #0000001f;--shadow-glow:0 0 20px #e8553e4d;--header-height:72px;--green:#10b981}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;width:100vw;max-width:100%;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow-x:hidden}body{background-color:var(--surface);color:var(--text-1);width:100%;max-width:100%;line-height:1.5;overflow-x:hidden}button,a{font-family:inherit;transition:all .2s cubic-bezier(.4,0,.2,1)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 24px}.topbar{height:var(--header-height);z-index:1000;background:#fff;border-bottom:1px solid #f3f4f6;position:sticky;top:0}.topbar-inner{justify-content:space-between;align-items:center;max-width:1440px;height:100%;margin:0 auto;padding:0 24px;display:flex}.topbar-auth{align-items:center;gap:12px;display:flex}.sipo-logo-img{width:auto;height:28px}.btn-signup-black{color:#fff;border-radius:var(--radius-full);cursor:pointer;background:#000;border:none;align-items:center;height:48px;padding:0 20px;font-size:15px;font-weight:600;display:flex}.btn-signup-black:hover{background:#333}.restaurant-hero{color:#fff;background:radial-gradient(circle at 100% 0,#1f2937,#111827);height:280px;position:relative;overflow:hidden}.hero-img{object-fit:cover;opacity:.5;width:100%;height:100%}.hero-overlay{pointer-events:none;background:linear-gradient(#0000 40%,#000000d9 100%);position:absolute;inset:0}.hero-info-btn-ref{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10;background:#0006;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:absolute;top:24px;right:32px}.hero-title-mobile{display:none}.hero-container{width:100%;max-width:1280px;margin:0 auto;padding:0 32px}.hero-content-bottom{z-index:5;padding-bottom:32px;position:absolute;bottom:0;left:0;right:0}.hero-meta-row{align-items:flex-end;gap:20px;display:flex}.restaurant-avatar-ref{width:80px;height:80px;box-shadow:var(--shadow-elevated);background:#fff;border:4px solid #fff;border-radius:16px;flex-shrink:0;overflow:hidden}.restaurant-avatar-ref img{object-fit:cover;width:100%;height:100%}.restaurant-name-block-ref h1{color:#fff;letter-spacing:-.025em;margin-bottom:4px;font-size:30px;font-weight:700;line-height:1.2}.restaurant-status-row-ref{color:#fff9;align-items:center;gap:12px;font-size:14px;font-weight:500;display:flex}.status-badge{align-items:center;gap:6px;font-weight:600;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.is-open{background-color:#34d399;box-shadow:0 0 8px #34d39980}.status-dot.is-closed{background-color:#f87171}.status-badge:has(.is-open){color:#6ee7b7}.status-badge:has(.is-closed){color:#fca5a5}.separator{opacity:.5;margin:0 4px}.address-text{white-space:nowrap;text-overflow:ellipsis;max-width:400px;overflow:hidden}.hero-phone-link{color:#fffc;align-items:center;gap:5px;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.hero-phone-link:hover{color:#fff}.restaurant-hero-wrapper{background:var(--surface)}.badge-open-dot{background:#4ade80;border-radius:50%;width:6px;height:6px}.badge-closed{color:#f87171;border-radius:var(--radius-full);background:#ef444433;border:1px solid #ef44444d;align-items:center;gap:6px;padding:4px 10px;display:flex}.badge-closed-dot{background:#f87171;border-radius:50%;width:6px;height:6px}.booking-nav{border-bottom:1px solid var(--border-color);top:var(--header-height);z-index:900;background:#fff;padding:12px 0;position:sticky}.booking-nav-inner{scrollbar-width:none;gap:4px;display:flex;overflow-x:auto}.nav-tab{color:#6b7280;cursor:pointer;white-space:nowrap;border-radius:var(--radius-full);background:0 0;border:none;flex-shrink:0;padding:8px 16px;font-size:13px;font-weight:800;transition:all .2s}.nav-tab:hover{color:#111827;background:#f9fafb}.nav-tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-glow)}.site-footer{border-top:1px solid var(--border-color);text-align:center;background:#fff;padding:40px 24px}.section-head{align-items:center;gap:12px;padding:24px 24px 0;display:flex}.section-head-icon{background:var(--sipo-red-light);border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.section-head h2{color:var(--text-1);font-size:20px;font-weight:700}.section-body{padding:24px}.step-indicator{align-items:center;margin-bottom:32px;display:flex}.step-item{align-items:center;gap:10px;display:flex}.step-dot{background:var(--bg-app);border:1px solid var(--border-color);width:24px;height:24px;color:var(--text-4);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.step-item.active .step-dot{background:var(--sipo-red);border-color:var(--sipo-red);color:#fff;box-shadow:0 0 0 4px var(--sipo-red-light)}.step-item.done .step-dot{background:var(--green);border-color:var(--green);color:#fff}.step-item span{color:var(--text-3);font-size:13px;font-weight:600}.step-item.active span{color:var(--text-1)}.step-line{background:var(--border-color);flex:1;height:1px;margin:0 16px}.field-label{color:var(--text-2);margin-bottom:12px;font-size:14px;font-weight:600;display:block}.date-scroll{scrollbar-width:thin;gap:10px;padding-bottom:12px;display:flex;overflow-x:auto}.date-chip{border:1px solid var(--border-color);cursor:pointer;background:#fff;border-radius:16px;flex-direction:column;align-items:center;min-width:60px;padding:8px 0;transition:all .2s;display:flex}.date-chip.selected{color:#fff;background:#000;border-color:#000;box-shadow:0 4px 12px #0000001a}.dc-day{text-transform:uppercase;color:#9ca3af;margin-bottom:2px;font-size:9px;font-weight:900}.dc-num{color:#111827;font-size:15px;font-weight:900}.dc-mon{color:#9ca3af;font-size:9px;font-weight:800}.date-chip.selected .dc-num{color:#fff}.date-chip.selected .dc-mon{color:#fff9}.guest-stepper{background:var(--bg-app);border-radius:var(--radius-lg);align-items:center;gap:20px;width:fit-content;padding:6px;display:flex}.gs-btn{width:36px;height:36px;box-shadow:var(--shadow-sm);cursor:pointer;color:var(--text-2);background:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.gs-btn:hover{background:var(--sipo-red);color:#fff}.gs-val{text-align:center;min-width:20px;font-size:18px;font-weight:700}.time-chip{border-radius:var(--radius-xl);border:1px solid var(--border-color);text-align:center;cursor:pointer;background:#f9fafb;padding:12px;font-size:13px;font-weight:700;transition:all .2s}.time-chip:hover{background:#fff;border-color:#000}.form-input{border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;color:var(--text-1);appearance:none;background:#fff;padding:12px 16px;font-family:inherit;font-size:16px;font-weight:500;transition:all .2s}.form-textarea{border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;color:var(--text-1);resize:vertical;appearance:none;background:#fff;min-height:90px;padding:12px 16px;font-family:inherit;font-size:16px;font-weight:500;transition:all .2s}.input-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.guest-hint{color:var(--text-3);margin-top:10px;font-size:13px;font-weight:500}.time-empty{text-align:center;color:var(--text-3);background:var(--bg-app);border-radius:var(--radius-xl);border:1px dashed var(--border-color);padding:20px;font-size:14px;font-weight:500}.date-scroll{scrollbar-width:none;-ms-overflow-style:none;gap:8px;margin-top:8px;padding-bottom:8px;display:flex;overflow-x:auto}.date-scroll::-webkit-scrollbar{display:none}.date-chip{border-radius:var(--radius-xl);border:1px solid var(--border-color);cursor:pointer;background:#fff;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;min-width:60px;padding:12px 0;transition:all .2s;display:flex}.date-chip:hover{border-color:var(--text-4)}.date-chip.selected{background:var(--sipo-red);border-color:var(--sipo-red);color:#fff}.dc-day{text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:2px;font-size:11px;font-weight:700}.date-chip.selected .dc-day{color:#ffffffe6}.dc-num{font-size:16px;font-weight:800}.time-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;display:grid}.time-chip{border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:center;cursor:pointer;color:var(--text-1);background:#fff;padding:12px 8px;font-size:13px;font-weight:700;transition:all .2s}.time-chip:hover{border-color:var(--text-4)}.time-chip.selected{color:#fff;background:#000;border-color:#000}.btn-primary{color:#fff;border-radius:var(--radius-2xl);cursor:pointer;background:#000;border:none;justify-content:center;align-items:center;gap:10px;width:100%;padding:16px;font-size:15px;font-weight:700;display:flex;box-shadow:0 10px 15px -3px #0000001a}.btn-primary:hover{background:#333;transform:translateY(-2px)}.btn-ghost{color:var(--text-2);border-radius:var(--radius-lg);cursor:pointer;background:0 0;border:none;padding:10px 16px;font-weight:600;transition:all .2s}.btn-ghost:hover{background:var(--bg-app);color:var(--sipo-red)}.btn-outline{color:var(--text-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;background:0 0;padding:10px 20px;font-weight:600;transition:all .2s}.btn-outline:hover{border-color:var(--sipo-red);color:var(--sipo-red);background:var(--sipo-red-light)}.btn-secondary{background:var(--bg-app);color:var(--text-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:12px;padding:12px 20px;font-weight:600;transition:all .2s;display:flex}.btn-secondary:hover{border-color:var(--text-4);background:#fff}.form-input:focus,.form-textarea:focus{border-color:var(--sipo-red);box-shadow:0 0 0 4px var(--sipo-red-light);outline:none}.sidebar-card{top:calc(var(--header-height) + 20px);position:sticky}.summary-item{border-bottom:1px dashed var(--border-color);justify-content:space-between;padding:12px 0;display:flex}.summary-item:last-child{border:none}.info-label-caps{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);opacity:.8;margin-bottom:12px;font-size:10px;font-weight:800}.info-card-ref{border:1px solid var(--border-color);border-radius:var(--radius-2xl);background:#f9fafb80;align-items:flex-start;gap:16px;margin-bottom:16px;padding:16px;display:flex}.info-icon-box{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.info-icon-box.blue{color:#3b82f6;background:#eff6ff}.info-icon-box.emerald{color:#10b981;background:#ecfdf5}.info-icon-box.orange{color:#f97316;background:#fff7ed}.info-icon-box.purple{color:#a855f7;background:#faf5ff}.info-content-text{color:var(--text-1);font-size:14px;font-weight:600;line-height:1.4}.info-link{text-decoration:none;transition:color .2s;display:block}.info-link:hover{color:var(--primary)}.info-subtext{color:var(--text-3);margin-top:2px;font-size:13px;font-weight:500}.info-subtext.info-link:hover{color:var(--primary)}.website-card{background:#faf5ff80;border-color:#a855f726}.info-website-url{color:#a855f7;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:13px;font-weight:800;text-decoration:none;transition:color .2s;display:block;overflow:hidden}.info-website-url:hover{color:#7c3aed}.hours-card-ref{border:1px solid var(--border-color);background:#f9fafb80;border-radius:24px;overflow:hidden}.hours-tab-bar{border-bottom:1px solid var(--border-color);background:#fff;gap:2px;padding:4px;display:flex}.hours-tab{text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;padding:10px;font-size:11px;font-weight:800;transition:all .2s}.hours-tab:hover{color:var(--text-1);background:var(--bg-app)}.hours-tab.active{background:var(--primary-light);color:var(--primary)}.hours-list{padding:4px 0}.hours-row-ref{justify-content:space-between;align-items:center;padding:12px 20px;font-size:14px;display:flex}.hours-row-ref:not(:last-child){border-bottom:1px solid #1a14100a}.hours-day-ref{color:var(--text-2);align-items:center;gap:8px;font-weight:700;display:flex}.hours-time-ref{color:var(--text-1);font-weight:600}.hours-closed-ref{color:#9ca3af;font-weight:600}.today-pill{background:var(--primary-light);color:var(--primary);letter-spacing:.05em;border-radius:6px;padding:2px 7px;font-size:9px;font-weight:800}.legal-section{margin-bottom:20px}.legal-card{border:1px solid var(--border-color);background:#f9fafb80;border-radius:20px;padding:16px}.legal-card.amber{background:#fffbeb80;border-color:#f59e0b26}.legal-link{color:var(--primary);word-break:break-all;align-items:center;gap:6px;font-size:12px;font-weight:700;text-decoration:none;transition:color .2s;display:inline-flex}.legal-link:hover{color:var(--primary-dark);text-decoration:underline}.legal-text{color:var(--text-2);white-space:pre-line;margin:0;font-size:12px;line-height:1.6}.footer-links{flex-wrap:wrap;justify-content:center;gap:24px;display:flex}.footer-links a{color:var(--text-3);font-size:12px;font-weight:600;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--primary)}.success-panel{text-align:center;padding:20px 0;display:none}.success-panel.active{animation:.5s ease-out fadeIn;display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.success-check{width:64px;height:64px;color:var(--green);background:#dcfce7;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;display:flex}.success-title{color:var(--text-1);margin-bottom:8px;font-size:24px;font-weight:700}.success-sub{color:var(--text-3);margin-bottom:32px;font-size:15px}.confirm-card{background:var(--bg-app);border-radius:var(--radius-xl);border:1px solid var(--border-color);margin-bottom:24px;padding:20px}.confirm-row{border-bottom:1px solid #00000008;justify-content:space-between;padding:8px 0;display:flex}.confirm-row:last-child{border:none}.cr-key{color:var(--text-3);font-size:13px}.cr-val{color:var(--text-1);font-size:14px;font-weight:600}.action-grid{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:32px;display:grid}.booking-card{border-radius:var(--radius-3xl);box-shadow:var(--shadow-card);background:#fff;flex-direction:column;display:flex;overflow:hidden}.action-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-2);cursor:pointer;background:#fff;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;font-size:11px;font-weight:600;transition:all .2s;display:flex}.action-card:hover{border-color:var(--sipo-red);color:var(--sipo-red);background:var(--sipo-red-light)}.reset-link{color:var(--sipo-red);cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:600;text-decoration:underline}.reservation-card{overflow:hidden;border:1px solid var(--border-color)!important;background:#fff!important;border-radius:24px!important;box-shadow:0 4px 30px #0000000f!important}.reservation-card-head{border-bottom:1px solid var(--border-color);background:#fff;align-items:center;gap:14px;padding:20px 24px;display:flex}.reservation-icon-wrap{width:44px;height:44px;color:var(--primary);background:linear-gradient(135deg,#e8553e1f,#e8553e0a);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.reservation-card-title{color:var(--text-1);letter-spacing:-.01em;margin:0;font-size:16px;font-weight:800}.reservation-card-sub{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin:2px 0 0;font-size:11px;font-weight:600}.reservation-card-body{padding:20px 24px}.reservation-empty{text-align:center;padding:24px 16px}.reservation-empty-icon{width:56px;height:56px;color:var(--text-4);background:linear-gradient(135deg,#9ca3af1a,#9ca3af08);border-radius:16px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.reservation-empty-text{color:var(--text-3);font-size:13px;font-weight:500;line-height:1.5}.reservation-success-badge{background:linear-gradient(135deg,#10b98114,#10b98105);border:1px solid #10b9811f;border-radius:16px;align-items:center;gap:14px;padding:16px;display:flex}.reservation-success-icon{width:40px;height:40px;color:var(--green);background:#10b98126;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.reservation-success-title{color:var(--green);margin:0;font-size:15px;font-weight:800}.reservation-success-sub{color:var(--text-3);margin:2px 0 0;font-size:12px;font-weight:500}.reservation-details{flex-direction:column;gap:4px;display:flex}.res-detail-row{border-radius:14px;align-items:center;gap:12px;padding:10px 12px;transition:background .15s;display:flex}.res-detail-row:hover{background:#00000005}.res-detail-icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.res-detail-icon-wrap.orange{color:#f97316;background:linear-gradient(135deg,#f973161f,#f973160a)}.res-detail-icon-wrap.blue{color:#3b82f6;background:linear-gradient(135deg,#3b82f61f,#3b82f60a)}.res-detail-icon-wrap.emerald{color:#10b981;background:linear-gradient(135deg,#10b9811f,#10b9810a)}.res-detail-icon-wrap.purple{color:#a855f7;background:linear-gradient(135deg,#a855f71f,#a855f70a)}.res-detail-content{flex-direction:column;min-width:0;display:flex}.res-detail-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.res-detail-value{color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:700;overflow:hidden}.reservation-card-footer{border-top:1px solid var(--border-color);padding:16px 24px 24px}.trust-badges{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.trust-item{color:var(--text-3);align-items:center;gap:8px;font-size:12px;font-weight:600;display:flex}.trust-item svg{color:var(--green);flex-shrink:0}.sidebar-cta-btn{border-radius:14px!important;padding:14px!important;font-size:14px!important;box-shadow:0 6px 20px #0000001f!important}.powered-by-sipo{text-align:center;color:var(--text-4);letter-spacing:.02em;margin-top:16px;font-size:11px;font-weight:600}.powered-by-sipo a{color:var(--primary);font-weight:700;text-decoration:none;transition:color .2s}.powered-by-sipo a:hover{color:var(--primary-dark)}.mobile-cta{border-top:1px solid var(--border-color);z-index:200;background:#fff;padding:16px 20px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #0000000d}@media (max-width:900px){.mobile-cta{display:none!important}}.map-pin-wrap{flex-direction:column;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-100%)}.map-bubble{background:var(--text-1);color:#fff;white-space:nowrap;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600}.map-pin-tail{border-left:6px solid #0000;border-right:6px solid #0000;border-top:8px solid var(--text-1);width:0;height:0}.map-open-btn{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);cursor:pointer;background:#fff;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:11px;font-weight:600;display:flex;position:absolute;bottom:12px;right:12px}.time-legend{color:var(--text-3);gap:16px;margin-top:16px;font-size:12px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.err-msg{color:var(--sipo-red);margin-top:4px;font-size:12px;font-weight:500;display:none}.form-input.err{border-color:var(--sipo-red);background:var(--sipo-red-light)}.field-group{margin-bottom:24px}.info-section{flex-direction:column;gap:20px;display:flex}.info-row-item{border-bottom:1px solid var(--border-color);gap:16px;padding-bottom:20px;display:flex}.info-icon{width:20px;height:20px;color:var(--sipo-red);flex-shrink:0;margin-top:2px}.info-label{text-transform:uppercase;color:var(--text-4);letter-spacing:.05em;margin-bottom:4px;font-size:12px;font-weight:700}.info-val{color:var(--text-2);font-size:15px;line-height:1.4}.map-box{border-radius:var(--radius-lg);border:1px solid var(--border-color);background:#f3f4f6;height:180px;position:relative;overflow:hidden}.map-grid-lines{background-image:linear-gradient(var(--border-color) 1px, transparent 1px), linear-gradient(90deg, var(--border-color) 1px, transparent 1px);opacity:.3;background-size:40px 40px;position:absolute;inset:0}.hours-table{flex-direction:column;display:flex}.hours-tr{border-bottom:1px solid var(--bg-app);justify-content:space-between;padding:12px 0;font-size:14px;display:flex}.hours-tr:last-child{border:none}.hours-tr span:first-child{color:var(--text-2);font-weight:500}.hours-tr span:last-child{color:var(--text-1);font-weight:600}.today-row{background:var(--sipo-red-light);margin:0 -24px;padding:12px 24px}.today-badge{background:var(--sipo-red);color:#fff;text-transform:uppercase;vertical-align:middle;border-radius:4px;margin-left:8px;padding:2px 6px;font-size:10px;font-weight:700}@media (max-width:1100px){.page-layout{gap:24px}}@media (max-width:900px){:root{--header-height:56px}.topbar-inner{padding:0 16px}.sipo-logo-img{height:24px}.btn-signup-black{height:40px;padding:0 16px;font-size:13px}.restaurant-hero{height:220px;margin-bottom:0}.hero-container{padding:0 16px}.restaurant-avatar-ref{border-radius:14px;width:64px;height:64px}.restaurant-name-block-ref h1{font-size:22px}.restaurant-status-row-ref{flex-wrap:wrap;gap:6px;font-size:12px}.hero-phone-link{font-size:12px}.hero-info-btn-ref{width:36px;height:36px;top:12px;right:12px}.restaurant-info-bar{padding:60px 16px 20px}.restaurant-meta{text-align:center;flex-direction:column;gap:12px;padding:0}.restaurant-avatar{z-index:30;border-width:3px;border-radius:50%;width:80px;height:80px;margin:0;position:absolute;top:-40px;left:50%;transform:translate(-50%)}.restaurant-avatar img{border-radius:50%}.restaurant-name-block{margin-top:40px}.restaurant-name-block h1{font-size:24px}.restaurant-status-row{flex-wrap:wrap;justify-content:center;gap:8px}.booking-nav{top:var(--header-height)}.booking-nav-inner{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;gap:6px;padding:0 16px;-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 16px calc(100% - 16px),#0000 100%);mask-image:linear-gradient(90deg,#0000 0,#000 16px calc(100% - 16px),#0000 100%)}.nav-tab{scroll-snap-align:start;padding:10px 14px;font-size:12px}.page-layout{grid-template-columns:minmax(0,1fr);gap:16px;margin:16px 0;padding:0 16px}.section-card{border-radius:var(--radius-xl)}.section-body{padding:16px}.date-scroll{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding-bottom:8px;scroll-padding-left:4px}.date-chip{scroll-snap-align:start;min-width:62px;padding:10px 0}.time-grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr))}.today-row{margin:0 -16px;padding:12px 16px}.site-footer{padding:32px 16px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.footer-links{gap:16px}.info-card-ref{gap:12px;padding:14px}.hours-row-ref{padding:10px 16px;font-size:13px}.hours-tab{padding:8px;font-size:10px}.legal-card{padding:14px}.address-text{max-width:200px;font-size:12px}.form-input,.form-textarea{min-height:48px;font-size:16px!important}.form-textarea{min-height:100px}.input-row{flex-direction:column;gap:16px}.gs-btn{border-radius:12px;width:44px;height:44px}.gs-val{min-width:28px;font-size:20px}.guest-hint{font-size:12px}.action-pills{gap:8px;margin-top:16px}.action-pill{border-radius:16px;padding:16px 6px;font-size:11px}.mobile-cta-wrapper{bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;left:16px;right:16px}.mobile-floating-btn{color:#fff;cursor:pointer;background:#000;border:none;border-radius:16px;justify-content:space-between;align-items:center;width:100%;height:56px;padding:0 20px;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 8px 30px #0000004d}.mobile-floating-btn:active{transform:scale(.98)}.mobile-floating-badge{color:#fff;background:#fff3;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.mobile-powered-by-fixed{text-align:center;color:var(--text-4);letter-spacing:.02em;background:#fff;border-radius:8px;margin-top:4px;padding:4px;font-size:10px;font-weight:600}.mobile-powered-by-fixed a{color:var(--primary);font-weight:700;text-decoration:none;transition:color .2s}body{padding-bottom:0}}@media (max-width:768px){.hero-title-desktop{display:none}.hero-title-mobile{display:block}.restaurant-hero{height:190px}.hero-content-bottom{padding-bottom:20px}.hero-meta-row{gap:12px}.restaurant-avatar-ref{border-width:3px;border-radius:12px;width:56px;height:56px}.restaurant-name-block-ref h1{margin-bottom:2px;font-size:20px}.restaurant-status-row-ref{flex-wrap:wrap;gap:4px;font-size:11px}.address-text{white-space:normal;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;width:100%;max-width:none;font-size:11px;line-height:1.3;display:-webkit-box;overflow:hidden}.hero-phone-link{font-size:11px;display:inline-flex}.restaurant-avatar{border-width:3px;width:72px;height:72px;top:-36px}.restaurant-name-block{margin-top:40px}.restaurant-name-block h1{font-size:22px}.container{padding:0 16px}.booking-nav-inner{gap:4px;padding:0 12px}.nav-tab{padding:10px 14px;font-size:13px;font-weight:700}.section-head{padding:16px 16px 0}.section-head h2{font-size:18px}.step-indicator{margin-bottom:24px}.step-item span{font-size:12px}.step-line{margin:0 10px}.time-chip{justify-content:center;align-items:center;min-height:44px;padding:12px 8px;font-size:13px;display:flex}.action-grid{grid-template-columns:1fr 1fr 1fr;gap:8px}.action-card{padding:14px 6px;font-size:10px}.confirm-card{padding:16px}.confirm-row{padding:10px 0}.footer-sipo-name{font-size:13px}.footer-copy{font-size:11px}}@media (max-width:480px){:root{--header-height:52px}.restaurant-hero{height:170px}.hero-content-bottom{padding-bottom:14px}.hero-container{padding:0 12px}.restaurant-avatar-ref{border-width:2px;border-radius:10px;width:44px;height:44px}.restaurant-name-block-ref h1{letter-spacing:-.02em;font-size:17px}.restaurant-status-row-ref{gap:3px;font-size:10px}.status-dot{width:6px;height:6px}.separator{margin:0 2px;font-size:10px}.hero-info-btn-ref{width:32px;height:32px;top:8px;right:8px}.hero-info-btn-ref svg{width:15px!important;height:15px!important}.page-layout{gap:12px;margin:12px 0;padding:0 12px}.section-card{border-radius:16px}.section-body{padding:12px}.section-head{gap:10px;padding:12px 12px 0}.section-head-icon{border-radius:8px;width:28px;height:28px}.section-head h2{font-size:16px}.step-indicator{margin-bottom:16px}.step-dot{width:22px;height:22px;font-size:11px}.step-item span{white-space:nowrap;font-size:10px}.step-line{margin:0 6px}.date-scroll{gap:5px;margin-left:-2px;margin-right:-2px;padding-left:2px;padding-right:2px}.date-chip{border-radius:12px;min-width:52px;padding:8px 0}.dc-day{font-size:8px}.dc-num{font-size:13px}.dc-mon{font-size:8px}.time-grid{grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:6px}.time-chip{border-radius:12px;min-height:42px;padding:10px 6px;font-size:12px}.btn-primary{border-radius:14px;padding:14px;font-size:14px}.btn-secondary{padding:10px 16px;font-size:13px}.guest-stepper{gap:16px}.field-label{margin-bottom:8px;font-size:13px}.field-group{margin-bottom:18px}.info-card-ref{border-radius:14px;gap:10px;margin-bottom:10px;padding:12px}.info-icon-box{width:34px;height:34px}.info-content-text{font-size:13px}.hours-card-ref{border-radius:14px}.hours-row-ref{padding:10px 14px;font-size:12px}.hours-tab-bar{padding:3px}.hours-tab{border-radius:8px;padding:7px;font-size:9px}.legal-card{border-radius:14px;padding:12px}.map-box{border-radius:14px!important;height:140px!important}.site-footer{padding:24px 12px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.footer-inner{gap:8px}.footer-links{gap:10px}.footer-links a{font-size:11px}.footer-sipo-logo{width:20px;height:20px;font-size:9px}.footer-sipo-name{font-size:12px}.footer-copy{font-size:11px}.action-pills{grid-template-columns:repeat(4,1fr);gap:6px;margin-top:12px}.action-pill{border-radius:14px;gap:6px;padding:12px 4px;font-size:10px}.action-pill-icon{border-radius:10px;width:34px;height:34px}.action-pill-icon svg{width:16px!important;height:16px!important}.time-legend{gap:12px;margin-top:12px;font-size:11px}body{padding-bottom:0}.success-title{font-size:20px}.success-sub{margin-bottom:20px;font-size:13px}.success-check{width:52px;height:52px;margin-bottom:16px}.action-grid{gap:6px;margin-bottom:20px}.action-card{border-radius:12px;gap:6px;padding:12px 4px;font-size:10px}.action-card svg{width:18px!important;height:18px!important}}@media (max-width:375px){.restaurant-hero{height:150px}.restaurant-name-block-ref h1{font-size:15px}.restaurant-avatar-ref{border-radius:8px;width:40px;height:40px}.hero-meta-row{gap:8px}.restaurant-status-row-ref{font-size:9px}.nav-tab{padding:8px 10px;font-size:11px}.step-item span{font-size:9px}.step-dot{width:20px;height:20px;font-size:10px}.step-line{margin:0 4px}.date-chip{min-width:46px}.dc-num{font-size:12px}.time-grid{grid-template-columns:repeat(3,1fr)}.section-head h2{font-size:15px}.action-pills{grid-template-columns:repeat(2,1fr)}.action-pill{flex-direction:row;gap:10px;padding:12px}.action-pill-icon{border-radius:8px;width:32px;height:32px}}.nav-item{color:var(--text-3);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;font-size:10px;font-weight:600;text-decoration:none;transition:color .2s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item.active,.nav-item:hover{color:var(--primary)}.action-pills{grid-template-columns:repeat(4,1fr);gap:10px;margin-top:24px;display:grid}.action-pill{border:1px solid var(--border-color);cursor:pointer;color:var(--text-2);background:#fff;border-radius:20px;flex-direction:column;align-items:center;gap:8px;padding:20px 8px;font-size:12px;font-weight:700;text-decoration:none;transition:all .2s;display:flex;box-shadow:0 2px 8px #00000008}.action-pill:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px);box-shadow:0 6px 20px #0000000f}.action-pill-icon{border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.action-pill-icon.blue{color:#3b82f6;background:linear-gradient(135deg,#3b82f61f,#3b82f60a)}.action-pill-icon.emerald{color:#10b981;background:linear-gradient(135deg,#10b9811f,#10b9810a)}.action-pill-icon.orange{color:#f97316;background:linear-gradient(135deg,#f973161f,#f973160a)}.action-pill-icon.red{color:var(--primary);background:linear-gradient(135deg,#e8553e1f,#e8553e0a)}.info-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#0006;justify-content:center;align-items:flex-end;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.info-modal-container{background:#fff;border-radius:32px 32px 0 0;flex-direction:column;width:100%;max-width:600px;max-height:90vh;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;display:flex;box-shadow:0 -10px 40px #0003}.info-modal-handle-wrap{flex-shrink:0;justify-content:center;align-items:center;height:24px;display:flex}.info-modal-handle{background:#e5e7eb;border-radius:2px;width:36px;height:4px}.info-modal-header{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:0 24px 16px;display:flex}.info-modal-title{color:#111827;font-size:20px;font-weight:800}.info-modal-subtitle{color:#6b7280;font-size:13px;font-weight:600}.info-modal-close{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.info-modal-body{flex:1;padding:24px;overflow-y:auto}.modal-info-card{background:#f9fafb;border-radius:20px;align-items:center;gap:16px;margin-bottom:16px;padding:16px;display:flex}.modal-info-icon{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.modal-info-icon.blue{color:#3b82f6;background:#eff6ff}.modal-info-icon.emerald{color:#10b981;background:#ecfdf5}.modal-info-icon.purple{color:#a855f7;background:#faf5ff}.modal-info-text{color:#111827;font-size:15px;font-weight:700}.modal-info-sub{color:#6b7280;font-size:13px;font-weight:600}.modal-section{margin-top:24px}.modal-section-label{color:#111827;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-size:14px;font-weight:800}.modal-hours-card{border:1px solid #f3f4f6;border-radius:24px;overflow:hidden}.modal-hours-tabs{background:#f9fafb;gap:4px;padding:4px;display:flex}.modal-hours-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;padding:8px;font-size:11px;font-weight:800}.modal-hours-tab.active{color:var(--sipo-red);background:#fff;box-shadow:0 2px 8px #0000000d}.modal-hours-list{padding:12px 0}.modal-hour-row{justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.modal-hour-row.is-today{background:#fef2f2}.modal-hour-day{color:#374151;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.modal-hour-time{color:#111827;font-size:14px;font-weight:600}.modal-hour-closed{color:#ef4444;font-size:14px;font-weight:600}.info-modal-footer{text-align:center;color:#9ca3af;letter-spacing:.1em;border-top:1px solid #f3f4f6;padding:16px;font-size:10px;font-weight:800}.modal-legal-card{background:#f9fafb;border-radius:16px;margin-top:8px;padding:16px}.modal-legal-card.amber{background:#fffbeb}.modal-legal-text{color:#4b5563;font-size:13px;line-height:1.6}.modal-legal-link{color:var(--sipo-red);align-items:center;gap:6px;font-size:13px;font-weight:700;text-decoration:none;display:flex}@media (min-width:640px){.info-modal-overlay{align-items:center}.info-modal-container{border-radius:32px;margin:24px}}.site-footer{border-top:1px solid var(--border-color);background:#fff;padding:32px 24px}.footer-inner{flex-direction:column;align-items:center;gap:8px;max-width:600px;margin:0 auto;display:flex}.footer-brand{align-items:center;gap:8px;display:flex}.footer-sipo-logo{background:var(--sipo-red);color:#fff;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:10px;font-weight:900;display:flex;box-shadow:0 2px 8px #e8362a4d}.footer-sipo-name{color:var(--text-1);letter-spacing:-.02em;font-size:14px;font-weight:800}.footer-copy{color:var(--text-3);margin:0;font-size:12px;font-weight:500}@keyframes scaleIn{0%{opacity:0;transform:scale(.98)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.animate-fade-in{animation:.6s ease-out forwards fadeIn}.animate-scale-in{animation:.8s cubic-bezier(.16,1,.3,1) forwards scaleIn}.topbar{z-index:1000;background:#fff;border-bottom:1px solid #f3f4f6;align-items:center;height:52px;display:flex;position:sticky;top:0}.header-mobile-optimized{justify-content:space-between;align-items:center;width:100%;max-width:1280px;margin:0 auto;padding:0 16px;display:flex}.sipo-logo-img-optimized{object-fit:contain;width:auto;height:22px}.topbar-auth-optimized{align-items:center;gap:8px;display:flex}.auth-btn-login{color:#000;cursor:pointer;background:0 0;border:none;border-radius:9999px;height:32px;padding:0 12px;font-size:13px;font-weight:700;transition:background .2s}.auth-btn-login:hover{background:#f9fafb}.auth-btn-signup{color:#fff;cursor:pointer;background:#000;border:none;border-radius:9999px;height:32px;padding:0 16px;font-size:13px;font-weight:700;transition:background .2s}.auth-btn-signup:hover{background:#333}.restaurant-hero-optimized{color:#fff;background:radial-gradient(circle at 100% 0,#1f2937,#111827);height:170px;position:relative;overflow:hidden}.hero-img-optimized{object-fit:cover;opacity:.5;width:100%;height:100%}.hero-img-placeholder-optimized{opacity:.5;background:linear-gradient(135deg,#1f2937 0%,#111827 100%);width:100%;height:100%}.hero-overlay-optimized{pointer-events:none;background:linear-gradient(#0000 30%,#000000d9 100%);position:absolute;inset:0}.hero-top-actions{z-index:10;gap:8px;display:flex;position:absolute;top:12px;right:12px}.hero-action-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .2s;display:flex}.hero-action-btn:active{transform:scale(.9)}.hero-bottom-info{z-index:10;position:absolute;bottom:12px;left:12px;right:12px}.hero-info-container{align-items:center;gap:10px;display:flex}.restaurant-logo-optimized{background:#000;border:2px solid #ffffffe6;border-radius:10px;flex-shrink:0;width:44px;height:44px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.restaurant-logo-optimized img{object-fit:cover;width:100%;height:100%}.logo-placeholder{background:#000;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.logo-placeholder span{color:#fff;font-size:18px;font-weight:900}.restaurant-meta-optimized{flex:1;min-width:0}.name-status-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.restaurant-title-optimized{color:#fff;letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:17px;font-weight:700;line-height:1.1;overflow:hidden}.status-pill{background:0 0;align-items:center;gap:6px;padding:0;font-size:12px;font-weight:600;display:flex}.status-pill.is-open{color:#34d399}.status-pill.is-closed{color:#f87171}.status-pill .dot{border-radius:50%;width:6px;height:6px}.status-pill.is-open .dot{background:#34d399}.status-pill.is-closed .dot{background:#f87171}.restaurant-address-optimized{color:#d1d5db;white-space:nowrap;text-overflow:ellipsis;margin:2px 0 0;font-size:12px;overflow:hidden}@media (min-width:1024px){.topbar{height:72px}.sipo-logo-img-optimized{height:28px}.auth-btn-login,.auth-btn-signup{height:48px;font-size:15px}.auth-btn-login{border-radius:var(--radius-lg);padding:10px 16px;font-weight:600}.auth-btn-signup{border-radius:var(--radius-full);padding:0 20px;font-weight:600}.restaurant-hero-optimized{height:280px}.hero-bottom-info{width:100%;max-width:1280px;margin:0;padding:0 24px;bottom:32px;left:50%;transform:translate(-50%)}.header-mobile-optimized{max-width:1440px;padding:0 24px}.hero-info-container{align-items:flex-end;gap:20px}.restaurant-logo-optimized{width:80px;height:80px;box-shadow:var(--shadow-elevated);border:4px solid #fff;border-radius:16px}.restaurant-meta-optimized{flex-wrap:wrap;align-items:center;gap:4px 8px;display:flex}.name-status-row{display:contents}.restaurant-title-optimized{width:100%;margin:0;font-size:30px;line-height:1.2}.status-pill{order:2}.restaurant-address-optimized{order:3;align-items:center;margin-top:0;font-size:14px;display:flex}.restaurant-address-optimized:before{content:"•";opacity:.5;margin-right:8px}.hero-top-actions{justify-content:flex-end;width:100%;max-width:1280px;margin:0;padding:0 24px;top:24px;left:50%;transform:translate(-50%)}.mobile-only-hero{display:none!important}.header-left-side{align-items:center;gap:24px;display:flex}.desktop-restaurant-info{align-items:center;gap:16px;animation:.5s ease-out fadeIn;display:flex}.header-separator{background:#e5e7eb;width:1px;height:32px}.header-restaurant-logo{background:#fff;border-radius:12px;flex-shrink:0;width:44px;height:44px;overflow:hidden;box-shadow:0 4px 12px #00000014}.header-restaurant-logo img{object-fit:cover;width:100%;height:100%}.logo-letter{background:linear-gradient(135deg, var(--sipo-red), var(--sipo-red-dark));color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;font-weight:700;display:flex}.header-restaurant-meta{flex-direction:column;gap:2px;display:flex}.header-restaurant-name{color:#111827;letter-spacing:-.02em;font-size:16px;font-weight:700}.header-restaurant-status{align-items:center;gap:6px;display:flex}.header-restaurant-status .status-dot{border-radius:50%;width:6px;height:6px}.header-restaurant-status .status-text{text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.header-restaurant-status .status-dot.is-open{background-color:#10b981}.header-restaurant-status .status-text:has(+.is-open){background-color:#10b981}.header-restaurant-status:has(.is-open) .status-text{color:#10b981}.header-restaurant-status:has(.is-closed) .status-text{color:#ef4444}.header-restaurant-status .status-dot.is-closed{background-color:#ef4444}.desktop-hero-container{background:#0a0a0b;border-radius:0 0 4rem 4rem;align-items:center;min-height:520px;margin-bottom:40px;padding:0 5%;display:flex;position:relative;overflow:hidden}.desktop-hero-bg{z-index:0;position:absolute;inset:0}.desktop-hero-bg-img{object-fit:cover;opacity:.45;filter:brightness(.8)contrast(1.1);width:100%;height:100%}.desktop-hero-bg-placeholder{background:linear-gradient(135deg,#0f0c29,#1a1a2e,#16213e);width:100%;height:100%}.desktop-hero-overlay{background:linear-gradient(#0000 0%,#0a0a0b66 50%,#0a0a0b 100%);position:absolute;inset:0}.desktop-hero-glow-1{filter:blur(80px);pointer-events:none;background:radial-gradient(circle,#e8553e26 0%,#0000 70%);width:500px;height:500px;position:absolute;top:-100px;right:-100px}.desktop-hero-glow-2{filter:blur(60px);pointer-events:none;background:radial-gradient(circle,#f2896a1a 0%,#0000 70%);width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.desktop-hero-content{z-index:10;grid-template-columns:1.2fr .8fr;gap:40px;width:100%;max-width:1400px;margin:0 auto;padding:40px 0;display:grid;position:relative}.premium-tag{color:var(--sipo-red);text-transform:uppercase;letter-spacing:.4em;margin-bottom:20px;font-size:12px;font-weight:800;animation:.8s ease-out slideDown;display:inline-block}.desktop-hero-title{color:#fff;letter-spacing:-.04em;margin-bottom:32px;font-size:clamp(3rem,5vw,4.5rem);font-weight:900;line-height:.95;animation:.8s ease-out slideUp}.italic-gradient{background:linear-gradient(90deg,#f2896a,#e8553e);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:italic}.desktop-hero-description{color:#fff9;max-width:540px;margin-bottom:48px;font-size:18px;font-weight:500;line-height:1.6;animation:1s ease-out slideUp}.btn-explore-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);color:#fff;text-transform:uppercase;letter-spacing:.15em;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:12px;padding:18px 36px;font-size:14px;font-weight:800;transition:all .4s cubic-bezier(.4,0,.2,1);animation:1.2s ease-out slideUp;display:flex}.btn-explore-menu:hover{border-color:var(--sipo-red);background:#fff3;transform:translateY(-5px);box-shadow:0 20px 40px #0000004d}.btn-explore-menu svg{color:var(--sipo-red)}}@media (max-width:1023px){.desktop-hero-container,.desktop-restaurant-info{display:none!important}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
