/* WhichWine — Marketing one-pager: REFLOW layout (mobile + tablet)
   Loaded media="(max-width:1099.98px)". Lays out the SHARED #canvas DOM as a
   fluid, reflowing page. At >=1100 desktop.css takes over (pixel-exact PSD canvas)
   and these rules don't apply, so the same class names never collide. */

body{background:#cfc8c0;}                 /* frame backdrop behind the phone-width shell */
#stage{background:#cfc8c0;}

/* #canvas = the fluid shell (phone column on mobile, full-bleed on tablet).
   The desktop scaler clears its inline transform below 1100, so it lays out normally. */
#canvas{
  position:relative;max-width:480px;margin:0 auto;background:var(--bg);
  min-height:100vh;min-height:100dvh;overflow:hidden;box-shadow:0 0 60px rgba(0,0,0,.22);
  padding-bottom:calc(84px + env(safe-area-inset-bottom));
}

/* horizontal content frame shared by the below-hero sections */
.intro-grid,.stats,.block,.foot{
  width:100%;max-width:var(--maxw);margin-left:auto;margin-right:auto;
  padding-left:var(--gut);padding-right:var(--gut);
}

/* ---- sticky top bar ---- */
.topbar{
  position:sticky;top:0;z-index:40;background:var(--bar);
  display:flex;align-items:center;justify-content:center;gap:7px;padding:13px 18px;
  font-size:clamp(15px,1.9vw,30px);color:var(--tan);letter-spacing:.01em;font-weight:500;white-space:nowrap;}
.topbar b{color:#fff;font-weight:700;}
.topbar .dot{width:4px;height:4px;border-radius:50%;background:var(--tan);opacity:.6;}

/* ---- HERO (photo banner + overlaid headline) ---- */
.herointro{position:relative;}
.hero{position:relative;background:#0c0a09;overflow:hidden;}
.hero .bg{width:100%;height:auto;display:block;opacity:.93;}
.shade{position:absolute;inset:0;display:block;
  background:linear-gradient(180deg,rgba(8,6,5,.45) 0%,rgba(8,6,5,0) 30%,rgba(8,6,5,.5) 74%,rgba(8,6,5,.92) 100%);}
.hero-title{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;
  align-items:center;justify-content:flex-end;text-align:center;padding:0 24px 26px;}
.brand{margin:0;color:#fff;font-weight:700;font-size:clamp(48px,9.2vw,128px);line-height:.94;
  letter-spacing:-.035em;text-shadow:0 4px 26px rgba(0,0,0,.5);}
.b-which,.b-wine{position:static;}
.tag{margin:12px 0 0;color:var(--tan);font-weight:500;font-size:clamp(13px,1.5vw,24px);
  letter-spacing:.16em;text-transform:uppercase;}

/* ---- INTRO (text + media; stats) ---- */
.intro-grid{display:flex;flex-direction:column;gap:6px;padding-top:22px;}
.intro-media{order:-1;display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:6px;}
/* box-shadow, not a drop-shadow filter: WebKit hard-clips filter paint regions
   (visible shadow edge). The radius (≥ the PNG's ~40px bezel at this width)
   rounds the shadow rectangle; it clips only transparent corner pixels. */
.intro-media .phone{display:none;width:300px;border-radius:44px;box-shadow:0 26px 46px rgba(0,0,0,.42);}
.badge,.fbadge{display:block;width:180px;}
.badge img,.fbadge img{width:100%;height:auto;}
.price{display:inline-flex;align-items:baseline;gap:8px;color:var(--head);font-weight:500;
  font-size:clamp(14px,1.5vw,19px);letter-spacing:.01em;}
.price .eur{font-weight:700;font-size:clamp(19px,2vw,26px);color:var(--head);}
.price .sub{color:var(--ink);font-size:clamp(13px,1.3vw,17px);}

.introtext{padding-top:14px;}
.eyebrow{font-size:clamp(12px,1.2vw,15px);font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--tan-deep);margin:0 0 10px;}
h2.t{font-family:var(--sans);font-weight:400;color:var(--head);font-size:clamp(31px,4.1vw,55px);
  line-height:1.04;letter-spacing:-.01em;margin:0 0 16px;}
p.copy{font-family:var(--serif);font-weight:400;font-size:clamp(16px,1.55vw,24px);
  line-height:1.5;color:var(--ink);margin:0 0 16px;text-wrap:pretty;}
.lead{display:block;font-family:var(--sans);font-weight:300;font-size:clamp(20px,2.1vw,30px);line-height:1.32;
  color:var(--head);margin:0 0 16px;letter-spacing:-.01em;}
ul.ticks{list-style:none;margin:18px 0 0;padding:0;}
ul.ticks li{font-family:var(--sans);font-size:clamp(15px,1.5vw,24px);font-weight:500;color:var(--head);
  line-height:1.4;margin:0 0 9px;padding-left:26px;position:relative;}
ul.ticks li::before{content:"";position:absolute;left:2px;top:.55em;width:9px;height:9px;border-radius:50%;background:var(--tan);}

.stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:22px;background:var(--bar);border-radius:18px;overflow:hidden;}
.stats .s{padding:18px 8px;text-align:center;}
.stats .s + .s{border-left:1px solid rgba(194,170,147,.22);}
.stats .n{font-size:clamp(24px,3vw,40px);font-weight:700;color:#fff;line-height:1;}
.stats .l{font-size:clamp(11px,1.1vw,14px);font-weight:500;color:var(--tan);letter-spacing:.05em;margin-top:7px;text-transform:uppercase;}

/* ---- SECTIONS ---- */
.block{margin-top:34px;}

/* feature cards */
.card{background:var(--card);border-radius:22px;overflow:hidden;box-shadow:0 14px 30px rgba(40,28,18,.07);}
.card .split{display:flex;flex-direction:column;}
.card .ph{order:-1;position:relative;background:#ddd;aspect-ratio:16/10;}
.card .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.card .pad{padding:24px 22px 26px;position:relative;}
.card .pad h2.t{margin-bottom:12px;}
.glasswrap,.glassacc{display:none;}     /* desktop-only glass accent */
.disc{position:absolute;right:20px;top:-26px;width:52px;height:52px;border-radius:50%;
  overflow:hidden;box-shadow:0 6px 16px rgba(40,28,18,.20);z-index:2;margin:0;}
.disc img{width:100%;height:100%;object-fit:cover;}
.chip{display:inline-block;background:#f3ede7;color:var(--head);border:1px solid var(--line);
  font-size:clamp(13px,1.3vw,16px);font-weight:600;letter-spacing:.02em;padding:7px 14px;border-radius:999px;margin-top:4px;}

/* tile sections (carousel) — flat on the page bg, not a card */
.tilecard{background:none;box-shadow:none;border-radius:0;padding:0;}
.tilecard h2.t{margin-bottom:4px;}
.sub{display:block;font-family:var(--serif);font-size:clamp(15px,1.5vw,22px);color:var(--ink);margin:0 0 16px;line-height:1.45;}
.tiles{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-padding-left:var(--gut);scroll-padding-right:var(--gut);
  margin:0 calc(-1 * var(--gut));padding:4px var(--gut);-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.tiles::-webkit-scrollbar{display:none;}
.tile{position:relative;flex:0 0 76%;scroll-snap-align:start;border-radius:16px;overflow:hidden;aspect-ratio:3/4;background:#2a1d14;height:auto;}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.tile .scrim{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(18,11,7,.82) 0%,rgba(18,11,7,.34) 30%,rgba(18,11,7,0) 56%);}
.tile .lbl{position:absolute;left:18px;right:18px;top:20px;color:#fff;text-align:left;}
.tile .lbl h3{margin:0 0 7px;font-weight:600;font-size:clamp(20px,2vw,30px);line-height:1.02;}
.tile .lbl p{margin:0;font-weight:400;font-size:clamp(14px,1.3vw,18px);line-height:1.3;color:#efe7df;font-family:var(--serif);}
.dots{display:flex;justify-content:center;gap:7px;margin-top:14px;}
.dots button{width:6px;height:6px;border:0;padding:0;appearance:none;border-radius:50%;background:#c7bcb0;transition:.2s;cursor:pointer;}
.dots button.on{background:var(--tan-deep);width:18px;border-radius:3px;}

/* Nachschlagen (Glossar / Suche) */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.appcard{padding:24px 20px;text-align:center;}
.appcard h2.t{margin-bottom:6px;}
.appcard .row{display:block;}
.appcard .pf{width:150px;max-width:64%;margin:0 auto 14px;border-radius:20px;overflow:hidden;box-shadow:0 16px 26px rgba(40,28,18,.22);}
.appcard p{margin:0;font-family:var(--serif);font-size:clamp(14px,1.4vw,22px);line-height:1.45;color:var(--ink);}

/* FAQ */
.faqcard{padding:24px 20px;}
.faqcard h2.t{margin-bottom:10px;}
.faq{border-top:1px solid var(--line);}
.faq:first-of-type{border-top:0;}
.faq summary{cursor:pointer;list-style:none;position:relative;padding:14px 34px 14px 0;
  font-family:var(--sans);font-weight:500;color:var(--head);
  font-size:clamp(16px,1.6vw,24px);line-height:1.35;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"";position:absolute;right:6px;top:50%;width:9px;height:9px;
  border-right:2px solid var(--tan-deep);border-bottom:2px solid var(--tan-deep);
  /* -70%/-30% optically center the rotated box in both states */
  transform:translateY(-70%) rotate(45deg);transition:transform .2s;}
.faq[open] summary::after{transform:translateY(-30%) rotate(225deg);}
.faq p{margin:0;padding:0 0 16px;font-family:var(--serif);
  font-size:clamp(14px,1.4vw,22px);line-height:1.5;color:var(--ink);text-wrap:pretty;}

/* icon row (>=768 only) */
.iconrow{display:none;}
.iconstrip{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(14px,2.2vw,34px);max-width:1180px;margin:0 auto;}
.iconstrip img{width:clamp(52px,5.4vw,74px);height:clamp(52px,5.4vw,74px);border-radius:50%;}

/* footer */
.foot{text-align:center;padding-top:46px;padding-bottom:30px;margin-top:38px;}
.foot .mark{width:clamp(104px,14vw,210px);margin:0 auto 14px;}
.foot .wm{font-weight:700;color:var(--head);font-size:clamp(26px,3vw,38px);letter-spacing:.06em;}
.foot .sm{color:var(--tan-deep);font-size:clamp(13px,1.4vw,22px);letter-spacing:.16em;margin:4px 0 22px;text-transform:uppercase;}
.foot .dl{display:none;}                  /* sticky CTA covers download on mobile */
.foot .fbadge{margin:0 auto;}
.footbar{background:var(--bar);color:var(--tan);text-align:center;padding:18px;font-size:clamp(12px,1.2vw,15px);letter-spacing:.08em;}
.footbar .footlinks{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 22px;list-style:none;margin:0 0 10px;padding:0;}
.footbar a{color:var(--tan);text-decoration:none;}
.footbar a:hover{text-decoration:underline;}
.footbar .copyright{margin:0;opacity:.78;letter-spacing:.06em;}

/* sticky bottom CTA (mobile) */
.cta{position:fixed;left:0;right:0;bottom:0;z-index:50;max-width:480px;margin:0 auto;
  background:rgba(11,1,2,.97);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:13px 18px calc(13px + env(safe-area-inset-bottom));border-top:1px solid rgba(194,170,147,.25);}
.cta .txt{line-height:1.1;}
.cta .txt .a{color:#fff;font-weight:700;font-size:16px;}
.cta .txt .b{color:var(--tan);font-size:12.5px;font-weight:500;margin-top:2px;}
.cta .go{flex:0 0 auto;background:var(--tan);color:#1a0c06;font-weight:700;font-size:14.5px;
  text-decoration:none;padding:12px 20px;border-radius:999px;letter-spacing:.01em;white-space:nowrap;}

@media (max-width:479px){#canvas{box-shadow:none;}}

/* ════════ TABLET (768–1099) ════════ */
@media (min-width:768px){
  :root{--gut:30px;}
  #canvas{max-width:100%;min-height:0;padding-bottom:0;box-shadow:none;}

  .hero{height:clamp(440px,52vw,720px);clip-path:ellipse(135% 100% at 50% 0%);}
  .hero .bg{height:100%;object-fit:cover;}
  .hero-title{justify-content:center;padding-bottom:0;}

  .intro-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:clamp(30px,5vw,80px);align-items:start;padding-top:42px;}
  .intro-media{order:0;justify-content:flex-start;margin-bottom:0;margin-top:clamp(-200px,-22vw,-90px);}
  .intro-media .phone{display:block;}
  .introtext{padding-top:6px;}
  .stats{max-width:560px;margin-top:30px;}

  .card .split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}
  .card .ph{order:0;aspect-ratio:auto;min-height:300px;}
  .card .pad{padding:clamp(30px,4vw,52px);display:flex;flex-direction:column;justify-content:center;}
  .disc{width:64px;height:64px;right:28px;top:auto;bottom:28px;}

  .tiles{display:grid;overflow:visible;scroll-snap-type:none;margin:0;padding:0;}
  .tiles.three{grid-template-columns:repeat(3,1fr);gap:18px;}
  .tiles.four{grid-template-columns:repeat(2,1fr);gap:18px;}
  .tile{flex:none;}
  .tile .lbl{text-align:center;}
  .dots{display:none;}

  .duo{gap:24px;}
  .appcard{padding:clamp(28px,3vw,44px);text-align:left;}
  .appcard h2.t{text-align:center;margin-bottom:18px;}
  .appcard .row{display:grid;grid-template-columns:160px 1fr;gap:28px;align-items:center;}
  .appcard .pf{width:160px;max-width:none;margin:0;}

  .faqcard{padding:clamp(28px,3vw,44px);}

  .iconrow{display:block;}
  .iconstrip{flex-wrap:nowrap;justify-content:space-between;}
  .foot .dl{display:block;font-weight:700;color:#1a0c06;font-size:clamp(16px,1.7vw,24px);letter-spacing:.04em;margin:0 0 16px;text-transform:uppercase;}
  .cta{display:none;}
}
