:root{
  --vinho:#87374d;
  --vinho-claro:#a25268;
  --vinho-escuro:#552233;
  --verde:#4a5e3b;
  --creme:#fff7ed;
  --branco:#ffffff;
  --texto:#26161a;
  --muted:#7c6a6e;
  --borda:#f0e2e5;
  --sombra:0 22px 60px rgba(45,18,28,.16);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;background:linear-gradient(180deg,#fff7ed 0%,#fff 52%,#fff7ed 100%);color:var(--texto)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.hero{position:relative;padding:28px 7vw 90px;background:radial-gradient(circle at 15% 20%,#b96f86 0,#87374d 35%,#552233 100%);color:#fff;overflow:hidden}
.hero:before{content:"";position:absolute;right:-180px;top:120px;width:520px;height:520px;border-radius:50%;background:rgba(255,255,255,.08)}
.hero:after{content:"";position:absolute;left:-160px;bottom:-220px;width:520px;height:520px;border-radius:50%;background:rgba(255,214,160,.12)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(0,0,0,.08),rgba(0,0,0,0) 48%)}
.topbar{position:relative;z-index:3;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:16px}
.brand__logo{width:74px;height:74px;border-radius:22px;object-fit:cover;box-shadow:0 14px 30px rgba(0,0,0,.18);background:rgba(255,255,255,.15)}
.brand strong{display:block;font-size:19px}
.brand span{display:block;font-size:13px;opacity:.86;margin-top:2px}
.topbar__actions{display:flex;align-items:center;gap:14px}
.topbar__link{font-weight:700;opacity:.92}
.topbar__whats{padding:13px 20px;border-radius:999px;background:#fff;color:var(--vinho);font-weight:800;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center;margin-top:48px}
.hero__content{max-width:700px}
.badge{display:inline-flex;padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.18);font-weight:700}
.hero h1{font-family:Playfair Display,serif;font-size:clamp(44px,6vw,78px);line-height:.98;margin:24px 0 18px}
.hero p{font-size:19px;line-height:1.65;max-width:600px;opacity:.94}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero__miniinfo{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}
.hero__miniinfo div{padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(4px)}
.hero__miniinfo strong{display:block;margin-bottom:6px;font-size:14px}
.hero__miniinfo span{font-size:13px;opacity:.88;line-height:1.45}
.hero__showcase{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.showcase-card{position:relative;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:30px;padding:10px;backdrop-filter:blur(8px);box-shadow:0 18px 40px rgba(24,8,14,.16)}
.showcase-card--big{grid-column:span 2}
.showcase-card img{width:100%;height:220px;object-fit:cover;border-radius:22px}
.showcase-card--big img{height:300px}
.showcase-card__label{position:absolute;left:24px;bottom:24px;background:rgba(31,13,18,.66);border:1px solid rgba(255,255,255,.14);padding:10px 14px;border-radius:999px;font-weight:800;font-size:14px}
.btn{border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:15px 22px;border-radius:18px;font-weight:800;font-size:15px;transition:.2s}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--vinho);color:#fff;box-shadow:0 16px 35px rgba(135,55,77,.28)}
.hero .btn--primary{background:#fff;color:var(--vinho)}
.btn--ghost{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);color:#fff}
.btn--full{width:100%}
.info-strip{width:min(1180px,88vw);margin:-42px auto 30px;position:relative;z-index:4;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.info-strip div{background:#fff;border-radius:24px;padding:22px;box-shadow:var(--sombra)}
.info-strip strong{display:block;color:var(--vinho);margin-bottom:6px}
.info-strip span{color:var(--muted);font-size:14px;line-height:1.5}
.section{width:min(1180px,88vw);margin:72px auto}
.section__title{text-align:center;max-width:760px;margin:0 auto 32px}
.section__title span{color:var(--vinho);font-weight:900;text-transform:uppercase;letter-spacing:.13em;font-size:12px}
.section__title h2{font-family:Playfair Display,serif;font-size:clamp(34px,5vw,58px);margin:8px 0}
.section__title p{color:var(--muted);font-size:17px;line-height:1.6}
.filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.filter{border:1px solid #ead9dd;background:#fff;color:var(--vinho);padding:11px 15px;border-radius:999px;font-weight:800;cursor:pointer;transition:.18s}
.filter:hover{transform:translateY(-1px)}
.filter.active{background:var(--vinho);color:#fff;border-color:var(--vinho)}
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.product{background:#fff;border:1px solid var(--borda);border-radius:var(--radius);overflow:hidden;box-shadow:0 12px 40px rgba(80,35,49,.08);display:flex;flex-direction:column;transition:.2s}
.product:hover{transform:translateY(-4px);box-shadow:0 18px 46px rgba(80,35,49,.12)}
.product__photo{height:210px;background:linear-gradient(135deg,#87374d,#3d4e36);display:grid;place-items:center;color:#fff;font-size:52px;position:relative;overflow:hidden}
.product__photo img{width:100%;height:100%;object-fit:cover}
.product__photo.has-image{background:#f7f2f4}
.product__body{padding:22px;display:flex;flex-direction:column;gap:12px;flex:1}
.product__cat{display:inline-flex;align-self:flex-start;padding:7px 10px;border-radius:999px;background:#fff1f4;color:var(--vinho);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.product h3{font-family:Playfair Display,serif;font-size:28px;line-height:1.05;margin:0;color:var(--vinho)}
.product p{margin:0;color:var(--muted);font-size:14px;line-height:1.55;min-height:44px}
.product__bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
.price{font-size:22px;font-weight:900;color:var(--texto)}
.add{background:var(--verde);color:#fff;border:0;border-radius:15px;padding:12px 14px;font-weight:900;cursor:pointer;transition:.18s}
.add:hover{filter:brightness(1.08)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-grid img,.menu-grid img{width:100%;height:360px;object-fit:cover;object-position:top;border-radius:24px;box-shadow:var(--sombra);background:#eee}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cart{position:fixed;right:20px;top:20px;bottom:20px;width:min(430px,calc(100vw - 40px));background:#fff;border-radius:30px;box-shadow:0 30px 90px rgba(0,0,0,.24);z-index:25;padding:20px;transform:translateX(calc(100% + 40px));transition:.25s;display:flex;flex-direction:column}
.cart.open{transform:translateX(0)}
.cart__header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--borda);padding-bottom:14px}
.cart__header span{color:var(--vinho);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.12em}
.cart__header h3{font-family:Playfair Display,serif;font-size:32px;margin:3px 0 0}
.cart__close{width:42px;height:42px;border:0;border-radius:50%;background:#fff0f4;color:var(--vinho);font-size:28px;cursor:pointer}
.cart__items{overflow:auto;max-height:240px;padding:12px 0}
.empty{color:var(--muted);text-align:center;padding:28px 10px}
.cart-item{display:grid;grid-template-columns:1fr auto;gap:8px;padding:12px 0;border-bottom:1px dashed #ead9dd}
.cart-item strong{display:block;font-size:14px}
.cart-item span{color:var(--muted);font-size:13px}
.qty{display:flex;align-items:center;gap:8px}
.qty button{width:28px;height:28px;border:0;border-radius:9px;background:#fff0f4;color:var(--vinho);font-weight:900;cursor:pointer}
.cart__total{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-top:1px solid var(--borda);border-bottom:1px solid var(--borda)}
.cart__total strong{font-size:26px;color:var(--vinho)}
.checkout{overflow:auto;padding-top:14px}
.checkout h4{margin:0 0 12px;font-size:18px}
.checkout label{display:block;font-size:13px;font-weight:800;margin:10px 0 6px;color:#4a343b}
.checkout input,.checkout textarea,.checkout select{width:100%;margin-top:6px;border:1px solid #ead9dd;border-radius:14px;padding:12px 13px;font-family:inherit;font-size:14px;outline:none;background:#fff}
.checkout input:focus,.checkout textarea:focus,.checkout select:focus{border-color:var(--vinho)}
.mini-note{text-align:center;color:var(--muted);font-size:12px}
.floating-cart{position:fixed;right:24px;bottom:24px;z-index:15;border:0;border-radius:999px;background:var(--vinho);color:#fff;padding:16px 22px;font-weight:900;box-shadow:0 18px 44px rgba(135,55,77,.35);cursor:pointer}
.floating-cart span{display:inline-grid;place-items:center;background:#fff;color:var(--vinho);min-width:24px;height:24px;border-radius:999px;margin-left:6px}

@media (max-width:1100px){
  .hero__grid{grid-template-columns:1fr;gap:24px}
  .hero__content{max-width:none}
  .products{grid-template-columns:repeat(2,1fr)}
  .gallery-grid,.menu-grid{grid-template-columns:repeat(2,1fr)}
  .info-strip,.hero__miniinfo{grid-template-columns:1fr}
}
@media (max-width:620px){
  .hero{padding:22px 22px 80px}
  .topbar__link{display:none}
  .topbar__whats{display:none}
  .brand__logo{width:60px;height:60px;border-radius:18px}
  .hero h1{font-size:40px}
  .hero p{font-size:16px}
  .section,.info-strip{width:calc(100vw - 32px)}
  .hero__showcase{grid-template-columns:1fr}
  .showcase-card--big{grid-column:span 1}
  .showcase-card img,.showcase-card--big img{height:220px}
  .products,.gallery-grid,.menu-grid{grid-template-columns:1fr}
  .gallery-grid img,.menu-grid img{height:auto;max-height:none}
  .cart{right:10px;left:10px;top:10px;bottom:10px;width:auto}
  .floating-cart{right:18px;bottom:18px}
  .product__photo{height:180px}
}

/* Melhorias comerciais */
.promo-section{margin-top:38px}
.promo-card{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:center;background:linear-gradient(135deg,var(--vinho),var(--vinho-escuro));color:#fff;border-radius:36px;padding:34px;box-shadow:var(--sombra);overflow:hidden;position:relative}
.promo-card:before{content:"";position:absolute;right:-110px;top:-130px;width:330px;height:330px;border-radius:50%;background:rgba(255,255,255,.08)}
.promo-eyebrow{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);padding:9px 13px;border-radius:999px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.12em}
.promo-card h2{font-family:Playfair Display,serif;font-size:clamp(34px,5vw,58px);line-height:1;margin:18px 0 14px}
.promo-card p{font-size:17px;line-height:1.65;opacity:.92;max-width:620px}
.promo-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.btn--light{background:#fff;color:var(--vinho)}
.promo-card__image{position:relative;z-index:2}.promo-card__image img{width:100%;height:360px;object-fit:cover;border-radius:28px;box-shadow:0 22px 52px rgba(0,0,0,.22)}
.rules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}.rules-grid article{background:#fff;border:1px solid var(--borda);border-radius:24px;padding:20px;box-shadow:0 12px 34px rgba(80,35,49,.07)}.rules-grid strong{display:block;color:var(--vinho);margin-bottom:8px}.rules-grid span{display:block;color:var(--muted);font-size:14px;line-height:1.5}.order-notice{background:#fff4f7;border:1px solid #efd3dc;color:#6a3142;border-radius:20px;padding:16px 18px;margin:-10px auto 22px;max-width:880px;text-align:center;font-size:14px;line-height:1.5}.combo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.combo{background:#fff;border:1px solid var(--borda);border-radius:24px;padding:18px;box-shadow:0 12px 34px rgba(80,35,49,.07);display:flex;align-items:center;justify-content:space-between;gap:16px}.combo strong{display:block;color:var(--vinho);font-family:Playfair Display,serif;font-size:22px}.combo span{display:block;color:var(--muted);font-size:13px;margin-top:4px}.combo button{background:var(--vinho);color:#fff;border:0;border-radius:14px;padding:11px 13px;font-weight:900;cursor:pointer;white-space:nowrap}
@media (max-width:1100px){.promo-card{grid-template-columns:1fr}.rules-grid{grid-template-columns:repeat(2,1fr)}.combo-grid{grid-template-columns:1fr}}
@media (max-width:620px){.promo-card{padding:24px;border-radius:28px}.promo-card__image img{height:240px}.rules-grid{grid-template-columns:1fr}.combo{align-items:flex-start;flex-direction:column}.combo button{width:100%}}


/* Status do pedido + Apps Script */
.status-section{margin-top:48px}
.status-card{background:#fff;border:1px solid var(--borda);border-radius:30px;padding:26px;box-shadow:var(--sombra)}
.status-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;border-bottom:1px solid var(--borda);padding-bottom:18px;margin-bottom:18px}
.status-card__head span{color:var(--vinho);font-weight:900;text-transform:uppercase;letter-spacing:.13em;font-size:12px}
.status-card__head h2{font-family:Playfair Display,serif;color:var(--vinho);font-size:42px;margin:6px 0 8px}
.status-card__head p{margin:0;color:var(--muted);line-height:1.55}
.status-admin-link{white-space:nowrap;background:#fff0f4;color:var(--vinho);border:1px solid #efd3dc;border-radius:999px;padding:12px 15px;font-weight:900;font-size:13px}
.status-search{display:grid;grid-template-columns:1fr auto;gap:12px;margin-bottom:18px}
.status-search input{border:1px solid #ead9dd;border-radius:18px;padding:15px 16px;font-size:16px;outline:0;text-transform:uppercase}
.status-search input:focus{border-color:var(--vinho)}
.status-empty{background:#fff7fa;border:1px dashed #eacbd4;border-radius:20px;padding:18px;color:var(--muted);text-align:center}
.status-order-card{background:#fff7fa;border:1px solid #edcfd8;border-radius:24px;padding:22px}
.status-order-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.status-order-top h3{font-family:Playfair Display,serif;color:var(--vinho);font-size:34px;margin:0 0 6px}
.status-order-top p{margin:0;color:var(--muted)}
.status-order-top span{background:#e9f8e9;color:#2d7b35;border-radius:999px;padding:9px 12px;font-weight:900;font-size:13px;white-space:nowrap}
.status-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:18px 0}
.status-step{background:#fff;border:1px solid #ead9dd;border-radius:18px;padding:14px 10px;text-align:center;color:#6d575f;font-size:13px;font-weight:900;min-height:70px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.status-step b{display:block;width:14px;height:14px;border-radius:50%;background:#e4d2d8}
.status-step.active{border-color:#d28ba0;background:#fff1f5;color:var(--vinho)}
.status-step.active b{background:var(--vinho)}
.status-details{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}
.status-details div{background:#fff;border:1px solid #ead9dd;border-radius:18px;padding:14px}
.status-details small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;margin-bottom:6px}
.status-details strong{font-size:18px;color:#160f12}
.status-whats{display:inline-flex;margin-top:4px}
@media (max-width:720px){.status-card{padding:18px}.status-card__head{flex-direction:column}.status-card__head h2{font-size:32px}.status-search{grid-template-columns:1fr}.status-timeline{grid-template-columns:1fr}.status-details{grid-template-columns:1fr}.status-order-top{flex-direction:column}.status-whats{width:100%}}
