:root{
  --coral:#ef5a57;
  --bg:#ececec;
  --card:#ffffff;
  --text:#101010;
  --muted:rgba(16,16,16,.62);
  --line:rgba(0,0,0,.08);
  --soft:#f6f6f6;
  --shadow:0 14px 34px rgba(0,0,0,.10);
  --radius-xl:18px;
  --radius-lg:16px;
  --radius-md:14px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,a,input,textarea,select{font:inherit;color:inherit;-webkit-appearance:none;appearance:none}
.hidden{display:none!important}
.app-shell{width:100%;max-width:430px;margin:0 auto;min-height:100vh;background:#fff;overflow-x:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.02);position:relative}
.header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.header-inner{min-height:60px;display:flex;align-items:center;justify-content:center;padding:0 15px;position:relative}
.brand-select img{width:170px;height:auto;object-fit:contain}
.menu-btn,.icon-btn,.selection-trigger,.delete-btn,.add-btn,.pairing-add,.lightbox-close,.category-back{border:0;border-radius:999px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#fff;z-index: 9999;}
.menu-btn{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  width:46px;
  height:46px;
  background:transparent;
  color:#ef5a57;
}

.menu-icon{
  display:flex;
  align-items:center;
  justify-content:center;
}

.menu-icon svg{
  width:38px;
  height:38px;
}
.overlay{position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.40);opacity:0;visibility:hidden;transition:.22s ease}
.overlay.show{opacity:1;visibility:visible}
.category-panel{position:fixed;top:72px;right:14px;z-index:80;width:calc(100% - 28px);max-width:320px;background:#fff;border-radius:18px;padding:16px;box-shadow:0 24px 60px rgba(0,0,0,.18);opacity:0;transform:translateY(-8px) scale(.98);visibility:hidden;transition:.2s ease}
.category-panel.show{opacity:1;transform:translateY(0) scale(1);visibility:visible}
.category-item{width:100%;border:0;background:transparent;display:flex;align-items:center;gap:12px;padding:12px 0;text-align:left;cursor:pointer}
.category-item + .category-item{border-top:1px solid var(--line)}
.category-item span:last-child{font-size:18px;font-weight:600;letter-spacing:-.03em}
.content{padding:5px 14px 30px}
.section-block{margin-bottom:5px}
.section-spacing{margin-top:14px}
.section-title{margin:0 0 0px;font-size:20px;line-height:1;font-weight:600;letter-spacing:-0.5px}
.hero-card,.category-slide,.category-dish,.pairing-card,.dish-card{width:100%;border:0;padding:0;position:relative;overflow:hidden;text-align:left;cursor:pointer;border-radius:18px;background:#ddd;box-shadow:var(--shadow)}
.hero-media{position:relative;height:600px;overflow:hidden; border-radius: 15px;}
.hero-media img,.category-slide img,.category-dish img,.detail-image img,.pairing-card img,.selection-thumb img,.lightbox-image img,.dish-card img{width:100%;height:100%;object-fit:cover;object-position:center center}
.hero-gradient,.category-slide::after,.category-dish::after,.detail-image::after,.pairing-card::after,.dish-card::after{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.44),rgba(0,0,0,.05) 52%,rgba(0,0,0,0) 75%)}
.badge-pill{position:absolute;z-index:2;top:14px;left:14px;background:rgba(255,255,255,.99);color:#111;border-radius:999px;padding:4px 10px;display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:500;box-shadow:0 3px 11px rgba(0,0,0,.05);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.hero-bottom{position:absolute;z-index:2;left:18px;right:18px;bottom:25px;display:flex;align-items:end;justify-content:space-between;gap:12px}
.hero-title {
    color: #fff;
    font-size: 22px;
    line-height: 1.1;
    font-weight: 600;
    max-width: 53%;
    text-shadow: 0 3px 10px rgba(0, 0, 0, .26);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.hero-side{display:grid;gap:12px;justify-items:end}
.hero-like{display:inline-flex;align-items:center;gap:7px;color:#fff;font-size:13px;font-weight:500;text-shadow:0 3px 10px rgba(0,0,0,.26)}
.quick-links{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px 8px 4px}
.quick-link{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.quick-link-image{width:110px;height:110px;border-radius:999px;padding:8px;background:linear-gradient(180deg,#f8f8f8,#ececec);box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.quick-link-image img{width:100%;height:100%;object-fit:cover;border-radius:999px}
.quick-link-label{font-size:14px;font-weight:600;letter-spacing:-.03em}
.dish-rail{display:flex;gap:7px;overflow-x:auto;padding:2px 0 2px;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none; height: 250px;}
.dish-rail::-webkit-scrollbar{display:none}
.rail-card{flex:0 0 44%;min-height:185px;scroll-snap-align:start}
.rail-card .dish-card-bottom{left:14px;right:14px;bottom:14px}
.rail-card .dish-card-title{max-width:90%;font-size:18px;line-height:.99;font-weight:600}
.category-slider{display:flex;gap:8px;overflow-x:auto;padding:2px 0 0;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;max-height:250px}
.category-slider::-webkit-scrollbar{display:none}
.category-slide{flex:0 0 45%;min-height:120px;scroll-snap-align:start}
.category-slide-content{position:absolute;inset:auto 12px 14px 16px;z-index:2;display:grid;gap:4px}
.category-slide-top{display:inline-flex;align-items:center;gap:7px;color:#fff;font-weight:700;font-size:14px;text-shadow:0 2px 8px rgba(0,0,0,.24)}
.category-slide-label{color:#fff;font-size:20px;line-height:.95;font-weight:600;letter-spacing:-1px;text-shadow:0 2px 8px rgba(0,0,0,.24)}
.first-time-row{text-align:center}
.first-time-btn{margin-top:18px;width:auto;border:0;border-radius:999px;background:#ec6a62;color:#fff;padding:14px 24px;font-size:15px;font-weight:600;box-shadow:0 16px 28px rgba(236,106,98,.22);cursor:pointer}
.footer{padding:18px 20px 26px 20px;text-align:center;background:#fff}
.footer-links{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:8px}
.footer-link{width:48px;height:48px;border-radius:999px;background:#fff;display:flex;align-items:center;justify-content:center;border:1px solid rgba(239,90,87,.2)}
.footer-name{font-size:13px;font-weight:600;color:var(--coral);margin-top:2px}
.footer-text{font-size:12px;color:rgba(0,0,0,.28);margin-top:10px;line-height:1.4}
.page-content{padding:14px 14px 28px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.page-heading{font-size:22px;line-height:.95;font-weight:700;letter-spacing:-1px;margin:0}
.page-sub{margin:6px 0 0;color:var(--muted);font-size:14px}
.category-back,.icon-btn{width:42px;height:42px;background:rgba(255,255,255,.82);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.category-list,.grid-list{display:grid;gap:16px}
.category-dish{height: 250px;}
.category-dish-bottom,.dish-card-bottom{position:absolute;z-index:2;left:18px;right:18px;bottom:18px;display:flex;align-items:end;justify-content:space-between;gap:12px}
.category-dish-title,.dish-card-title{color:#fff;font-size:24px;line-height:.95;font-weight:600;letter-spacing:-1px;text-shadow:0 2px 8px rgba(0,0,0,.24);max-width:66%}
.category-dish-price,.dish-card-price{color:#fff;font-size:14px;font-weight:400;text-shadow:0 2px 8px rgba(0,0,0,.24)}
.add-btn,.pairing-add{width:56px;height:56px;flex:0 0 56px;border-radius:999px;border:0;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#ffffff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 20px rgba(0,0,0,.12),inset 0 1px 1px rgba(255,255,255,.8);transition:transform .18s ease,background .18s ease,box-shadow .18s ease;padding:0;z-index:3}
.add-btn.is-added,.pairing-add.is-added{background:#f45b5b;box-shadow:0 10px 24px rgba(244,91,91,.28)}
.add-btn svg,.pairing-add svg{width:24px;height:24px;stroke:#111;stroke-width:2.2;transition:stroke .18s ease}
.add-btn.is-added svg,.pairing-add.is-added svg{stroke:#fff}
.detail-image{
  position:relative;
  overflow:hidden;
  background:#ddd;
  max-height:600px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.detail-controls-left{position:absolute;z-index:3;top:18px;left:18px;display:grid;gap:10px}
.detail-controls-right{position:absolute;z-index:3;top:18px;right:18px}
.detail-card{background:#fff;border-radius:18px;padding:18px 18px 16px;box-shadow:0 10px 40px rgba(0,0,0,.12);margin:-44px 16px 0;position:relative;z-index:5}
.detail-card-top{display:flex;gap:16px;align-items:flex-start}
.detail-name{flex:1;min-width:0;font-size:23px;line-height:.95;letter-spacing:-1px;font-weight:600;color:var(--text)}
.detail-desc{margin-top:4px;font-size:14px;line-height:1.15;color:rgba(0,0,0,.85)}
.detail-helper{margin-top:3px;font-size:14px;line-height:1.28;color:#ef5a57}
.detail-price{margin-top:-10px;text-align:right;font-size:20px;line-height:1;letter-spacing:-.04em;font-weight:700}
.pairings{margin-top:18px;background:#fff;padding:0 16px 0}
.pairings h3{margin:0 0 0px;font-size:20px;line-height:1;font-weight:500;letter-spacing:-1px}
.pairings-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;grid-auto-rows:140px}
.pairing-card{height:140px;min-height:0}
.pairing-card.wide{grid-column:1 / -1}
.pairing-body{position:absolute;inset:auto 14px 14px 14px;z-index:2;display:flex;align-items:end;justify-content:space-between;gap:8px}
.pairing-title{font-size:18px;line-height:.96;letter-spacing:-1px;font-weight:600;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.18);max-width:calc(100% - 56px)}

.selection-trigger{
  position:fixed;
  right:18px;
  bottom:26px;
  width:92px;
  height:92px;
  border-radius:999px;
  background:#f7f7f7;
  box-shadow:0 12px 30px rgba(0,0,0,.10);
  z-index:140;
}

.selection-trigger-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  color:var(--coral);
}

.selection-trigger-icon svg{
  width:44px;
  height:44px;
  display:block;
}

.selection-trigger-icon img{
  width:30px;
  height:30px;
  object-fit:contain;
  display:block;
}

.selection-trigger-count{
  position:absolute;
  top:-13px;
  right:-8px;
  min-width:30px;
  height:30px;
  padding:0 8px;
  border-radius:999px;
  background:var(--coral);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:17px;
  font-weight:600;
  line-height:1;
  box-shadow:0 8px 18px rgba(239,90,87,.28);
}

.selection-trigger-count.is-empty{
  display:none;
}
.pairing-add{width:44px;height:44px;position:absolute;right:12px;bottom:12px}
.selection-trigger{position:fixed;right:max(calc((100vw - 410px) / 2 + 16px),16px);bottom:25px;z-index:95;width:62px;height:62px;background:#fff;box-shadow:0 16px 34px rgba(0,0,0,.16)}
.sheet{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(110%);width:min(92vw,380px);max-height:min(72vh,620px);z-index:90;transition:transform .26s ease;background:#fff;border-radius:18px;box-shadow:0 26px 60px rgba(0,0,0,.22);overflow:hidden}
.sheet.show{transform:translateX(-50%) translateY(0)}
.sheet-header{position:sticky;top:0;z-index:2;background:#fff;padding:20px 22px 16px;display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(0,0,0,.05)}
.sheet-title{font-size:16px;line-height:1;font-weight:600;letter-spacing:-.5px}
.sheet-scroll{max-height:calc(min(72vh,620px) - 80px);overflow:auto;padding:10px 14px 18px}
.sheet-list{display:grid;gap:10px}
.selection-item{display:grid;grid-template-columns:88px 1fr 42px;align-items:center;gap:14px;background:#fff;border-radius:16px;padding:0;transition:opacity .2s ease,transform .2s ease,max-height .22s ease,margin .22s ease,padding .22s ease;max-height:120px}
.selection-item:nth-child(odd){background:#f4f4f4}
.selection-item.is-removing{opacity:0;transform:translateY(-8px);max-height:0;margin:0;padding-top:0;padding-bottom:0;overflow:hidden}
.selection-thumb{width:88px;height:88px;border-radius:16px;overflow:hidden;border:0;padding:0;cursor:pointer;background:#ddd}
.selection-info{min-width:0}
.selection-name{font-size:15px;line-height:1.02;font-weight:600;letter-spacing: -.5px;}
.selection-code{margin-top:5px;font-size:12px;color:var(--muted);font-weight:500}
.delete-btn{width:42px;height:42px;background:transparent}
.sheet-footer{text-align:center;padding:16px 8px 6px}
.sheet-footer-title{color:var(--coral);font-size:18px;font-weight:600;letter-spacing: -1px;}
.sheet-footer-sub{font-size:15px;color:#111}
.empty-selection{padding:26px 12px;text-align:center;color:var(--muted)}
.lightbox{position:fixed;inset:0;z-index:180;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.show{display:flex}
.lightbox-close{position:absolute;top:18px;right:18px;width:46px;height:46px;  z-index: 9999; background:rgba(255,255,255,.52);color:#fff}
.lightbox-image{width:min(92vw,430px);max-height:86vh}
.lightbox-image img{max-height:86vh;border-radius:20px}
.toast{position:fixed;left:50%;bottom:92px;transform:translateX(-50%) translateY(10px);z-index:160;background:#111;color:#fff;border-radius:999px;padding:12px 16px;box-shadow:0 10px 30px rgba(0,0,0,.22);display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;opacity:0;visibility:hidden;transition:.18s ease;white-space:nowrap}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.kpi-grid{display:grid;gap:20px;grid-template-columns:repeat(2,minmax(0,1fr))}
.kpi-card,.report-card{background:#fff;border-radius:24px;box-shadow:0 10px 30px rgba(38,57,120,.08);padding:20px}
.kpi-value{font-size:42px;line-height:1;font-weight:300;letter-spacing:-.04em}
.report-layout{display:grid;gap:20px}
.report-table{width:100%;border-collapse:collapse}
.report-table th,.report-table td{padding:12px 8px;border-bottom:1px solid var(--line);text-align:left}
.report-table th{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}
.report-table td.num{text-align:right;font-variant-numeric:tabular-nums}
.report-list{display:grid;gap:14px}
.report-row{display:grid;grid-template-columns:56px 1fr auto;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.report-thumb{width:56px;height:56px;border-radius:14px;overflow:hidden;background:#edf1f7}.report-thumb img{width:100%;height:100%;object-fit:cover}
.report-badge{padding:8px 12px;border-radius:999px;background:#eaf1ff;color:#2f6fe4;font-weight:700;min-width:82px;text-align:center}
.range{display:flex;gap:8px;flex-wrap:wrap}.range a{background:#fff;border:1px solid var(--line);padding:10px 14px;border-radius:16px;font-weight:600}.range a.active{background:#2f6fe4;border-color:#2f6fe4;color:#fff}
@media (max-width:430px){
  .hero-media{height:520px;}
  .quick-link-image{width:98px;height:98px}
}

.badge-pill-soft{background:rgba(255,255,255,.82);color:#111}
.detail-badges{display:grid;gap:8px;justify-items:end}
.sheet-footer-button{display:block;width:100%;border:0;background:#fff7f6;cursor:pointer;border-radius:18px;padding:16px 10px 8px; margin-top: 10px;}
.sheet-footer-button:disabled{opacity:.45;cursor:not-allowed}
.confirm-modal{position:fixed;inset:0;z-index:170;display:none;align-items:center;justify-content:center;padding:22px}
.confirm-modal.show{display:flex}
.confirm-modal-card{position:relative;width:min(92vw,430px);background:#fff;border-radius:24px;box-shadow:0 30px 70px rgba(0,0,0,.24);padding:30px 20px 30px}
.confirm-modal-close{position:absolute;top:14px;right:14px;width:42px;height:42px;border:0;border-radius:999px;background:#f4f4f4;display:flex;align-items:center;justify-content:center;cursor:pointer;  z-index: 9999;   /* clave */}
.confirm-ticket{border:2px dashed rgba(17,17,17,.18);border-radius:0px;padding:18px 16px;background:linear-gradient(180deg,#fff 0%,#f8f8f8 100%)}
.confirm-ticket-kicker{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:#ef5a57;font-weight:700}
.confirm-ticket-restaurant{margin-top:8px;font-size:26px;line-height:.95;font-weight:700;letter-spacing:-.04em}
.confirm-ticket-divider{height:1px;background:repeating-linear-gradient(to right,rgba(0,0,0,.14),rgba(0,0,0,.14) 8px,transparent 8px,transparent 16px);margin:16px 0}
.confirm-ticket-title{font-size:16px;font-weight:600;margin-bottom:12px}
.confirm-ticket-list{display:grid;gap:10px}
.confirm-ticket-item{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:15px;border-bottom:1px solid rgba(0,0,0,.06);padding-bottom:8px}
.confirm-ticket-total{margin-top:16px;font-size:16px}
.confirm-ticket-note{margin-top:12px;font-size:14px;line-height:1.4;color:rgba(0,0,0,.68)}

.section-head{display:grid;gap:3px;margin-bottom:12px}
.section-subtitle{margin:0;color:var(--muted);font-size:14px;line-height:1.35}
.rail-card-price{margin-top:6px}
.category-item-accent{border-color:rgba(239,90,87,.16)}
.filter-pills{display:flex;gap:10px;overflow:auto;padding:0 0 6px;margin:0 0 18px;scrollbar-width:none}
.filter-pills::-webkit-scrollbar{display:none}
.filter-pill{display:inline-flex;align-items:center;justify-content:center;padding:11px 16px;border-radius:999px;background:#fff;border:1px solid rgba(17,17,17,.08);color:#111;font-size:14px;font-weight:600;white-space:nowrap;box-shadow:0 6px 16px rgba(0,0,0,.04)}
.filter-pill.is-active{background:#111;color:#fff;border-color:#111}
.filter-pill-all{background:#fff4f3;border-color:rgba(239,90,87,.14);color:var(--coral)}
.filter-pill-all.is-active{background:var(--coral);border-color:var(--coral);color:#fff}
.icon-btn .back-icon,.category-back .back-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:#111}
.icon-btn .back-icon svg,.category-back .back-icon svg{display:block}
.detail-card-top{display:flex;gap:16px;align-items:flex-start;justify-content:space-between}
.detail-copy{flex:1;min-width:0}
.detail-action{width:94px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:14px;padding-top:4px}
.detail-price{margin-top:0;text-align:center;font-size:21px;line-height:1;letter-spacing:-.04em;font-weight:700}
.detail-action .add-btn{margin:0}
.page-content .grid-list{padding-top:2px}

.section-subtitle{margin:0;color:var(--muted);font-size:14px;line-height:1.35}
.entry-screen{position:absolute;inset:0;z-index:120;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:28px;transition:opacity .38s ease,visibility .38s ease}
.entry-screen.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.entry-screen-copy{text-align:center;transform:translateY(-60px)}
.entry-screen-copy h1{margin:0;font-size:46px;line-height:.95;letter-spacing:-0.06em;color:var(--coral);font-weight:800}
.entry-screen-copy p{margin:12px 0 0;font-size:32px;line-height:1;color:#111;font-weight:800;letter-spacing:-0.05em}
.entry-screen-brand{position:absolute;left:0;right:0;bottom:34px;display:flex;justify-content:center}
.entry-screen-brand img{width:150px;height:auto}
.pairings-sub{margin:4px 0 12px;color:var(--muted);font-size:14px}
.guided-page{padding-bottom:120px}
.guided-context{margin:-2px 0 18px 54px;font-size:13px;color:var(--muted);display: none;}
.guided-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.guided-card{position:relative;border-radius:20px;overflow:hidden;background:#ddd;box-shadow:var(--shadow);min-height:220px;    height: 230px;}
.guided-card-featured{grid-column:1/-1;min-height:360px; height: 430px;}
.guided-card-link{display:block;position:relative;height:100%}
.guided-card-link img{width:100%;height:100%;object-fit:cover}
.guided-card-copy{position:absolute;left:18px;right:18px;bottom:18px;z-index:2;color:#fff}
.guided-card-name{font-size:22px;line-height:.95;font-weight:600;letter-spacing:-0.05em;text-shadow:0 2px 8px rgba(0,0,0,.24)}
.guided-card-price{margin-top:8px;font-size:17px;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.24)}
.guided-add-btn{position:absolute;right:16px;bottom:16px;width:58px;height:58px;border:0;border-radius:999px;background:#f45b5b;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 26px rgba(244,91,91,.28);z-index:3}
.guided-add-btn svg{stroke:#fff}
.guided-skip{display:block;margin:20px 0 0;text-align:center;padding:16px 20px;border-radius:999px;background:#f5f5f5;font-weight:700}
.selection-hints{display:grid;gap:12px;margin-top:8px;padding-bottom:8px}
.selection-hint-block{padding:16px;border-radius:18px;background:#fff3f2;border:1px solid rgba(239,90,87,.12)}
.selection-hint-title{font-size:15px;font-weight:600;line-height:1.2}
.selection-hint-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.selection-hint-btn{border:0;border-radius:999px;padding:11px 14px;background:#ef5a57;color:#fff;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.selection-hint-btn-soft{background:#fff;color:#111;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
@media (max-width:390px){.entry-screen-copy h1{font-size:40px}.entry-screen-copy p{font-size:28px}}

body.entry-lock{overflow:hidden}
.brand-select{display:inline-flex;align-items:center;max-width:220px}
.brand-select img{    width: 170px;
    height: auto;
    object-fit: contain;
}
.entry-screen{position:fixed;inset:0;z-index:240;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:28px;transition:opacity .38s ease,visibility .38s ease}
.entry-screen-copy{width:100%;max-width:360px;text-align:center;transform:translateY(-44px)}
.entry-screen-copy h1{margin:0;font-size:58px;line-height:.92;letter-spacing:-0.07em;color:var(--coral);font-weight:800}
.entry-screen-copy p{margin:14px 0 0;font-size:28px;line-height:1.02;color:#111;font-weight:700;letter-spacing:-0.05em}
.entry-screen-brand{position:absolute;left:0;right:0;bottom:30px;display:flex;justify-content:center;padding:0 24px}
.entry-brand-lockup{display:flex;align-items:flex-end;gap:10px;color:var(--coral)}
.entry-brand-word{font-size:48px;line-height:.85;font-weight:800;letter-spacing:-0.08em;color:var(--coral)}
.entry-brand-word span{display:inline-block;margin-left:2px}
.entry-brand-sub{font-size:17px;line-height:.95;font-weight:700;color:#111;transform:translateY(-3px)}
.pairing-card{position:relative;overflow:hidden;height: 160px;}
.pairing-card-link{display:block;color:inherit;text-decoration:none}
@media (max-width:390px){.entry-screen-copy h1{font-size:48px}.entry-screen-copy p{font-size:24px}.entry-brand-word{font-size:42px}.entry-brand-sub{font-size:15px}}

/* 2026-04 selection and popularity refinements */
.hero-media img,
.category-slide img,
.category-dish img,
.detail-image img,
.pairing-card img,
.selection-thumb img,
.lightbox-image img,
.dish-card img,
.guided-card-link img{object-fit:cover;object-position:center center; }

.pairing-card img{
  position:absolute;
  top:0;
  left:0;

  width:100%;
  height:100%;

  object-fit:cover;
  object-position:center 60%;
}

.sheet-footer-button{
  background:linear-gradient(90deg,#fff 0%,#fff7f6 58%,#fde9e8 100%);
  border:1px solid rgba(239,90,87,.08);
  padding:18px 10px 10px;
}

.selection-hints{display:grid;gap:14px;margin-top:8px;padding-bottom:8px}
.selection-hint-block{
  position:relative;
  min-height:100px;
  display:flex;
  align-items:center;
  overflow:hidden;
  border-radius:22px;
  border:2px dashed rgba(17,17,17,.26);
  background:#fff;
  padding:20px 112px 20px 24px;
}
.selection-hint-block.is-primary{min-height:100px;box-shadow:0 8px 22px rgba(0,0,0,.04)}
.selection-hint-copy{position:relative;z-index:2;max-width:60%}
.selection-hint-title{font-size:24px;line-height:.96;font-weight:600;letter-spacing:-0.6px}
.selection-hint-subtitle{margin-top:8px;font-size:13px;line-height:1.22;color:rgba(17,17,17,.8)}
.selection-hint-media{
  position:absolute;
  top:12px;
  bottom:12px;
  right:0;
  width:38%;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}
.selection-hint-media::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(270deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.58) 38%,#fff 88%);
  z-index:2;
}
.selection-hint-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
}
.selection-hint-plus{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  width:64px;
  height:64px;
  border:0;
  border-radius:999px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 26px rgba(0,0,0,.16);
  z-index:3;
}
.selection-hint-plus svg{stroke:#111;stroke-width:2.5}

.guided-page{
  min-height:calc(100dvh - 94px);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.guided-grid{gap:12px}
.guided-card{min-height:132px}
.guided-card-featured{min-height:176px}
.guided-card-copy{left:16px;right:16px;bottom:16px}
.guided-card-name{font-size:19px}
.guided-card-price{margin-top:6px;font-size:15px}
.guided-add-btn{
  width:54px;
  height:54px;
  right:12px;
  bottom:12px;
  background:#fff;
  color:#111;
  box-shadow:0 12px 28px rgba(0,0,0,.16);
}
.guided-add-btn svg{stroke:#111}
.guided-skip{margin:16px 0 0}

.confirm-modal{
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(1px);
  -webkit-backdrop-filter:blur(1px);
}
body.confirm-open .overlay{background:rgba(0,0,0,.72)}

@media (max-width:390px){
  .selection-hint-block{padding:18px 96px 18px 18px;min-height:118px}
  .selection-hint-block.is-primary{min-height:105px}
  .selection-hint-title{font-size:18px}
  .selection-hint-subtitle{font-size:14px}
  .selection-hint-plus{width:58px;height:58px;right:10px}
}


/* 2026-04-01 follow-up fixes */
.pairings-grid{grid-auto-rows:176px}
.pairing-card{height:176px}
.pairing-card img,.guided-card-link img,.selection-hint-media img{object-position:center center !important}

.selection-hint-block{
  min-height:100px;
  padding:18px 100px 18px 20px;
}
.selection-hint-block.is-primary{min-height:100px}
.selection-hint-copy{
  z-index:4;
  max-width:calc(100% - 92px);
}
.selection-hint-title{
  position:relative;
  z-index:4;
  font-size:18px;
  line-height:.98;
}
.selection-hint-subtitle{
  position:relative;
  z-index:4;
  margin-top:6px;
  font-size:14px;
}
.selection-hint-media{
  top:0px;
  bottom:0px;
  width:45%;
  z-index:1;
}
.selection-hint-media::before{
  background:linear-gradient(270deg,rgba(255,255,255,.09) 0%,rgba(255,255,255,.5) 35%,#fff 95%);
}
.selection-hint-plus{
  right:12px;
  width:52px;
  height:52px;
  z-index:5;
}
.selection-hint-plus svg{width:22px;height:22px}

.guided-grid{grid-template-columns:1fr 1fr;gap:10px}
.guided-card{min-height:118px;border-radius:20px}
.guided-card-featured{min-height:164px}
.guided-card-link{min-height:100%;display:block}
.guided-card-link::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.36),rgba(0,0,0,0) 58%);pointer-events:none}
.guided-card-copy{z-index:2}
.guided-card-name{font-size:17px;max-width:68%}
.guided-card-price{font-size:14px}
.guided-add-btn{
  width:48px;
  height:48px;
  right:10px;
  bottom:10px;
  background:#fff;
  color:#111;
  box-shadow:0 10px 24px rgba(0,0,0,.14);
}
.guided-add-btn .plus-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px}
.guided-add-btn svg{width:22px;height:22px;stroke:#111;stroke-width:2.4}

@media (max-width:390px){
  .pairings-grid{grid-auto-rows:164px}
  .pairing-card{height:164px}
  .selection-hint-block{padding:16px 90px 16px 16px;min-height:112px}
  .selection-hint-block.is-primary{min-height:118px}
  .selection-hint-title{font-size:19px}
  .selection-hint-plus{width:48px;height:48px;right:10px}
  .guided-card{min-height:110px}
  .guided-card-featured{min-height:154px}
  .guided-card-name{font-size:16px}
  .guided-add-btn{width:44px;height:44px}
}

/* report dashboard refresh */
.report-body{background:#f3f4fa;color:#1f2847}
.report-shell{max-width:1440px;margin:0 auto;padding:42px 28px 56px}
.report-page{display:grid;gap:24px}
.report-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}
.report-brand-lockup{display:flex;gap:18px;align-items:flex-start;min-width:0}.report-brand-lockup img{width:240px;max-width:40vw;height:auto}.report-brand-lockup h1{margin:0;font-size:26px;line-height:1.05;letter-spacing:-.04em}.report-brand-lockup p{margin:8px 0 0;color:#667089;max-width:620px}
.report-actions{display:grid;gap:12px;justify-items:end}.report-back-link{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border:1px solid var(--line);border-radius:16px;background:#fff;font-weight:700}
.report-range{justify-content:flex-end}
.report-metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}
.report-metric-card,.report-panel{background:#fff;border-radius:28px;box-shadow:0 12px 34px rgba(38,57,120,.08);padding:26px}
.report-metric-label{font-size:15px;font-weight:700;color:#3f4864}
.report-metric-value{margin-top:12px;font-size:56px;line-height:.95;font-weight:300;letter-spacing:-.06em;color:#1f2847}
.report-metric-sub{margin-top:10px;color:#7a839b;font-size:14px}
.report-grid{display:grid;gap:24px}.report-grid-main{grid-template-columns:minmax(0,1.45fr) minmax(320px,.95fr)}.report-grid-rankings{grid-template-columns:repeat(3,minmax(0,1fr))}.report-grid-dual{grid-template-columns:repeat(2,minmax(0,1fr))}
.report-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.report-panel-head h2{margin:0;font-size:18px;line-height:1.1;letter-spacing:-.03em}.report-panel-head p{margin:6px 0 0;color:#778099;font-size:14px;max-width:620px}
.report-chart-wrap canvas{
  display:block;
  width:100% !important;
  height:100% !important;
  max-width:100%;
}
.report-chart-wrap{position:relative;height:300px;background:linear-gradient(180deg,rgba(47,111,228,.04),rgba(47,111,228,0));border:1px solid #edf0f7;border-radius:22px;padding:14px}
.report-chart-legend{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:14px;color:#667089;font-size:14px}.report-chart-legend span{display:inline-flex;align-items:center;gap:8px}.report-chart-legend i{width:12px;height:12px;border-radius:999px;display:inline-block}.report-chart-legend i.is-views{background:#2f6fe4}.report-chart-legend i.is-adds{background:#3dbb97}.report-chart-legend i.is-conversion{background:#f59c46}
.report-category-list,.report-combo-list,.report-insights-list,.report-rank-list{display:grid;gap:14px}.report-category-row,.report-combo-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(140px,1fr) auto;gap:14px;align-items:center}.report-category-copy,.report-combo-copy{min-width:0}.report-category-copy strong,.report-combo-copy strong{display:block;font-size:15px}.report-category-copy span,.report-combo-copy span{display:block;margin-top:4px;color:#7a839b;font-size:13px}
.report-inline-bar{height:14px;background:#eef1f7;border-radius:999px;overflow:hidden}.report-inline-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2f6fe4,#7fb3ff)}.report-category-ratio{font-weight:700;color:#1f2847;font-variant-numeric:tabular-nums}
.report-rank-item{display:grid;grid-template-columns:30px 58px minmax(0,1fr) auto;gap:14px;align-items:center;padding:10px 0;border-bottom:1px solid #edf0f7}.report-rank-item:last-child{border-bottom:0;padding-bottom:0}.report-rank-pos{font-weight:800;color:#8b93aa}.report-rank-thumb,.report-table-thumb{width:58px;height:58px;border-radius:16px;overflow:hidden;background:#edf1f7}.report-rank-thumb img,.report-table-thumb img{width:100%;height:100%;object-fit:cover;object-position:center}.report-rank-copy strong{display:block;font-size:16px}.report-rank-copy span{display:block;margin-top:4px;color:#778099;font-size:13px}.report-rank-metric{padding:10px 14px;border-radius:999px;background:#eef4ff;color:#2f6fe4;font-weight:800;white-space:nowrap}
.report-insight{padding:18px;border-radius:22px;border:1px solid #edf0f7;background:#fafbfe}.report-insight strong{display:block;font-size:15px}.report-insight p{margin:8px 0 0;color:#67718a;line-height:1.45}.report-insight.is-warning{background:#fff8f4;border-color:#ffe2ce}.report-insight.is-success{background:#f3fcf7;border-color:#d7f0e1}.report-insight.is-neutral{background:#f7f9fe;border-color:#e4ebfb}
.report-cross-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:16px}.report-cross-kpi{padding:18px;border-radius:20px;background:#f6f8fd;border:1px solid #edf0f7}.report-cross-kpi span{display:block;color:#6f7892;font-size:14px}.report-cross-kpi strong{display:block;margin-top:8px;font-size:30px;letter-spacing:-.04em}
.report-table-wrap{overflow:auto}.report-table{width:100%;border-collapse:collapse}.report-table th,.report-table td{padding:14px 12px;border-bottom:1px solid #edf0f7;text-align:left;vertical-align:middle}.report-table th{font-size:12px;text-transform:uppercase;color:#7d869e;letter-spacing:.06em}.report-table td.num{text-align:right;font-variant-numeric:tabular-nums}.report-table-full tbody tr:hover{background:#fafbfe}.report-table-dish{display:flex;align-items:center;gap:12px;min-width:220px}.report-table-dish strong{font-size:15px}
.report-empty{padding:22px;border-radius:18px;background:#f7f9fd;color:#69738c}
@media (max-width:1180px){.report-metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.report-grid-rankings,.report-grid-dual,.report-grid-main{grid-template-columns:1fr}}
@media (max-width:780px){.report-shell{padding:20px 14px 36px}.report-brand-lockup{display:grid}.report-brand-lockup img{width:190px;max-width:58vw}.report-actions{width:100%;justify-items:start}.report-range{justify-content:flex-start}.report-metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.report-metric-card,.report-panel{padding:20px;border-radius:24px}.report-metric-value{font-size:42px}.report-category-row,.report-combo-row{grid-template-columns:1fr}.report-rank-item{grid-template-columns:26px 50px 1fr}.report-rank-metric{grid-column:2 / -1;justify-self:start}.report-cross-summary{grid-template-columns:1fr}}

.report-chart-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px;color:#6f7892;font-size:13px}
.report-chart-legend span{display:inline-flex;align-items:center;gap:8px}
.report-chart-legend i{display:inline-block;width:10px;height:10px;border-radius:999px;background:#2f6fe4}
.report-chart-legend .is-adds{background:#3dbb97}
.report-table-dish{display:flex;align-items:center;gap:10px;min-width:0}
.report-table-dish strong{display:block;min-width:0}

/* === Select report redesign === */
.report-body-redesign{background:linear-gradient(180deg,#fbfbfd 0%,#f3f5fb 100%)}
.report-page-redesign{max-width:1280px;margin:0 auto;padding:22px 14px 72px}
.report-topbar-redesign{margin-bottom:18px}
.report-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#16181f 0%,#222734 55%,#ef5a57 180%);color:#fff;border-radius:30px;padding:22px;display:grid;gap:18px;box-shadow:0 20px 60px rgba(18,25,38,.16);margin-bottom:18px}
.report-hero.is-good{background:linear-gradient(135deg,#111827 0%,#1f3f37 45%,#29a17c 150%)}
.report-hero.is-down{background:linear-gradient(135deg,#171923 0%,#4b2d2d 50%,#d97745 150%)}
.report-hero.is-soft{background:linear-gradient(135deg,#171923 0%,#4a3a4f 50%,#8d5cf6 150%)}
.report-hero-kicker{font-size:12px;text-transform:uppercase;letter-spacing:.14em;opacity:.72}.report-hero-score-row{display:grid;grid-template-columns:112px 1fr;gap:16px;align-items:center}.report-hero-score{font-size:64px;line-height:.88;font-weight:800;letter-spacing:-.05em}.report-hero-score-label{font-size:13px;opacity:.78;text-transform:uppercase;letter-spacing:.08em}.report-hero-copy h2{margin:0;font-size:28px;line-height:.98;letter-spacing:-.04em}.report-hero-copy p{margin:8px 0 0;font-size:15px;line-height:1.35;max-width:54ch;color:rgba(255,255,255,.84)}.report-hero-state{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);font-size:13px;font-weight:700;margin-bottom:10px}.report-hero-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.report-hero-metric{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:14px 16px}.report-hero-metric span{display:block;font-size:13px;opacity:.74;margin-bottom:6px}.report-hero-metric strong{font-size:24px;line-height:1}
.report-section-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin:22px 0 14px}.report-section-kicker{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:#ef5a57;font-weight:800;margin-bottom:8px}.report-section-head h2,.report-focus-head h2,.report-action-card h2{margin:0;font-size:24px;line-height:1;letter-spacing:-.04em;color:#111827}.report-section-side{font-size:13px;color:#6b7280}
.report-now-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.report-now-card{overflow:hidden;border-radius:24px;background:#fff;border:1px solid rgba(17,24,39,.06);box-shadow:0 12px 36px rgba(15,23,42,.06);min-height:220px;display:flex;flex-direction:column}.report-now-card-media{height:108px;background:#edf1f7;overflow:hidden}.report-now-card-media img{width:100%;height:100%;object-fit:cover}.report-now-card-copy{padding:14px 16px 16px;display:grid;gap:6px}.report-now-card-copy span{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#ef5a57;font-weight:800}.report-now-card-copy strong{font-size:20px;line-height:1;color:#111827}.report-now-card-value{font-size:32px;line-height:.95;font-weight:800;color:#111827;margin-top:4px}.report-now-card-copy small{font-size:13px;color:#6b7280}
.report-mobile-stack{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;margin-bottom:14px}.report-focus-card,.report-action-card{background:#fff;border-radius:24px;border:1px solid rgba(17,24,39,.06);box-shadow:0 12px 36px rgba(15,23,42,.06);padding:20px}.report-alert-list{display:grid;gap:12px;margin-top:14px}.report-alert-item{display:grid;grid-template-columns:30px 1fr;gap:12px;padding:12px 0;border-bottom:1px solid rgba(17,24,39,.06)}.report-alert-item:last-child{border-bottom:0;padding-bottom:0}.report-alert-item strong{display:block;font-size:16px;color:#111827}.report-alert-item p{margin:5px 0 0;font-size:14px;line-height:1.4;color:#4b5563}.report-action-card p{margin:10px 0 0;font-size:15px;line-height:1.45;color:#4b5563}.report-action-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.report-action-meta span{display:inline-flex;padding:9px 12px;border-radius:999px;background:#f5f7fb;color:#374151;font-size:13px;font-weight:600}
.report-mobile-toggle-wrap{display:none;margin:0 0 12px}.report-mobile-toggle{width:100%;height:56px;border-radius:18px;border:0;background:#111827;color:#fff;font-weight:700;font-size:15px;box-shadow:0 12px 28px rgba(17,24,39,.16)}.report-desktop-sections{display:grid;gap:20px}.report-panel,.report-metric-card{border-radius:24px;border:1px solid rgba(17,24,39,.06);box-shadow:0 12px 36px rgba(15,23,42,.06)}.report-metric-card{padding:18px;background:#fff}.report-metric-label{font-size:13px;color:#6b7280;margin-bottom:8px}.report-metric-value{font-size:34px;line-height:1;font-weight:800;color:#111827}.report-metric-sub{font-size:13px;color:#6b7280;margin-top:8px;line-height:1.35}.report-panel-head h2{margin:0;font-size:22px;line-height:1;color:#111827}.report-panel-head p{margin:7px 0 0;color:#6b7280;font-size:14px;line-height:1.4}
.report-chart-wrap,.report-table-wrap,.report-cross-summary{transition:opacity .28s ease,transform .28s ease;opacity:0;transform:translateY(8px)}.report-chart-wrap.is-ready,.report-table-wrap.is-ready,.report-cross-summary.is-ready{opacity:1;transform:none}.report-chart-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;font-size:13px;color:#6b7280}.report-chart-legend i{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:6px}.report-chart-legend .is-views{background:#2f6fe4}.report-chart-legend .is-adds{background:#3dbb97}
.report-rank-list,.report-category-list,.report-combo-list,.report-insights-list{display:grid;gap:10px}.report-rank-item,.report-category-row,.report-combo-row{background:#fff;border-radius:18px;border:1px solid rgba(17,24,39,.05)}.report-rank-item{display:grid;grid-template-columns:40px 64px 1fr auto;gap:12px;align-items:center;padding:12px}.report-rank-pos{width:40px;height:40px;border-radius:999px;background:#f5f7fb;display:flex;align-items:center;justify-content:center;font-weight:800;color:#111827}.report-rank-thumb{width:64px;height:64px;border-radius:16px;overflow:hidden;background:#edf1f7}.report-rank-thumb img{width:100%;height:100%;object-fit:cover}.report-rank-copy strong{display:block;font-size:16px;line-height:1.1;color:#111827}.report-rank-copy span{display:block;margin-top:4px;font-size:13px;color:#6b7280}.report-rank-metric{font-size:15px;font-weight:800;color:#111827;background:#f5f7fb;padding:10px 12px;border-radius:14px}.report-category-row,.report-combo-row{display:grid;grid-template-columns:minmax(0,1fr) 160px auto;gap:12px;align-items:center;padding:14px}.report-category-copy strong,.report-combo-copy strong{display:block;font-size:15px;color:#111827}.report-category-copy span,.report-combo-copy span{display:block;margin-top:4px;font-size:13px;color:#6b7280;line-height:1.35}.report-inline-bar{height:10px;border-radius:999px;background:#eef2f7;overflow:hidden}.report-inline-bar span{display:block;height:100%;background:linear-gradient(90deg,#ef5a57,#ff9866);border-radius:999px}.report-category-ratio{font-size:14px;font-weight:800;color:#111827}
.report-insight{padding:16px 18px;border-radius:18px;background:#f8fafc;border:1px solid rgba(17,24,39,.06)}.report-insight strong{display:block;font-size:16px;color:#111827}.report-insight p{margin:6px 0 0;font-size:14px;line-height:1.45;color:#4b5563}.report-insight.is-warning{background:#fff8f2}.report-insight.is-success{background:#f2fbf7}.report-insight.is-neutral{background:#f4f7ff}.report-cross-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:14px 0 12px}.report-cross-kpi{padding:16px;border-radius:18px;background:#f8fafc;border:1px solid rgba(17,24,39,.06)}.report-cross-kpi span{display:block;font-size:13px;color:#6b7280;margin-bottom:6px}.report-cross-kpi strong{font-size:28px;line-height:1;color:#111827}
.report-table-wrap{overflow:auto}.report-table{width:100%;border-collapse:collapse}.report-table th,.report-table td{padding:14px 10px;border-bottom:1px solid #edf1f7;text-align:left;white-space:nowrap}.report-table th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#6b7280}.report-table td{font-size:14px;color:#111827}.report-table td.num{text-align:right}.report-table-dish{display:flex;align-items:center;gap:12px}.report-table-thumb{display:inline-flex;width:42px;height:42px;border-radius:12px;overflow:hidden;background:#edf1f7}.report-table-thumb img{width:100%;height:100%;object-fit:cover}.report-empty{padding:18px;border-radius:18px;background:#f8fafc;color:#6b7280;font-size:14px}
.reveal-on-scroll{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease;transition-delay:var(--reveal-delay,0ms)}.reveal-on-scroll.is-visible{opacity:1;transform:none}
@media (max-width:1024px){.report-now-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-mobile-stack{grid-template-columns:1fr}.report-grid-main,.report-grid-rankings,.report-grid-dual{grid-template-columns:1fr!important}}
@media (max-width:767px){.report-page-redesign{padding:14px 12px 56px}.report-hero{padding:18px;border-radius:26px}.report-hero-score-row{grid-template-columns:1fr;gap:10px}.report-hero-score{font-size:56px}.report-hero-copy h2{font-size:24px}.report-hero-metrics{grid-template-columns:1fr}.report-section-head{margin:18px 0 12px}.report-section-side{display:none}.report-now-grid{grid-template-columns:1fr 1fr;gap:12px}.report-mobile-toggle-wrap{display:block}.report-desktop-sections{display:none}body.report-mobile-expanded .report-desktop-sections{display:grid;margin-top:12px}}
@media (max-width:560px){.report-brand-lockup{align-items:flex-start}.report-brand-lockup h1{font-size:24px}.report-brand-lockup p{font-size:13px;line-height:1.35}.report-actions{width:100%}.report-range{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));width:100%}.report-range a{padding:10px 6px;text-align:center;font-size:12px}.report-back-link{display:none}.report-now-grid{grid-template-columns:1fr}.report-category-row,.report-combo-row{grid-template-columns:1fr;gap:10px}.report-rank-item{grid-template-columns:34px 56px 1fr;grid-template-areas:"pos thumb metric" "pos copy copy";align-items:center}.report-rank-pos{grid-area:pos;width:34px;height:34px;font-size:13px}.report-rank-thumb{grid-area:thumb;width:56px;height:56px}.report-rank-copy{grid-area:copy}.report-rank-metric{grid-area:metric;justify-self:end;font-size:13px;padding:8px 10px}}


.detail-info-btn {
  margin-top: 10px;
  display: inline-block;
  background: #ef5a57;
  color: #fff;
  font-size: 14px;
  padding: 8px 14px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  line-height: 1;
}

.detail-info-btn:active {
  transform: scale(0.97);
}

/* Modal */

.dish-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999;
}

.dish-modal.active {
  display: block;
}

.dish-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
}

.dish-modal-card {
  position: relative;
  background: #fff;
  border-radius: 20px;
  padding: 20px;
  margin: auto;
  width: 90%;
  max-width: 400px;
  top: 50%;
  transform: translateY(-50%);
}

.dish-modal-close {
  position: absolute;
  right: 15px;
  top: 15px;
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
}

.dish-modal-description {
  margin-top: 10px;
  font-size: 15px;
  line-height: 1.4;
}

/* Allergens */

.dish-allergens {
  display: flex;
  gap: 12px;
  margin-top: 15px;
}

.allergen-item {
  width: 32px;
  height: 32px;
  cursor: pointer;
  opacity: 0.6;
}

.allergen-item.active {
  opacity: 1;
}

.allergen-item img {
  width: 100%;
  height: 100%;
}

.allergen-tooltip {
  margin-top: 12px;
  font-size: 13px;
  color: #fff;
  background: #ff4d4d;
  padding: 6px 10px;
  border-radius: 8px;
  display: none;
  width: fit-content;
}

.dish-allergens-wrap {
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.dish-allergens {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.allergen-item {
  appearance: none;
  -webkit-appearance: none;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 1;
  box-shadow: none;
  outline: none;
}

.allergen-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.allergen-item.active {
  transform: scale(1.04);
}

.allergen-tooltip-wrap {
  margin-top: 8px;
  min-height: 52px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.allergen-tooltip {
  position: relative;
  display: none;
  background: #ef5a57;
  color: #fff;
  font-size: 16px;
  line-height: 1;
  padding: 12px 22px;
  border-radius: 18px;
  font-weight: 600;
  white-space: nowrap;
}

.allergen-tooltip.visible {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.allergen-tooltip.visible::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 12px solid #ef5a57;
}


body.modal-open,
body.is-page-loading{
  overflow:hidden;
}

.detail-copy{
  position:relative;
  z-index:6;
  flex:1 1 auto;
  min-width:0;
}

.detail-card,
.pairings,
.pairing-card,
.detail-image,
.detail-card-top,
.detail-action,
.pairing-card-link,
.category-dish,
.dish-card,
.category-slide,
.rail-card,
.section-block,
.hero-card{
  transition:opacity .28s ease, transform .28s ease, box-shadow .28s ease;
}

.detail-info-btn {
  margin-top: 10px;
  display: inline-flex;
  align-items:center;
  justify-content:center;
  min-height: 30px;
  min-width: 105px;
  background: #ef5a57;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  padding: 2px 0px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  line-height: 1;
  position: relative;
  z-index: 12;
  pointer-events: auto;
  transition: transform .22s ease, opacity .22s ease, box-shadow .22s ease, background .22s ease;
}

.detail-info-btn:hover,
.detail-info-btn:focus-visible {
  box-shadow: 0 14px 30px rgba(239,90,87,.28);
  transform: translateY(-1px);
}

.detail-info-btn:active {
  transform: scale(0.97);
}

.dish-modal {
  position: fixed;
  inset: 0;
  z-index: 230;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .28s ease, visibility .28s ease;
}

.dish-modal.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.dish-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.62);
  opacity: 0;
  transition: opacity .28s ease;
}

.dish-modal.active .dish-modal-overlay {
  opacity: 1;
}

.dish-modal-card {
  position: relative;
  z-index: 2;
  background: #fff;
  border-radius: 22px;
  padding: 22px 20px 20px;
  width: min(92vw, 420px);
  max-width: 420px;
  max-height: min(82vh, 680px);
  overflow: auto;
  box-shadow: 0 32px 70px rgba(0,0,0,.24);
  transform: translateY(18px) scale(.98);
  opacity: 0;
  transition: transform .3s ease, opacity .3s ease;
}

.dish-modal.active .dish-modal-card {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.dish-modal-close {
  position: absolute;
  right: 14px;
  top: 14px;
  z-index: 9999;   /* clave */
  background: transparent;
  border: none;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: #111;
  width: 40px;
  height: 40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  transition: background .22s ease, transform .22s ease;
}

.dish-modal-close:hover,
.dish-modal-close:focus-visible {
  background: rgba(0,0,0,.05);
}

.dish-modal-close:active {
  transform: scale(.96);
}

.dish-modal-description {
  margin-top: 10px;
  font-size: 15px;
  line-height: 1.45;
  color: rgba(16,16,16,.88);
}

.dish-allergens {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 18px;
}

.allergen-item {
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  overflow: visible;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  width: 35px;
  height: 35px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 1;
  box-shadow: none;
  outline: none;
  transition: transform .22s ease, opacity .22s ease, filter .22s ease;
}

.allergen-item:hover,
.allergen-item:focus-visible {
  transform: translateY(-1px) scale(1.03);
}

.allergen-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.allergen-item.active {
  transform: translateY(-1px) scale(1.06);
}

.allergen-tooltip-wrap {
  display:none;
}

.allergen-tooltip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  transform: translate(-50%, 6px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ef5a57;
  color: #fff;
  font-size: 13px;
  line-height: 1;
  padding: 9px 12px;
  border-radius: 999px;
  font-weight: 600;
  white-space: nowrap;
  box-shadow: 0 14px 28px rgba(239,90,87,.24);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
}

.allergen-tooltip.visible {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}

.allergen-tooltip::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 85%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 8px solid #ef5a57;
}

.confirm-modal{
  opacity:0;
  visibility:hidden;
  display:flex;
  pointer-events:none;
  transition:opacity .28s ease, visibility .28s ease;
}

.confirm-modal.show{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.confirm-modal-card{
  transform:translateY(18px) scale(.98);
  opacity:0;
  transition:transform .3s ease, opacity .3s ease;
}

.confirm-modal.show .confirm-modal-card{
  transform:translateY(0) scale(1);
  opacity:1;
}

.lightbox{
  opacity:0;
  visibility:hidden;
  display:flex;
  pointer-events:none;
  transition:opacity .28s ease, visibility .28s ease;
}

.lightbox.show{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.lightbox-image{
  transform:translateY(16px) scale(.985);
  opacity:0;
  transition:transform .3s ease, opacity .3s ease;
}

.lightbox.show .lightbox-image{
  transform:translateY(0) scale(1);
  opacity:1;
}

.page-loader {
  position: fixed;
  inset: 0;
  z-index: 260;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.98);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, visibility .2s ease;
}

.page-loader.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.page-loader-inner {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
}

.page-loader img {
  width: 56px;
  height: 56px;
  object-fit: contain;
  animation: selectLoaderSpin 1s linear infinite;
}

.page-loader span {
  font-size: 14px;
  font-weight: 600;
  color: #ef5a57;
}

body.is-page-loading .app-shell {
  opacity: 0;
  transition: opacity .16s ease;
}

@keyframes selectLoaderSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@media (max-width: 767px) {
  .detail-card,
  .pairings,
  .footer,
  .page-content,
  .content,
  .grid-list,
  .category-list,
  .section-block,
  .quick-links,
  .dish-rail,
  .category-slider {
    animation: selectFadeUp .32s ease both;
  }

  .detail-card-top {
    gap: 12px;
  }

  .detail-info-btn {
    min-width: 124px;
    min-height: 42px;
  }

  .dish-modal {
    padding: 14px;
  }

  .dish-modal-card {
    width: min(100%, 420px);
    max-height: min(84vh, 680px);
    border-radius: 20px;
  }
}

@keyframes selectFadeUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

img[src*="milk.svg"] {
  width: 42px !important;
  height: 35px !important;
  object-fit: contain;
  display: block;
  flex: 0 0 42px;
}

.page-loader-logo {
  position: relative;
  width: 50px;
  height: 50px;
  background: rgba(239, 90, 87, 0.5);
  -webkit-mask: url("https://select.c-gui.de/assets/icons/select.svg") no-repeat center / contain;
  mask: url("https://select.c-gui.de/assets/icons/select.svg") no-repeat center / contain;
  overflow: hidden;
}

.page-loader-logo::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 0%;
  background: #ef5a57;
  animation: loaderFill 1.2s ease-in-out infinite;
}

@keyframes loaderFill {
  0% { height: 0%; }
  50% { height: 100%; }
  100% { height: 0%; }
}
.locale-switcher {
    position: fixed;
    top: 10px;
    right: 10px;
    z-index: 1200;
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(18,28,45,.08);
    border-radius: 14px;
    box-shadow: 0 8px 24px rgba(18,28,45,.08);
    backdrop-filter: blur(10px);
}

.locale-switcher form {
    display: flex;
    gap: 8px;
    align-items: end;
    padding: 8px 10px;
}

.locale-switcher label {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.locale-switcher span {
    font-size: 10px;
    line-height: 1;
    color: #6f7a90;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.locale-switcher select {
    border: 1px solid rgba(18,28,45,.1);
    background: #fff;
    border-radius: 10px;
    padding: 6px 26px 6px 8px;
    font-size: 12px;
    font-weight: 600;
    color: #121c2d;
}

.report-body .locale-switcher {
    top: 14px;
    right: 14px;
}

@media (max-width: 640px) {
    .locale-switcher form {
        gap: 6px;
        padding: 7px 8px;
    }

    .locale-switcher select {
        min-width: 70px;
        font-size: 11px;
        padding-right: 18px;
    }
}

/* ===== Admin dashboard simplified ===== */
.report-body-simple{
  background:#f4f5fb;
}
.report-shell-simple{
  padding:24px;
}
.report-page-simple{
  max-width:1480px;
  margin:0 auto;
  display:grid;
  gap:22px;
}
.report-topbar-simple{
  align-items:flex-start;
  gap:18px;
}
.report-actions-simple{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
}
.report-simple-hero,
.report-simple-panel{
  background:#fff;
  border:1px solid rgba(17,24,39,.06);
  border-radius:32px;
  box-shadow:0 8px 30px rgba(28,35,90,.05);
}
.report-simple-hero{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(260px,.8fr);
  gap:18px;
  padding:28px;
}
.report-simple-kicker{
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#7a839b;
  margin-bottom:8px;
}
.report-simple-hero h2{
  margin:0;
  font-size:clamp(32px,4vw,56px);
  line-height:.95;
  letter-spacing:-.04em;
  color:#1f274a;
}
.report-simple-hero h2 span{color:#7a839b}
.report-simple-hero p{
  margin:14px 0 0;
  color:#7a839b;
  font-size:18px;
}
.report-hero-delta.is-up{color:#1e9d63}
.report-hero-delta.is-down{color:#cf4c4c}
.report-hero-delta.is-flat{color:#7a839b}
.report-simple-hero-side{
  display:grid;
  gap:14px;
}
.report-simple-hero-mini{
  background:#f6f7fc;
  border-radius:24px;
  padding:18px 20px;
  display:grid;
  gap:8px;
}
.report-simple-hero-mini span{
  color:#7a839b;
  font-size:14px;
}
.report-simple-hero-mini strong{
  color:#1f274a;
  font-size:20px;
  line-height:1.1;
}
.report-simple-grid-main{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px;
}
.report-simple-panel{
  padding:28px;
}
.report-simple-panel-wide{
  padding:28px;
}
.report-simple-panel-head{
  margin-bottom:18px;
}
.report-simple-panel-head h3{
  margin:0;
  font-size:22px;
  line-height:1.05;
  color:#1f274a;
}
.report-simple-panel-head p{
  margin:8px 0 0;
  font-size:16px;
  color:#7a839b;
}
.report-simple-card-grid{
  display:grid;
  gap:16px;
}
.report-simple-card-grid.cols-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.report-simple-card{
  min-width:0;
  background:#f6f7fc;
  border:1px solid rgba(17,24,39,.04);
  border-radius:24px;
  padding:20px;
}
.report-simple-card-label{
  color:#7a839b;
  font-size:15px;
  line-height:1.3;
}
.report-simple-card-value{
  margin-top:10px;
  font-size:clamp(28px,3vw,46px);
  line-height:.95;
  letter-spacing:-.04em;
  color:#1f274a;
  font-weight:700;
}
.report-simple-card-sub{
  margin-top:12px;
  color:#7a839b;
  font-size:15px;
  line-height:1.35;
}
.report-simple-card.is-money .report-simple-card-value{color:#2f6fe4}
.report-simple-card.is-accent .report-simple-card-value{color:#1f274a}
.report-trend-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.report-trend-badge{
  flex:0 0 auto;
  padding:8px 10px;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
  line-height:1;
}
.report-trend-badge.is-up{
  background:rgba(30,157,99,.12);
  color:#1e9d63;
}
.report-trend-badge.is-down{
  background:rgba(207,76,76,.12);
  color:#cf4c4c;
}
.report-trend-badge.is-flat{
  background:rgba(122,131,155,.12);
  color:#6d7590;
}
.report-simple-list{
  display:grid;
  gap:14px;
}
.report-simple-list-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  background:#f6f7fc;
  border-radius:24px;
  padding:16px 18px;
}
.report-simple-list-left{
  min-width:0;
  display:flex;
  align-items:center;
  gap:14px;
}
.report-simple-list-rank{
  width:40px;
  text-align:center;
  font-size:28px;
  font-weight:700;
  color:#8b93ab;
}
.report-simple-list-thumb{
  width:64px;
  height:64px;
  border-radius:20px;
  overflow:hidden;
  background:#eceff7;
  flex:0 0 64px;
}
.report-simple-list-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.report-simple-list-copy{
  min-width:0;
  display:grid;
  gap:4px;
}
.report-simple-list-copy strong{
  color:#1f274a;
  font-size:18px;
  line-height:1.15;
}
.report-simple-list-copy span{
  color:#7a839b;
  font-size:14px;
}
.report-simple-list-value{
  flex:0 0 auto;
  min-width:52px;
  text-align:right;
  font-size:30px;
  font-weight:700;
  color:#2f6fe4;
}

/* ===== Login ===== */
.admin-login-body{
  min-height:100vh;
  background:#efeee9;
}
.admin-login-shell{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.admin-login-card{
  width:min(100%,840px);
  background:#fff;
  border:1px solid rgba(17,24,39,.08);
  border-radius:32px;
  padding:40px;
  box-shadow:0 10px 30px rgba(17,24,39,.06);
}
.admin-login-logo img{
  width:56px;
  height:56px;
  object-fit:contain;
  display:block;
  margin-bottom:20px;
}
.admin-login-head h1{
  margin:0;
  font-size:64px;
  line-height:.95;
  letter-spacing:-.04em;
  color:#111;
}
.admin-login-head p{
  margin:10px 0 0;
  font-size:20px;
  color:#666;
}
.admin-login-form{
  margin-top:34px;
  display:grid;
  gap:22px;
}
.admin-login-field{
  display:grid;
  gap:10px;
}
.admin-login-field span{
  font-size:18px;
  font-weight:700;
  color:#111;
}
.admin-login-field input{
  width:100%;
  height:94px;
  border-radius:24px;
  border:2px solid #d9d5ca;
  background:#fff;
  padding:0 24px;
  font-size:22px;
  color:#111;
  outline:none;
}
.admin-login-field input:focus{
  border-color:#111;
}
.admin-login-button{
  width:100%;
  height:96px;
  border:0;
  border-radius:28px;
  background:#161616;
  color:#fff;
  font-size:28px;
  font-weight:700;
  cursor:pointer;
}
.admin-login-error{
  margin-top:20px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(207,76,76,.1);
  color:#b23333;
  font-size:15px;
}

@media (max-width: 1080px){
  .report-simple-grid-main,
  .report-simple-card-grid.cols-2{
    grid-template-columns:1fr;
  }
  .report-simple-hero{
    grid-template-columns:1fr;
  }
}

@media (max-width: 740px){
  .report-shell-simple{
    padding:14px;
  }
  .report-page-simple{
    gap:14px;
  }
  .report-topbar-simple{
    gap:12px;
  }
  .report-actions-simple{
    width:100%;
    justify-content:flex-start;
  }
  .report-simple-hero,
  .report-simple-panel,
  .report-simple-panel-wide{
    border-radius:24px;
    padding:20px;
  }
  .report-simple-hero p,
  .report-simple-panel-head p{
    font-size:15px;
  }
  .report-simple-list-item{
    align-items:flex-start;
  }
  .report-simple-list-value{
    font-size:24px;
  }
  .admin-login-card{
    padding:24px;
    border-radius:24px;
  }
  .admin-login-head h1{
    font-size:44px;
  }
  .admin-login-head p{
    font-size:16px;
  }
  .admin-login-field input,
  .admin-login-button{
    height:74px;
    font-size:20px;
    border-radius:22px;
  }
}


/* product detail add onboarding */
.detail-action{
  position:relative;
  z-index:18;
}

.detail-action .add-btn[data-onboarding="product-add"]{
  position:relative;
  overflow:visible;
  isolation:isolate;
  transform-origin:center center;
  will-change:transform;
  z-index:3;
}

.detail-action .add-btn[data-onboarding="product-add"] .add-btn-onboarding-text{
  position:absolute;
  top:50%;
  right:-9px;
width:min(200px,calc(100vw - 160px));
  max-width:calc(100vw - 40px);
  height:70px;
padding:0 64px 0 20px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:15px;
  font-weight:600;
  letter-spacing:-0.01em;
  line-height:1;
  color:#fff;
  background:#ef5a57;
  box-shadow:0 16px 34px rgba(239,90,87,.24);
  opacity:0;
  pointer-events:none;
  user-select:none;
  z-index:1;
  transform:translateY(-50%) translateX(0) scaleX(.28);
  transform-origin:right center;
  transition:opacity .22s ease,transform .52s cubic-bezier(.22,1,.36,1);
}

.detail-action .add-btn[data-onboarding="product-add"] .plus-icon{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  width:56px;
  height:56px;
  min-width:56px;
  border-radius:999px;
  background:#fff;
  color:#111;
  box-shadow:0 8px 18px rgba(0,0,0,.10),inset 0 1px 1px rgba(255,255,255,.9);
  transition:transform .52s cubic-bezier(.22,1,.36,1),box-shadow .24s ease,color .2s ease,background .2s ease;
}


.detail-action .add-btn[data-onboarding="product-add"].is-added{
  background:#f45b5b;
  box-shadow:0 10px 24px rgba(244,91,91,.28);
}

.detail-action .add-btn[data-onboarding="product-add"].is-added .plus-icon{
  background:transparent;
  box-shadow:none;
  color:#fff;
}

.detail-action .add-btn[data-onboarding="product-add"].is-added .plus-icon svg{
  stroke:#fff;
}

.detail-action .add-btn[data-onboarding="product-add"].is-added .add-btn-onboarding-text{
  opacity:0 !important;
}

.detail-action .add-btn[data-onboarding="product-add"].is-onboarding-open{
  animation:selectAddOnboardingBounce .62s cubic-bezier(.2,1.15,.32,1);
}

.detail-action .add-btn[data-onboarding="product-add"].is-onboarding-open .add-btn-onboarding-text{
  opacity:1;
  transform:translateY(-50%) translateX(0) scaleX(1);
}

.detail-action .add-btn[data-onboarding="product-add"].is-onboarding-closing .add-btn-onboarding-text{
  opacity:0;
  transform:translateY(-50%) translateX(0) scaleX(.28);
}

.detail-action .add-btn[data-onboarding="product-add"].is-onboarding-hidden{
  transition:none !important;
  animation:none !important;
}

@keyframes selectAddOnboardingBounce{
  0%{transform:scale(1)}
  55%{transform:scale(1.035)}
  78%{transform:scale(.99)}
  100%{transform:scale(1)}
}

@media (max-width:420px){
  .detail-action .add-btn[data-onboarding="product-add"] .add-btn-onboarding-text{
    width:min(220px,calc(100vw - 132px));
    max-width:calc(100vw - 40px);
    padding:0 72px 0 20px;
    font-size:14px;
  }
}

