:root{
  --ink:#18322d;--muted:#668077;--cream:#f7f1e7;--sand:#dfc8a8;--aqua:#21c7c5;--aqua-dark:#008f91;--coral:#f06f61;--green:#315f4f;--white:#fff;--line:#e6dac9;--shadow:0 24px 80px rgba(24,50,45,.14);
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:linear-gradient(180deg,#fbf7ef 0%,#edf8f6 52%,#fbf7ef 100%)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0}a{color:var(--aqua-dark);font-weight:800;text-decoration:none}a:hover{text-decoration:underline}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px clamp(16px,4vw,56px);background:rgba(247,241,231,.86);backdrop-filter:blur(18px);border-bottom:1px solid rgba(230,218,201,.75)}.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-size:22px;font-weight:950;letter-spacing:.02em}.brand:hover{text-decoration:none}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:999px;background:linear-gradient(135deg,var(--aqua),#eafffb);color:#063e40;box-shadow:0 10px 24px rgba(33,199,197,.28)}nav{display:flex;gap:18px;flex-wrap:wrap}nav a{color:var(--green);font-size:14px}.hero,.section,.footer{max-width:1180px;margin:0 auto}.landing-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:44px;align-items:center;padding:72px 24px 52px}.hero-copy h1{font-size:clamp(42px,6vw,76px);line-height:.94;margin:0 0 22px;letter-spacing:-.06em;color:#112d29}.eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--aqua-dark);font-weight:950;font-size:12px;margin:0 0 12px}.lead{font-size:clamp(18px,2.1vw,23px);line-height:1.48;color:#49655d;margin:0 0 28px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.btn,button{font:inherit;border-radius:999px;border:1px solid transparent;padding:13px 20px;cursor:pointer;font-weight:950}.primary{background:linear-gradient(135deg,var(--coral),#ff9f79);color:white;box-shadow:0 14px 34px rgba(240,111,97,.28)}.ghost{background:rgba(255,255,255,.72);border-color:var(--line);color:var(--green)}.btn.full{width:100%;border-radius:18px}.trust-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.trust-row span{padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--green);font-weight:900;font-size:13px}.hero-media{position:relative;min-height:560px}.hero-img{object-fit:cover;border-radius:36px;box-shadow:var(--shadow);border:8px solid rgba(255,255,255,.82)}.hero-img.main{width:100%;height:520px}.hero-img.floating{position:absolute;width:38%;height:220px}.hero-img.one{left:-34px;bottom:18px}.hero-img.two{right:-16px;bottom:-22px;height:180px}.section{padding:54px 24px}.split{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:start}.section h2{font-size:clamp(32px,4.4vw,54px);line-height:1;margin:0 0 18px;letter-spacing:-.04em}.section p{font-size:17px;line-height:1.65;color:var(--muted)}.feature-card,.service-card,.booking-card,.contact-panel,.card{background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:30px;padding:26px;box-shadow:0 18px 60px rgba(24,50,45,.08)}.check-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}.check-list li{font-weight:850;color:var(--green)}.check-list li:before{content:'✓';display:inline-grid;place-items:center;width:22px;height:22px;margin-right:10px;border-radius:999px;background:var(--aqua);color:white}.section-head{max-width:760px;margin-bottom:26px}.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.service-card{min-height:230px}.service-card .icon{font-size:38px}.service-card h3,.feature-card h3,.contact-panel h3{font-size:24px;margin:12px 0}.service-card b{color:var(--aqua-dark)}.gallery-section{padding-top:30px}.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.insta-grid img{width:100%;height:220px;object-fit:cover;border-radius:22px;box-shadow:0 10px 30px rgba(24,50,45,.12)}.insta-grid img:nth-child(1),.insta-grid img:nth-child(6){grid-column:span 2}.instagram-link{display:inline-block;margin-top:18px}.booking-section{background:rgba(255,255,255,.42);border:1px solid rgba(230,218,201,.75);border-radius:42px;margin-top:30px;margin-bottom:30px}.booking-card{display:grid;gap:16px}form{display:grid;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}label{display:grid;gap:8px;font-weight:900;color:var(--green)}input,select{font:inherit;width:100%;border-radius:18px;border:1px solid #d9ccb9;padding:14px 15px;background:#fff;color:var(--ink)}.hint{margin:0;color:#6a8179;font-size:14px}.slots-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:22px;background:#fff}.slots-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.slots-table th,.slots-table td{padding:9px;border-bottom:1px solid #eee4d5;text-align:center}.slots-table th:first-child{width:32%;text-align:left;color:var(--green)}.slots-table tr:last-child th,.slots-table tr:last-child td{border-bottom:0}.slot-cell{width:100%;min-height:46px;padding:9px 6px;border-radius:14px;white-space:nowrap;background:#e8faf8;color:#07585a;border:1px solid #b9ece8;box-shadow:none}.slot-cell.active{background:linear-gradient(135deg,var(--aqua-dark),var(--aqua));color:#fff;border-color:var(--aqua-dark)}.slot-cell[disabled]{opacity:.45;cursor:not-allowed;background:#f1f3f1}.empty-cell{display:block;color:#b1afa9}.selected-summary{padding:14px 16px;border-radius:18px;background:#fff8ee;border:1px solid var(--line);line-height:1.55;color:var(--green)}.result{margin-top:16px;padding:16px;border-radius:18px;display:none}.result.ok{display:block;background:#e4fbf2;border:1px solid #b9ecda}.result.err{display:block;background:#ffe9e4;border:1px solid #ffc2b8}.contacts{display:grid;grid-template-columns:1fr .8fr;gap:20px}.contact-panel strong{font-size:42px;color:var(--coral)}.footer{display:flex;justify-content:space-between;padding:30px 24px 44px;color:var(--muted)}
/* Admin */.shell{max-width:1180px;margin:0 auto;padding:28px}.badge{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:900;color:var(--green)}.muted{background:#fffaf2}.card.muted{margin-top:14px}.card b{color:var(--green)}
@media(max-width:900px){.landing-hero,.split,.contacts{grid-template-columns:1fr}.hero-media{min-height:auto}.hero-img.main{height:430px}.hero-img.floating{display:none}.cards-grid{grid-template-columns:1fr}.insta-grid{grid-template-columns:repeat(2,1fr)}.insta-grid img,.insta-grid img:nth-child(1),.insta-grid img:nth-child(6){grid-column:auto;height:210px}}
@media(max-width:700px){.topbar{position:static;align-items:flex-start}.topbar nav{justify-content:flex-end;gap:10px}.landing-hero{padding:34px 14px}.section{padding:38px 14px}.hero-copy h1{font-size:42px}.form-row{grid-template-columns:1fr}.slots-table th,.slots-table td{padding:6px 4px}.slots-table th:first-child{width:30%;font-size:13px}.slot-cell{font-size:13px;min-height:42px;padding:8px 4px}.shell{padding:14px}.card{padding:18px;border-radius:22px}}

/* Hero carousel update */
.hero-media.carousel{position:relative;min-height:560px;display:grid;place-items:center}
.carousel-frame{position:relative;width:100%;height:540px;border-radius:38px;overflow:hidden;box-shadow:var(--shadow);border:8px solid rgba(255,255,255,.84);background:linear-gradient(135deg,#c9f6f5,#f7f1e7)}
.carousel-frame:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,143,145,.08),rgba(0,0,0,.18));pointer-events:none}
.carousel-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;animation:heroCarousel 30s infinite;filter:saturate(1.08) contrast(1.02)}
.carousel-slide.s1{animation-delay:0s}.carousel-slide.s2{animation-delay:5s}.carousel-slide.s3{animation-delay:10s}.carousel-slide.s4{animation-delay:15s}.carousel-slide.s5{animation-delay:20s}.carousel-slide.s6{animation-delay:25s}
@keyframes heroCarousel{0%{opacity:0;transform:scale(1.04)}4%{opacity:1}16%{opacity:1}20%{opacity:0;transform:scale(1.11)}100%{opacity:0}}
.carousel-dots{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);display:flex;gap:8px;z-index:2;padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.48);backdrop-filter:blur(10px)}
.carousel-dots span{width:9px;height:9px;border-radius:999px;background:#fff;opacity:.82;box-shadow:0 2px 8px rgba(0,0,0,.18)}
@media(max-width:900px){.hero-media.carousel{min-height:auto}.carousel-frame{height:430px}}
@media(max-width:700px){.carousel-frame{height:360px;border-radius:28px;border-width:6px}.carousel-dots{bottom:14px}.footer{gap:12px;flex-direction:column}}

/* Mobile-first hero: show carousel + title immediately on phone */
.mobile-hero-title{display:none}
@media(max-width:700px){
  .landing-hero{display:flex;flex-direction:column;padding-top:12px;gap:18px}
  .hero-media.carousel{order:-1;width:100%}
  .carousel-frame{height:78vh;min-height:520px;max-height:680px}
  .carousel-frame:after{background:linear-gradient(180deg,rgba(0,50,65,.08) 0%,rgba(0,71,84,.2) 44%,rgba(0,0,0,.72) 100%)}
  .mobile-hero-title{display:block;position:absolute;left:18px;right:18px;bottom:58px;z-index:3;color:#fff;text-shadow:0 8px 28px rgba(0,0,0,.45)}
  .mobile-hero-title .eyebrow{color:#bffffd;margin-bottom:10px}
  .mobile-hero-title h1{margin:0;font-size:clamp(34px,10vw,48px);line-height:.95;letter-spacing:-.055em;color:#fff}
  .hero-copy h1,.hero-copy>.eyebrow{display:none}
  .hero-copy{width:100%}
  .lead{font-size:17px;margin-bottom:18px}
}

/* Booking polish */
.booking-card{overflow:hidden}
.booking-notice{display:none;margin-bottom:2px;padding:13px 15px;border-radius:16px;font-weight:850;line-height:1.45}
.booking-notice.err{display:block;background:#ffe9e4;border:1px solid #ffc2b8;color:#8c2f22}
.booking-notice.info{display:block;background:#e8faf8;border:1px solid #b9ece8;color:#07585a}
.date-row{grid-template-columns:minmax(0,1fr)}
.date-row label,input,select{min-width:0;max-width:100%}
.slots-table thead th:first-child{text-align:center}
.slots-table tbody th:first-child{text-align:left}
@media(max-width:700px){
  .booking-card{padding:18px;width:100%}
  input[type="date"],input[type="tel"],input[name="phone"]{width:100%;max-width:100%;font-size:16px}
  .date-row{display:block;width:100%}
}
@media(max-width:950px) and (orientation:landscape){
  .landing-hero{display:flex;flex-direction:column;gap:18px;padding-top:18px}
  .hero-copy{order:-2;width:100%}
  .hero-copy h1,.hero-copy>.eyebrow{display:block}
  .hero-media.carousel{order:-1;width:100%;min-height:auto}
  .carousel-frame{height:72vh;min-height:330px;max-height:520px}
  .mobile-hero-title{display:none}
}

/* Latest mobile-landscape and booking time alignment fixes */
.slots-table tbody th:first-child{text-align:center}
@media(max-width:950px) and (orientation:landscape){
  .landing-hero{display:flex;flex-direction:column;padding-top:12px;gap:16px}
  .hero-media.carousel{order:-1;width:100%;min-height:auto}
  .carousel-frame{height:76vh;min-height:360px;max-height:560px}
  .carousel-frame:after{background:linear-gradient(180deg,rgba(0,50,65,.08) 0%,rgba(0,71,84,.2) 44%,rgba(0,0,0,.72) 100%)}
  .mobile-hero-title{display:block;position:absolute;left:18px;right:18px;bottom:46px;z-index:3;color:#fff;text-shadow:0 8px 28px rgba(0,0,0,.45)}
  .mobile-hero-title .eyebrow{color:#bffffd;margin-bottom:8px}
  .mobile-hero-title h1{margin:0;font-size:clamp(30px,6vw,44px);line-height:.96;letter-spacing:-.05em;color:#fff}
  .hero-copy{width:100%}
  .hero-copy h1,.hero-copy>.eyebrow{display:none}
}

/* Landscape phone: carousel/title must be the very first visible block */
@media(max-width:950px) and (orientation:landscape){
  .topbar{display:none}
  .landing-hero{padding-top:0;margin-top:0}
  .hero-media.carousel{margin-top:0}
  .carousel-frame{border-radius:0 0 28px 28px;border-top:0}
}

/* Show booked future slots, but make them clearly unavailable */
.slot-cell.booked[disabled]{background:#eef3f3;color:#6f8381;border-color:#d7e3e1;opacity:1;text-decoration:none;cursor:not-allowed}
.slot-cell.unavailable[disabled]{background:#f5f0e9;color:#a09180;border-color:#e8dccb;opacity:1;cursor:not-allowed}

/* Smaller booking date picker */
.booking-card .date-row{max-width:280px;width:100%;grid-template-columns:1fr}
.booking-card .date-row input[type="date"]{height:44px;padding:9px 12px;border-radius:14px;font-size:15px}
@media(max-width:700px){
  .booking-card .date-row{max-width:220px;width:220px}
  .booking-card .date-row input[type="date"]{height:42px;padding:8px 10px;font-size:15px}
}

/* Admin auth */
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{width:min(440px,100%)}
.auth-card h1{font-size:clamp(38px,7vw,60px);line-height:1;margin:18px 0 8px;letter-spacing:-.05em}
.login-form{margin-top:18px}
.topbar .badge{padding:8px 12px;font-size:13px}
.topbar button.ghost{padding:8px 13px}
