.elementor-13 .elementor-element.elementor-element-7ebf48b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}/* Start custom CSS *//* ===== WINESTONE — FUNDAMENT GLOBALNY ===== */

/* Zmienne kolorystyczne marki */
:root {
  --ws-bg: #1a0612;
  --ws-bg2: #1A1714;
  --ws-bg3: #231F1B;
  --ws-bg4: #2C2520;
  --ws-t1: #F5F0E8;
  --ws-t2: #B8AFA3;
  --ws-t3: #7A7167;
  --ws-brand: #A8145A;
  --ws-brand-light: #C4186A;
  --ws-gold: #C9A962;
  --ws-gold-light: #DBBF7A;
  --ws-wine: #722F37;
}

/* Tło całej strony - dot pattern jak w referencji */
body {
  background-color: #1a0612;
  background-image: radial-gradient(rgba(168,20,90,.18) 1px, transparent 1px);
  background-size: 24px 24px;
  color: var(--ws-t1);
}

/* Utility klasy — dodawaj w polu "CSS Classes" widgetu */

/* Etykieta sekcji (np. "Nasza historia") */
.ws-label {
  font-size: .65rem !important;
  letter-spacing: .4em !important;
  text-transform: uppercase !important;
  color: var(--ws-brand-light) !important;
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}
.ws-label::before {
  content: '';
  width: 30px;
  height: 1px;
  background: var(--ws-brand);
}

/* Tytuł sekcji z akcentem italic */
.ws-title em,
.ws-title i {
  font-style: italic;
  color: var(--ws-brand-light);
}

/* Przycisk główny (magenta solid) */
.ws-btn-primary {
  background: var(--ws-brand) !important;
  color: #fff !important;
  border: 1px solid var(--ws-brand) !important;
  letter-spacing: .25em !important;
  text-transform: uppercase !important;
  transition: all .4s !important;
}
.ws-btn-primary:hover {
  background: var(--ws-brand-light) !important;
  border-color: var(--ws-brand-light) !important;
}

/* Przycisk outline */
.ws-btn-outline {
  background: transparent !important;
  color: var(--ws-brand-light) !important;
  border: 1px solid var(--ws-brand) !important;
  letter-spacing: .25em !important;
  text-transform: uppercase !important;
}
.ws-btn-outline:hover {
  background: var(--ws-brand) !important;
  color: #fff !important;
}

/* Przycisk złoty */
.ws-btn-gold {
  background: transparent !important;
  color: var(--ws-gold) !important;
  border: 1px solid var(--ws-gold) !important;
  letter-spacing: .25em !important;
  text-transform: uppercase !important;
}
.ws-btn-gold:hover {
  background: var(--ws-gold) !important;
  color: var(--ws-bg) !important;
}

/* Karta z obramowaniem (dla feature box, reviews, wine cards) */
.ws-card {
  padding: 1.5rem !important;
  border: 1px solid rgba(168,20,90,.1) !important;
  background: rgba(168,20,90,.03) !important;
  transition: border-color .3s;
}
.ws-card:hover {
  border-color: rgba(168,20,90,.3) !important;
}

/* Sekcja z ciemniejszym tłem (naprzemienne) */
.ws-section-dark {
  background-color: var(--ws-bg2) !important;
}

:root{
    --primary:#A8145A;
    --secondary:#C4186A;
    --text:#F5F0E8;
    --accent:#C9A962;
    --bg:#151014;
    --line:rgba(245,240,232,0.12);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Outfit',sans-serif;font-weight:300;-webkit-font-smoothing:antialiased}

  /* ============================
     TOP BAR (phone + socials)
     ============================ */
  .ws-topbar{
    position:fixed;top:0;left:0;right:0;z-index:51;
    padding:10px 32px;
    display:flex;align-items:center;justify-content:space-between;gap:24px;
    background:rgba(13,10,12,0.7);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
    font-size:11px;
    transition:transform .35s ease, opacity .3s ease;
  }
  .ws-topbar.hidden{transform:translateY(-100%);opacity:0;pointer-events:none}
  .ws-topbar .tb-left{display:flex;align-items:center;gap:22px;opacity:.85}
  .ws-topbar .tb-right{display:flex;align-items:center;gap:18px}
  .ws-topbar .tb-meta{
    font-family:'Outfit';font-weight:400;font-size:10px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--text);opacity:.7;
  }
  .ws-topbar .tb-meta .sep{color:var(--accent);opacity:.5;margin:0 8px;font-size:8px}
  .ws-topbar a.tb-address{
    display:inline-flex;align-items:center;gap:8px;
    text-decoration:none;
    opacity:.75;transition:opacity .2s ease, color .2s ease;
  }
  .ws-topbar a.tb-address:hover{opacity:1;color:var(--accent)}
  .ws-topbar a.tb-address svg{
    width:12px;height:12px;flex-shrink:0;
    transform:translateY(-0.5px);
    opacity:.9;
  }

  /* ============================
     NAV (desktop)
     ============================ */
  .ws-nav{
    position:fixed;top:38px;left:0;right:0;z-index:50;
    padding:22px 32px;
    display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px;
    transition:background .4s ease, backdrop-filter .4s ease, border-color .4s ease, padding .4s ease, top .4s ease;
    border-bottom:1px solid transparent;
  }
  .ws-nav.scrolled{
    top:0;
    background:rgba(21,16,20,0.82);
    backdrop-filter:blur(18px) saturate(140%);
    -webkit-backdrop-filter:blur(18px) saturate(140%);
    border-bottom-color:var(--line);
    padding:14px 32px;
  }

  /* left / right clusters — perfectly symmetric now */
  .ws-nav .cluster{display:flex;align-items:center;gap:18px;min-width:0}
  .ws-nav .cluster.left{justify-content:flex-end;padding-right:12px}
  .ws-nav .cluster.right{justify-content:flex-start;padding-left:12px}
  .ws-nav .links{display:flex;align-items:center;gap:18px;flex-wrap:nowrap}

  .ws-nav a.link{
    position:relative;
    color:var(--text);text-decoration:none;
    font-family:'Outfit';font-weight:300;
    font-size:13px;letter-spacing:.22em;text-transform:uppercase;
    padding:6px 0;
    opacity:.88;
    white-space:nowrap;
    transition:opacity .2s ease, color .2s ease;
  }
  .ws-nav a.link::after{
    content:"";position:absolute;left:50%;right:50%;bottom:0;height:1px;
    background:var(--accent);opacity:0;
    transition:left .35s cubic-bezier(.2,.7,.2,1), right .35s cubic-bezier(.2,.7,.2,1), opacity .2s ease;
  }
  .ws-nav a.link:hover{opacity:1;color:var(--accent)}
  .ws-nav a.link:hover::after{left:0;right:0;opacity:1}

  /* diamond separators */
  .ws-nav .sep{
    color:var(--accent);opacity:.55;
    font-size:8px;line-height:1;
    transform:translateY(-1px);
    user-select:none;pointer-events:none;
  }

  /* center logo */
  .ws-nav .logo{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
  .ws-nav .logo img{display:block;height:28px;width:auto;transition:height .4s ease}
  .ws-nav.scrolled .logo img{height:22px}

  /* right side extras — scoped to both .ws-nav and .ws-right-fixed / .ws-left-fixed */
  .ws-nav .right-cluster{display:flex;align-items:center;gap:20px;justify-content:flex-end}
  .phone{
    display:inline-flex;align-items:center;gap:8px;
    color:var(--text);text-decoration:none;
    font-family:'Outfit';font-weight:400;
    font-size:12px;letter-spacing:.12em;
    white-space:nowrap;
    opacity:.75;transition:opacity .2s, color .2s;
  }
  .phone svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.5;flex-shrink:0}
  .phone:hover{opacity:1;color:var(--accent)}

  .socials{display:flex;align-items:center;gap:12px}
  .socials a{
    display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;
    color:var(--text);opacity:.65;transition:opacity .2s, color .2s;
    text-decoration:none;
  }
  .socials a:hover{opacity:1;color:var(--accent)}
  .socials svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.3}

  .cta{
    position:relative;
    color:var(--accent);text-decoration:none;
    font-family:'Outfit';font-weight:600;
    font-size:12px;letter-spacing:.26em;text-transform:uppercase;
    padding:6px 0;
    border-bottom:1px solid var(--accent);
    transition:color .25s ease, border-color .25s ease, letter-spacing .25s ease;
    white-space:nowrap;
  }
  .cta:hover{color:var(--text);border-color:var(--text);letter-spacing:.3em}

  /* open/closed status dot */
  .status{
    display:inline-flex;align-items:center;gap:8px;
    background:none;border:none;padding:0;margin:0;
    font-family:'Outfit';font-weight:400;
    font-size:10px;letter-spacing:.26em;text-transform:uppercase;
    color:var(--text);opacity:.7;
  }
  .status .dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--accent);
    box-shadow:0 0 0 0 currentColor;
  }
  .status.is-open .dot{
    background:#7FB796;color:#7FB796;
    animation:pulse 2.4s ease-in-out infinite;
  }
  .status.is-closed .dot{background:#8a4a5a;color:#8a4a5a}
  @keyframes pulse{
    0%,100%{box-shadow:0 0 0 0 rgba(127,183,150,.55)}
    50%{box-shadow:0 0 0 6px rgba(127,183,150,0)}
  }

  /* status interactive wrapper + hours popover */
  .status-wrap{position:relative}
  .status-wrap .status{
    cursor:pointer;
    transition:opacity .2s ease, color .2s ease;
    padding:4px 2px;
    border-radius:2px;
  }
  .status-wrap .status:hover{opacity:1;color:var(--accent)}
  .status-wrap .status:hover .next-time{color:var(--accent);opacity:.9}
  .status-wrap .status .next-time{
    display:inline-block;
    margin-left:2px;
    opacity:.55;
    font-weight:300;
    letter-spacing:.18em;
    transition:opacity .2s ease, color .2s ease;
  }
  .status-wrap .status .next-time::before{
    content:"·";margin:0 6px 0 2px;opacity:.6;
  }
  .status-wrap .status::after{
    content:"";display:inline-block;width:0;height:0;margin-left:8px;
    border-left:3.5px solid transparent;border-right:3.5px solid transparent;
    border-top:4px solid currentColor;opacity:.7;
    transform:translateY(1px);
    transition:transform .25s ease, opacity .2s ease;
  }
  .status-wrap .status:hover::after{opacity:1}
  .status-wrap.open .status::after{transform:translateY(1px) rotate(180deg);opacity:1}

  .hours-pop{
    position:absolute;top:calc(100% + 14px);left:-12px;
    min-width:280px;
    background:rgba(21,16,20,0.96);
    backdrop-filter:blur(20px) saturate(140%);
    -webkit-backdrop-filter:blur(20px) saturate(140%);
    border:1px solid var(--line);
    border-radius:2px;
    padding:18px 20px 16px;
    box-shadow:0 24px 60px rgba(0,0,0,.55);
    opacity:0;transform:translateY(-6px);pointer-events:none;
    transition:opacity .25s ease, transform .25s ease;
    z-index:60;
  }
  .status-wrap.open .hours-pop{opacity:1;transform:translateY(0);pointer-events:auto}
  .hours-pop::before{
    content:"";position:absolute;top:-5px;left:22px;width:8px;height:8px;
    background:rgba(21,16,20,0.96);
    border-left:1px solid var(--line);border-top:1px solid var(--line);
    transform:rotate(45deg);
  }
  .hours-pop h5{
    margin:0 0 12px;
    font-family:'Outfit';font-weight:400;font-size:10px;
    letter-spacing:.3em;text-transform:uppercase;color:var(--accent);
  }
  .hours-pop table{width:100%;border-collapse:collapse;font-family:'Outfit';font-size:12px}
  .hours-pop tr{border-bottom:1px solid rgba(255,255,255,.04)}
  .hours-pop tr:last-child{border-bottom:none}
  .hours-pop td{padding:7px 0;vertical-align:top;color:var(--text);opacity:.85}
  .hours-pop td.day{
    letter-spacing:.1em;text-transform:lowercase;opacity:.65;
    width:40%;
  }
  .hours-pop td.shifts{text-align:right;font-variant-numeric:tabular-nums}
  .hours-pop td.shifts span{display:block;line-height:1.45}
  .hours-pop tr.today td{opacity:1;color:var(--accent-soft,#E8B554)}
  .hours-pop tr.today td.day{opacity:.95}
  .hours-pop tr.today td.day::before{
    content:"";display:inline-block;width:4px;height:4px;border-radius:50%;
    background:var(--accent);margin-right:8px;transform:translateY(-2px);
  }
  /* drawer hours table — reuses .ws-hours-body */
  .d-hours table tr{border-bottom:1px solid rgba(255,255,255,.04)}
  .d-hours table tr:last-child{border-bottom:none}
  .d-hours table td{padding:6px 0;color:var(--text);opacity:.8}
  .d-hours table td.day{letter-spacing:.08em;text-transform:lowercase;opacity:.6;width:42%;font-size:11px}
  .d-hours table td.shifts{text-align:right;font-size:11px}
  .d-hours table td.shifts span{display:block;line-height:1.5}
  .d-hours table tr.today td{opacity:1;color:var(--accent)}

  /* on scrolled / dark nav, right-align popover for right-side status */
  .cluster.right .hours-pop{left:auto;right:-12px}
  .cluster.right .hours-pop::before{left:auto;right:22px}

  /* burger (mobile) */
  .ws-burger{
    display:none;
    background:none;border:none;padding:10px;margin:-10px;cursor:pointer;
    color:var(--text);
  }
  .ws-burger span{
    display:block;width:24px;height:1px;background:currentColor;
    margin:6px 0;transition:transform .3s ease, opacity .3s ease;
  }
  body.menu-open .ws-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.menu-open .ws-burger span:nth-child(2){opacity:0}
  body.menu-open .ws-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* ============================
     MOBILE OFF-CANVAS (right)
     ============================ */
  .ws-drawer-scrim{
    position:fixed;inset:0;z-index:60;
    background:rgba(13,10,12,0.6);
    backdrop-filter:blur(6px);
    opacity:0;pointer-events:none;transition:opacity .3s ease;
  }
  .ws-drawer{
    position:fixed;top:0;right:0;bottom:0;z-index:70;
    width:min(420px, 88vw);
    background:rgba(21,16,20,0.98);
    backdrop-filter:blur(20px);
    border-left:1px solid var(--line);
    padding:96px 40px 40px;
    transform:translateX(100%);
    transition:transform .45s cubic-bezier(.2,.7,.2,1);
    display:flex;flex-direction:column;gap:4px;
    overflow-y:auto;
  }
  body.menu-open .ws-drawer-scrim{opacity:1;pointer-events:auto}
  body.menu-open .ws-drawer{transform:translateX(0)}
  .ws-drawer .close{
    position:absolute;top:28px;right:28px;
    background:none;border:none;color:var(--text);cursor:pointer;
    font-family:'Outfit';font-size:11px;letter-spacing:.26em;text-transform:uppercase;
    opacity:.7;transition:opacity .2s;
  }
  .ws-drawer .close:hover{opacity:1;color:var(--accent)}
  .ws-drawer a.d-link{
    display:block;
    font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
    font-size:34px;line-height:1.6;
    color:var(--text);text-decoration:none;
    padding:2px 0;
    transition:color .2s, padding-left .25s ease;
  }
  .ws-drawer a.d-link:hover{color:var(--accent);padding-left:10px}
  .ws-drawer .divider{height:1px;background:var(--line);margin:28px 0 24px}
  .ws-drawer .d-cta{
    align-self:flex-start;
    color:var(--accent);text-decoration:none;
    font-family:'Outfit';font-weight:600;
    font-size:12px;letter-spacing:.26em;text-transform:uppercase;
    padding:6px 0;border-bottom:1px solid var(--accent);
    margin-top:4px;
  }
  .ws-drawer .d-meta{
    margin-top:auto;padding-top:36px;
    display:flex;flex-direction:column;gap:14px;
    font-size:12px;letter-spacing:.14em;
  }
  .ws-drawer .d-meta a{color:var(--text);text-decoration:none;opacity:.75}
  .ws-drawer .d-meta .socials{display:flex;gap:14px}
  .ws-drawer .d-meta .socials a{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:50%;opacity:.8}
  .ws-drawer .d-meta .socials a:hover{color:var(--accent);border-color:var(--accent);opacity:1}
  .ws-drawer .d-meta .socials svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.3}

  /* ============================
     RESPONSIVE SWITCH
     ============================ */
  @media (max-width: 1100px){
    .ws-topbar{display:none}
    .ws-nav{top:0}
    .ws-nav .cluster .links,
    .ws-nav .cluster .cta,
    .ws-nav .cluster.left .status{display:none}
    .ws-nav{grid-template-columns:1fr auto 1fr;padding:18px 24px}
    .ws-nav.scrolled{padding:12px 24px}
    .ws-burger{display:block;justify-self:start}
    .ws-nav .logo{justify-self:center}
    .ws-nav .cluster.left{display:none}
    .ws-nav .cluster.right{justify-content:flex-end}
    .ws-nav .cluster.right .status{display:inline-flex;font-size:9px;letter-spacing:.22em}
    #wsStatusMobile{display:inline-flex !important}
  }
  @media (min-width:1101px){
    #wsStatusMobile{display:none}
  }
  @media (max-width: 520px){
    #wsStatusMobile span:not(.dot){display:none}
  }
  @media (max-width: 520px){
    .ws-nav .cluster.right .status span:not(.dot){display:none}
  }/* End custom CSS */