/* =========================================================
   Centre of Soul — styles.css (lavender / violet / rose)
   ========================================================= */
:root{
  --bg:#fbf8ff; --ink:#0f0a1f; --muted:#5b5b73; --line:#ece7f6; --card:#ffffff;
  --primary:#7c3aed; --accent:#ec4899; --river:#dbeafe;
  --shadow:0 10px 28px rgba(124,58,237,.12); --radius:16px;
  --focus:#c4b5fd; --hover:#f6edff;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial;font-size:16px;line-height:1.6;color:var(--ink);background:var(--bg)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1140px;margin:auto;padding:0 20px}
.grid{display:grid;gap:20px}
.row{display:flex;gap:12px}
.center{align-items:center}
.between{justify-content:space-between}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px}

/* Header & Nav */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.navbar{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;padding:12px 0}
.brand a{display:flex;gap:10px;align-items:center;font-weight:800;white-space:nowrap}
.brand img{height:26px;width:auto;display:block}
.links{display:flex;gap:14px;justify-content:center}
.links a{padding:10px 12px;border-radius:12px;white-space:nowrap}
.links a:hover{background:var(--hover)}
.nav-actions{display:flex;justify-content:flex-end;gap:10px}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);background:#fff;border-radius:12px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:6px auto}
.nav-cart{position:relative;border:1px solid var(--line);background:#fff;border-radius:12px;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center}
.nav-cart svg{width:20px;height:20px}
.badge{position:absolute;top:-6px;right:-6px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-radius:999px;padding:2px 6px;font-size:11px;line-height:1}
@media (max-width:900px){
  .navbar{grid-template-columns:auto 44px}
  .links{position:fixed;right:16px;top:72px;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:10px;display:none;flex-direction:column}
  .links.open{display:flex}
  .nav-actions{display:none}
  .nav-toggle{display:block;justify-self:end}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:12px;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:700;line-height:1;transition:transform .2s,background .2s,box-shadow .2s;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;box-shadow:0 6px 16px rgba(236,72,153,.18)}
.btn-ghost{background:#f7f2ff}
.btn.wide{width:100%}
.note{font-size:12px;color:#64748b}

/* Hero */

.h1{font-size:clamp(30px,5vw,44px);margin-bottom:10px}
.h2{font-size:clamp(24px,4vw,32px);margin-bottom:8px}
.muted{color:var(--muted)}

/* Carousel */
.hero-carousel{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin:16px 0}
.slides{position:relative;height:min(56vh,520px)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .5s ease}
.slide.active{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover}
.slide figcaption{position:absolute;left:12px;bottom:12px;background:rgba(15,23,42,.45);color:#fff;padding:6px 10px;border-radius:10px;font-size:12px}
.carousel-ui{position:absolute;inset:0;display:flex;justify-content:space-between;align-items:center;pointer-events:none}
.carousel-ui button{pointer-events:auto;background:rgba(255,255,255,.9);border:1px solid var(--line);width:40px;height:40px;border-radius:999px;margin:10px;font-size:20px}
.carousel-dots{position:absolute;left:0;right:0;bottom:8px;display:flex;justify-content:center;gap:6px}
.carousel-dots button{width:8px;height:8px;border-radius:999px;border:1px solid #fff;background:rgba(255,255,255,.7)}
.carousel-dots button.active{background:#fff}

/* Sections & Cards */
.section{padding:56px 0}
.section.alt{background:#fff}
.section-head{text-align:center;margin-bottom:12px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);text-align:center}
.card.soft{background:#fefbff}
.cards-popular{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.cards-popular{grid-template-columns:1fr}}
.service-img{width:100%;height:260px;object-fit:cover;border-radius:12px;margin-bottom:10px}
.meta{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin:6px 0}
.badge-time,.badge-price{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);padding:6px 10px;border-radius:999px;font-weight:700}
.badge-price{background:#fbfeff}
.badge-price small{font-weight:600;color:var(--muted);margin-left:2px}

/* Currency pills */
.currency-toggle{display:flex;gap:8px;align-items:center;justify-content:center}
.pill{border:1px solid var(--line);background:#fff;padding:8px 16px;border-radius:999px;cursor:pointer;font-weight:700;box-shadow:0 2px 6px rgba(15,23,42,.05)}
.pill:hover{background:#fbf8ff}
.pill.active{background:linear-gradient(135deg,#ede9fe,#ffe3f1);border-color:#e9d5ff;color:#4c1d95}

/* Pricing */
.pricing-neo .neo-cards{grid-template-columns:repeat(3,1fr)}
@media (max-width:1100px){.pricing-neo .neo-cards{grid-template-columns:1fr}}
.neo-card{display:flex;flex-direction:column;gap:12px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow);text-align:center}
.neo-card.highlight{border-color:#eadcff;box-shadow:0 8px 26px rgba(124,58,237,.15)}
.tag{display:inline-block;font-size:12px;padding:4px 8px;border:1px solid var(--line);border-radius:999px;background:#faf5ff}
.tag-accent{border-color:#ffd5ea;background:#fff1f7}
.neo-price{display:flex;flex-direction:column;align-items:center}
.neo-price .price{display:flex;align-items:flex-end;justify-content:center;gap:8px;font-weight:800}
.neo-price .unit{font-size:14px;color:#475569}
.neo-price .amt{font-size:36px;line-height:1}
.neo-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;justify-items:center}
.neo-list li{width:100%;max-width:520px;padding:10px 0;border-top:1px dashed #e6edf5}
.neo-list li:first-child{border-top:0}

/* Forms & Booking */
.form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow);text-align:left}
.form-grid{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
.form-grid .full{grid-column:1/-1}
@media (max-width:720px){.form-grid{grid-template-columns:1fr}}
input,select,textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:12px;font:inherit;background:#f8f5ff}
textarea{min-height:120px}

/* Calendar embed */
.calendar-embed{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.cal-inline{width:100%;height:720px}

/* Cart (drawer) */
.cart-section-head{
  font-weight:800; letter-spacing:.2px; padding:6px 0 4px;
  border-bottom:1px solid var(--line); margin:6px 0 10px; text-transform:uppercase;
  font-size:12px; color:#6b7280;
}

.cart-drawer{position:fixed;right:0;top:0;bottom:0;width:min(420px,92vw);background:#fff;border-left:1px solid var(--line);box-shadow:var(--shadow);transform:translateX(100%);transition:transform .28s ease;z-index:90;display:flex;flex-direction:column}
.cart-drawer.open{transform:none}
.cart-head{padding:16px;border-bottom:1px solid var(--line);display:grid;justify-items:center;gap:8px}
.cart-logo{font-weight:800}
.cart-close{position:absolute;left:12px;top:12px;border:none;background:#fff;width:36px;height:36px;border-radius:999px;box-shadow:0 2px 6px rgba(0,0,0,.06);display:flex;align-items:center;justify-content:center}
.cart-close svg{width:18px;height:18px}
.cart-body{padding:14px 16px;overflow:auto;display:grid;gap:12px}
.cart-item{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;border-bottom:1px dashed var(--line);padding:8px 0}
.cart-item .desc{grid-column:1/-1;color:#6b7280;font-size:12px;margin-top:-2px}
.cart-item .qty{display:flex;align-items:center;gap:6px}
.cart-item .qty button{width:28px;height:28px;border-radius:8px}
.cart-foot{padding:14px 16px;border-top:1px solid var(--line);display:grid;gap:10px}
.cart-total{display:flex;justify-content:space-between;font-weight:800}
.tip-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
input[type="range"]{appearance:none;height:6px;border-radius:999px;background:#eee;outline:none}
input[type="range"]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 2px 8px rgba(124,58,237,.3)}
#tip-input{width:70px;text-align:center}

/* Modal (Service detail) */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(17,12,33,.35);z-index:100}
.modal.open{display:flex;animation:fadeIn .2s ease both}
.modal-box{width:min(820px,95vw);max-height:85vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.modal-head{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-body{padding:14px 16px;display:grid;gap:10px}
.modal-foot{padding:14px 16px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Portal */
.portal-grid{display:grid;grid-template-columns:1.1fr 1.9fr;gap:18px}
.portal-grid.single{grid-template-columns:1fr}
@media (max-width:900px){.portal-grid{grid-template-columns:1fr}}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.files li{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding:8px 0}
.view-json{background:#0f172a;color:#e5e7eb;padding:12px;border-radius:12px;overflow:auto;max-height:260px;text-align:left;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px}
.portal-lists{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:700px){.portal-lists{grid-template-columns:1fr}}
.portal-lists ul{list-style:none;padding:0;margin:0}
.portal-lists li{padding:8px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between}

/* Meditation */
.meditation-hero{background:linear-gradient(180deg,#e0f2fe 0%,#dbeafe 60%,#eff6ff 100%)}
.river{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--line);background:var(--river)}
.river::before,.river::after{content:"";position:absolute;inset:-40% -20%;background:radial-gradient( ellipse at 50% 50%, rgba(59,130,246,.28), transparent 60%);animation:flow 12s linear infinite}
.river::after{animation-duration:18s;animation-direction:reverse}
@keyframes flow{0%{transform:translateX(-20%) translateY(0)}50%{transform:translateX(20%) translateY(-10%)}100%{transform:translateX(-20%) translateY(0)}}
.timer{font-variant-numeric:tabular-nums;letter-spacing:2px;font-weight:800;font-size:42px;padding:18px 0}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:24px 0;background:#fff;text-align:center}
.disclaimer{color:#64748b;font-size:13px}

/* Motion */
@media (prefers-reduced-motion:no-preference){
  .transition-in{animation:fadeSlide .5s ease both}
  @keyframes fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
}


/* Meditation full height & waves */
.meditation-full{min-height:calc(100vh - 72px);display:flex;flex-direction:column;justify-content:flex-start}


/* Timer UI */
.timer-wrap{position:relative;width:220px;height:220px;margin:14px auto}
.timer-svg{position:absolute;inset:0;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:#eee;stroke-width:10}
.ring{fill:none;stroke:linear-gradient(135deg,var(--primary),var(--accent));stroke:#a78bfa;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .5s ease}
.timer{position:absolute;inset:0;display:grid;place-items:center;font-variant-numeric:tabular-nums;letter-spacing:2px;font-weight:800;font-size:44px;color:#3f3cbb}

/* Calendar tweaks (visibility) */
.calendar .head strong{font-weight:800}
.calendar .cell{background:#fff}
.calendar .cell.disabled{opacity:.5;pointer-events:none}
.calendar .slot{min-width:54px}


/* Calendar cosmetics */
#calGrid .dow{font-weight:700;color:#6b7280;text-align:center}
#calGrid .cell{border:1px solid var(--line);border-radius:12px;padding:6px;min-height:110px;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.03)}
#calGrid .cell.dim{opacity:.4}
#calGrid .dnum{font-weight:700;margin-bottom:4px}
#calGrid .slot{display:inline-block;margin:2px;border:1px solid var(--line);background:#f8f5ff;padding:6px 8px;border-radius:999px;font-size:12px;cursor:pointer}
#calGrid .slot.selected{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}
#calGrid .slot.booked{opacity:.35;cursor:not-allowed}

/* Shop hover */
.shop-item:hover{box-shadow:0 12px 26px rgba(124,58,237,.18); transform:translateY(-2px); transition:.2s}

/* Portal auth spacing like your mock */
#authPanel .panel .btn.wide, #authPanel .panel .btn{height:100%}
.hidden{display:none !important}

/* --- HERO base --- */
.hero{
  position:relative;
  overflow:hidden;
  padding:36px 0 8px;
  background:linear-gradient(180deg,#f5f0ff 0%, #f9f6ff 55%, #ffffff 100%);
}

/* wszystko w hero nad falami */
.hero > *{ position:relative; z-index:1; }

/* --- WAVES component (default: violet) --- */
.hero-waves{
  position:absolute;
  left:0; right:0; bottom:-1px;         /* -1px = zero szpary */
  height:240px;
  z-index:0;
  pointer-events:none;
}

/* warstwa tylna (jaśniejsza, wolniejsza) */
.hero-waves::before{
  content:"";
  position:absolute; inset:0;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'><path fill='%23c7b3ff' fill-opacity='0.45' d='M0,224L40,202.7C80,181,160,139,240,133.3C320,128,400,160,480,165.3C560,171,640,203,720,213.3C800,224,880,192,960,181.3C1040,171,1120,181,1200,186.7C1280,192,1360,192,1400,192L1440,192L1440,320L0,320Z'/></svg>")
    repeat-x left bottom;
  background-size:200% 100%;
  animation:waveBack 28s linear infinite;
}

/* warstwa przednia (ciemniejsza, szybsza, kierunek przeciwny) */
.hero-waves::after{
  content:"";
  position:absolute; inset:0;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 520'><path fill='%23a78bfa' fill-opacity='0.75' d='M0,256L40,256C80,256,160,256,240,245.3C320,235,400,213,480,213.3C560,213,640,235,720,234.7C800,235,880,213,960,202.7C1040,192,1120,213,1200,213.3C1280,213,1360,192,1400,192L1440,192L1440,320L0,320Z'/></svg>")
    repeat-x left bottom;
  background-size:200% 100%;
  animation:waveFront 18s linear infinite reverse;
}

/* animacje */
@keyframes waveFront{
  from{ background-position-x: 0; }
  to  { background-position-x: -1440px; }
}
@keyframes waveBack{
  from{ background-position-x: 0; }
  to  { background-position-x: 1440px; }
}

/* --- BLUE theme (tylko zmiana kolorów fal, geometria i animacje – te same) --- */
.hero-waves.is-blue::before{
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'><path fill='%2393c5fd' fill-opacity='0.45' d='M0,224L40,202.7C80,181,160,139,240,133.3C320,128,400,160,480,165.3C560,171,640,203,720,213.3C800,224,880,192,960,181.3C1040,171,1120,181,1200,186.7C1280,192,1360,192,1400,192L1440,192L1440,320L0,320Z'/></svg>");
}
.hero-waves.is-blue::after{
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'><path fill='%2360a5fa' fill-opacity='0.78' d='M0,256L40,256C80,256,160,256,240,245.3C320,235,400,213,480,213.3C560,213,640,235,720,234.7C800,235,880,213,960,202.7C1040,192,1120,213,1200,213.3C1280,213,1360,192,1400,192L1440,192L1440,320L0,320Z'/></svg>");
}
.nav-cart svg{width:22px;height:22px;display:block}