@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Lora:ital,wght@0,400;0,600;1,400&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --green: #2e7d32; --green-dark: #1b5e20; --green-light: #4caf50; --green-pale: #e8f5e9;
  --orange: #f57c00; --orange-light: #ff9800;
  --white: #ffffff; --off-white: #f9f9f7; --grey-light: #f2f2f0; --grey: #e0e0dc;
  --text: #1f2d1f; --text-mid: #4a5a4a; --text-light: #7a8a7a;
  --font: 'Nunito', sans-serif; --accent: 'Lora', Georgia, serif;
  --radius: 12px; --shadow: 0 4px 20px rgba(0,0,0,.09); --shadow-h: 0 8px 32px rgba(0,0,0,.14);
}
html { scroll-behavior: smooth; }
body { font-family: var(--font); background: var(--off-white); color: var(--text); overflow-x: hidden; }

/* NAV */
nav { position: sticky; top:0; z-index:100; background:var(--white); border-bottom:3px solid var(--green); display:flex; align-items:center; justify-content:space-between; padding:0 2rem; height:64px; box-shadow:0 2px 12px rgba(0,0,0,.08); }
.nav-logo { display:flex; align-items:center; gap:.6rem; text-decoration:none; }
.nav-logo-icon { width:128px; height:128px; background:transparent; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.1rem; overflow:hidden; flex-shrink:0; } .nav-logo-icon img { width:100%; height:100%; object-fit:contain; }
.nav-logo-text { font-weight:900; font-size:1rem; color:var(--green-dark); line-height:1.1; }
.nav-logo-text span { display:block; font-weight:600; font-size:.67rem; color:var(--text-mid); letter-spacing:.04em; }
.nav-links { display:flex; align-items:center; gap:.15rem; list-style:none; }
.nav-links > li { position:relative; }
.nav-links a { font-size:.85rem; font-weight:700; color:var(--text-mid); text-decoration:none; padding:.45rem .8rem; border-radius:6px; transition:background .2s,color .2s; display:flex; align-items:center; gap:.3rem; }
.nav-links a:hover, .nav-links a.active { background:var(--green-pale); color:var(--green-dark); }
/* Dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown-toggle { cursor:pointer; }
.nav-dropdown-toggle::after { content:'▾'; font-size:.65rem; opacity:.6; }
.nav-dropdown-menu { display:none; position:absolute; top:100%; left:0; background:var(--white); border-radius:var(--radius); box-shadow:0 8px 32px rgba(0,0,0,.12); border:1px solid var(--grey); min-width:200px; overflow:hidden; z-index:200; padding-top:8px; }
.nav-dropdown-menu::before { content:''; position:absolute; top:-8px; left:0; right:0; height:8px; background:transparent; }
.nav-dropdown:hover .nav-dropdown-menu { display:block; }
.nav-dropdown-menu a { display:block; padding:.7rem 1.1rem; font-size:.83rem; font-weight:700; color:var(--text-mid); text-decoration:none; border-radius:0; transition:background .15s; }
.nav-dropdown-menu a:hover { background:var(--green-pale); color:var(--green-dark); }
.nav-dropdown-menu a .dm-icon { margin-right:.4rem; }
.nav-book-btn { font-size:.85rem; font-weight:800; color:var(--white); background:var(--orange); border:none; padding:.55rem 1.3rem; border-radius:8px; cursor:pointer; text-decoration:none; transition:background .2s,transform .15s; white-space:nowrap; }
.nav-book-btn:hover { background:var(--orange-light); transform:translateY(-1px); }
/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; }
.mobile-nav { display:none; position:fixed; inset:0; top:64px; z-index:99; background:var(--white); flex-direction:column; padding:1.5rem; gap:.4rem; border-top:1px solid var(--grey); overflow-y:auto; }
.mobile-nav.open { display:flex; }
.mobile-nav a { font-size:1rem; font-weight:700; color:var(--text); text-decoration:none; padding:.7rem 1rem; border-radius:8px; transition:background .2s; }
.mobile-nav a:hover { background:var(--green-pale); color:var(--green-dark); }
.mobile-nav .mn-sub { padding-left:2rem; font-size:.9rem; color:var(--text-mid); }
.mobile-nav .mn-label { font-size:.7rem; font-weight:900; text-transform:uppercase; letter-spacing:.08em; color:var(--text-light); padding:.5rem 1rem .2rem; }
.mobile-nav .mobile-book { margin-top:1rem; background:var(--orange); color:var(--white)!important; text-align:center; border-radius:8px; }

/* PAGE HERO (non-home pages) */
.page-hero { background:var(--green-dark); padding:3rem 2rem; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 80% 50%,rgba(76,175,80,.15),transparent 60%); }
.page-hero-inner { position:relative; max-width:1100px; margin:0 auto; }
.page-hero h1 { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:900; color:var(--white); line-height:1.1; margin-bottom:.5rem; }
.page-hero h1 em { font-family:var(--accent); font-style:italic; font-weight:400; color:#a5d6a7; }
.page-hero p { font-size:.95rem; color:rgba(255,255,255,.7); max-width:520px; line-height:1.7; }
.breadcrumb { display:flex; align-items:center; gap:.4rem; font-size:.72rem; font-weight:700; color:rgba(255,255,255,.5); margin-bottom:.75rem; }
.breadcrumb a { color:rgba(255,255,255,.5); text-decoration:none; transition:color .2s; }
.breadcrumb a:hover { color:rgba(255,255,255,.85); }
.breadcrumb span { color:rgba(255,255,255,.3); }

/* SHARED */
.section-wrap { max-width:1100px; margin:0 auto; padding:4rem 2rem; }
.section-header { margin-bottom:2.5rem; }
.tag-pill { display:inline-flex; align-items:center; gap:.3rem; background:var(--green-pale); color:var(--green-dark); font-size:.7rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; padding:.3rem .8rem; border-radius:100px; margin-bottom:.75rem; }
.section-title { font-weight:900; font-size:clamp(1.6rem,3.5vw,2.4rem); color:var(--text); line-height:1.15; margin-bottom:.6rem; }
.section-title em { font-family:var(--accent); font-style:italic; font-weight:400; color:var(--green); }
.section-subtitle { font-size:.95rem; color:var(--text-mid); line-height:1.7; max-width:560px; }

/* BUTTONS */
.btn-orange { font-size:.9rem; font-weight:800; color:var(--white); background:var(--orange); border:none; padding:.9rem 2rem; border-radius:10px; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:.4rem; transition:background .2s,transform .15s; }
.btn-orange:hover { background:var(--orange-light); transform:translateY(-2px); }
.btn-green { display:inline-flex; align-items:center; justify-content:center; font-family:var(--font); font-size:.85rem; font-weight:800; color:var(--white); background:var(--green); border:none; padding:.7rem 1.4rem; border-radius:8px; cursor:pointer; text-decoration:none; transition:background .2s; }
.btn-green:hover { background:var(--green-dark); }
.btn-white-ghost { font-size:.9rem; font-weight:700; color:var(--white); background:rgba(255,255,255,.12); border:2px solid rgba(255,255,255,.55); padding:.9rem 1.8rem; border-radius:10px; text-decoration:none; transition:background .2s; }
.btn-white-ghost:hover { background:rgba(255,255,255,.22); }

/* SERVICES */
.services-section-label { font-size:1rem; font-weight:900; color:var(--text); margin-bottom:1.25rem; padding:.6rem 1.1rem; background:var(--green-pale); border-left:4px solid var(--green); border-radius:0 8px 8px 0; display:inline-block; }
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.25rem; }
.service-card { background:var(--white); border-radius:var(--radius); padding:1.75rem; box-shadow:var(--shadow); border:2px solid transparent; transition:border-color .25s,box-shadow .25s,transform .2s; display:flex; flex-direction:column; }
.service-card:hover { border-color:var(--green-light); box-shadow:var(--shadow-h); transform:translateY(-3px); }
.service-emoji { font-size:2.2rem; margin-bottom:.8rem; display:block; }
.service-card h3 { font-size:1.05rem; font-weight:800; color:var(--text); margin-bottom:.5rem; }
.service-card p { font-size:.85rem; line-height:1.7; color:var(--text-mid); margin-bottom:1rem; }
.service-prices { display:flex; flex-direction:column; gap:.3rem; margin-top:auto; padding-top:1rem; border-top:1px solid var(--grey); }
.service-price-item { font-size:.85rem; color:var(--text-mid); }
.service-price-item strong { color:var(--green-dark); font-weight:800; }
.service-cta { margin-top:1rem; }

/* CONTACT */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; }
.ci-items { display:flex; flex-direction:column; gap:1rem; margin-top:1.5rem; }
.ci-item { display:flex; align-items:flex-start; gap:1rem; padding:1.25rem; background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); }
.ci-icon { font-size:1.4rem; flex-shrink:0; }
.ci-label { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-light); margin-bottom:.2rem; }
.ci-value { font-size:.92rem; font-weight:700; color:var(--text); }
.msg-form { background:var(--white); border-radius:var(--radius); padding:2rem; box-shadow:var(--shadow); }
.msg-form h3 { font-size:1.05rem; font-weight:900; color:var(--text); margin-bottom:.3rem; }
.msg-form > p { font-size:.85rem; color:var(--text-mid); margin-bottom:1.5rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.fg { display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.fg label { font-size:.72rem; font-weight:700; color:var(--text-mid); text-transform:uppercase; letter-spacing:.05em; }
.fg input, .fg select, .fg textarea { background:var(--off-white); border:1.5px solid var(--grey); color:var(--text); border-radius:8px; padding:.75rem 1rem; font-family:var(--font); font-size:.88rem; outline:none; width:100%; transition:border-color .2s; }
.fg input:focus, .fg select:focus, .fg textarea:focus { border-color:var(--green); }
.fg textarea { resize:vertical; min-height:110px; }
.btn-send { font-family:var(--font); font-size:.9rem; font-weight:800; color:var(--white); background:var(--green); border:none; padding:.85rem; border-radius:8px; cursor:pointer; width:100%; transition:background .2s; }
.btn-send:hover { background:var(--green-dark); }

/* FOOTER */
footer { background:var(--green-dark); color:rgba(255,255,255,.7); padding:2rem; }
.footer-inner { max-width:1100px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer-logo { font-weight:900; color:var(--white); font-size:1rem; }
.footer-links { display:flex; gap:1.5rem; list-style:none; flex-wrap:wrap; }
.footer-links a { font-size:.78rem; font-weight:600; color:rgba(255,255,255,.5); text-decoration:none; transition:color .2s; }
.footer-links a:hover { color:#a5d6a7; }
.footer-copy { font-size:.72rem; color:rgba(255,255,255,.3); }

/* BOOKING SYSTEM */
.bk-wrap { background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }
.bk-top-bar { display:flex; align-items:center; justify-content:space-between; padding:1rem 1.5rem; background:var(--green-pale); border-bottom:1px solid var(--grey); flex-wrap:wrap; gap:.75rem; }
.bk-mode-toggle { display:flex; background:var(--white); border-radius:8px; overflow:hidden; border:1.5px solid var(--grey); }
.bk-toggle-btn { font-family:var(--font); font-size:.8rem; font-weight:700; padding:.45rem 1rem; border:none; background:none; cursor:pointer; color:var(--text-mid); transition:background .2s,color .2s; }
.bk-toggle-btn.active { background:var(--green); color:var(--white); }
.bk-admin-badge { font-size:.72rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--green-dark); background:rgba(46,125,50,.12); padding:.3rem .8rem; border-radius:100px; border:1px solid rgba(46,125,50,.25); }
.bk-week-nav { display:flex; align-items:center; justify-content:space-between; padding:.9rem 1.5rem; border-bottom:1px solid var(--grey); }
.bk-nav-btn { font-size:1.5rem; font-weight:700; background:none; border:1.5px solid var(--grey); border-radius:8px; width:36px; height:36px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--text-mid); transition:background .2s,border-color .2s; line-height:1; }
.bk-nav-btn:hover { background:var(--green-pale); border-color:var(--green); color:var(--green-dark); }
.bk-week-label { font-size:.9rem; font-weight:700; color:var(--text); display:flex; align-items:center; gap:.6rem; }
.bk-this-week { font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; background:var(--green); color:var(--white); padding:.15rem .6rem; border-radius:100px; }
.bk-grid-outer { overflow-x:auto; padding:1rem; }
.bk-grid { display:grid; grid-template-columns:60px repeat(7,minmax(90px,1fr)); gap:4px; min-width:700px; }
.bk-cell { display:flex; align-items:center; justify-content:center; }
.bk-day-header { flex-direction:column; gap:2px; padding:.6rem .25rem; background:var(--green-pale); border-radius:8px; }
.bk-day-name { font-size:.75rem; font-weight:900; color:var(--green-dark); text-transform:uppercase; letter-spacing:.04em; }
.bk-day-date { font-size:.7rem; font-weight:600; color:var(--text-mid); }
.bk-hour-label { font-size:.72rem; font-weight:700; color:var(--text-light); justify-content:flex-end; padding-right:8px; height:44px; }
.bk-slot { height:44px; border-radius:6px; border:1.5px solid transparent; transition:transform .1s,box-shadow .15s; position:relative; gap:4px; font-size:.72rem; font-weight:700; }
.bk-slot-avail { background:var(--green-pale); border-color:var(--green-light); color:var(--green-dark); cursor:pointer; }
.bk-slot-avail:hover { background:#c8e6c9; border-color:var(--green); transform:scale(1.03); box-shadow:0 2px 8px rgba(46,125,50,.2); }
.bk-slot-unavail { background:var(--grey-light); border-color:var(--grey); color:transparent; cursor:default; }
.bk-slot-unavail.bk-slot-past { opacity:.4; }
.bk-slot-booked { background:#fff3e0; border-color:#ffb74d; color:var(--text-mid); cursor:pointer; display:flex; align-items:center; justify-content:space-between; padding:0 8px; }
.bk-slot-booked:hover { box-shadow:0 2px 8px rgba(0,0,0,.12); }
.bk-slot-check { font-size:.85rem; }
.bk-slot-name { font-size:.65rem; font-weight:700; color:var(--text-mid); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:70%; }
.bk-slot-cancel { font-size:.7rem; font-weight:900; color:#e53935; cursor:pointer; padding:2px 4px; border-radius:4px; flex-shrink:0; }
.bk-slot-cancel:hover { background:#ffebee; }
.bk-legend { display:flex; align-items:center; justify-content:center; gap:1.5rem; padding:1rem; border-top:1px solid var(--grey); flex-wrap:wrap; }
.bk-legend-item { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:var(--text-mid); font-weight:600; }
.bk-legend-dot { width:16px; height:16px; border-radius:4px; border:1.5px solid transparent; flex-shrink:0; }
.bk-modal { position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:500; display:none; align-items:center; justify-content:center; padding:1rem; }
.bk-modal.open { display:flex; }
.bk-modal-box { background:var(--white); border-radius:16px; padding:2rem; max-width:480px; width:100%; position:relative; box-shadow:0 20px 60px rgba(0,0,0,.2); max-height:90vh; overflow-y:auto; }
.bk-modal-close { position:absolute; top:1rem; right:1rem; background:var(--grey-light); border:none; border-radius:50%; width:32px; height:32px; font-size:.9rem; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-mid); }
.bk-modal-close:hover { background:var(--grey); }
.bk-modal-title { font-size:1.1rem; font-weight:900; color:var(--text); margin-bottom:.25rem; }
.bk-modal-subtitle { font-size:.85rem; color:var(--green-dark); font-weight:700; margin-bottom:1.5rem; }
.bk-confirm-btn { font-family:var(--font); font-size:.9rem; font-weight:800; color:var(--white); background:var(--green); border:none; border-radius:10px; padding:.9rem; cursor:pointer; width:100%; margin-top:.5rem; transition:background .2s; }
.bk-confirm-btn:hover { background:var(--green-dark); }
.bk-cancel-btn { font-family:var(--font); font-size:.85rem; font-weight:700; color:#c62828; background:#ffebee; border:1.5px solid #ef9a9a; border-radius:10px; padding:.75rem; cursor:pointer; width:100%; margin-top:1rem; transition:background .2s; }
.bk-cancel-btn:hover { background:#ffcdd2; }
.bk-detail-content { display:flex; flex-direction:column; gap:.75rem; margin:1.25rem 0; }
.bk-detail-row { display:flex; justify-content:space-between; align-items:center; padding:.65rem .9rem; background:var(--off-white); border-radius:8px; font-size:.88rem; }
.bk-detail-label { font-weight:700; color:var(--text-mid); font-size:.75rem; text-transform:uppercase; letter-spacing:.04em; }
.bk-toast { position:fixed; bottom:2rem; left:50%; transform:translateX(-50%); background:var(--green-dark); color:var(--white); font-family:var(--font); font-size:.9rem; font-weight:700; padding:.75rem 1.75rem; border-radius:100px; box-shadow:0 4px 20px rgba(0,0,0,.2); z-index:999; animation:toastIn .3s ease; }
@keyframes toastIn { from{opacity:0;transform:translateX(-50%) translateY(10px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }

/* RESPONSIVE */
@media(max-width:860px){
  nav { padding:0 1rem; }
  .nav-links, .nav-book-btn { display:none; }
  .hamburger { display:flex; }
  .section-wrap { padding:3rem 1.25rem; }
  .contact-grid, .form-row { grid-template-columns:1fr; }
  .footer-inner { flex-direction:column; align-items:flex-start; }
}

/* ── BOOKING WIDGET ─────────────────────────────────────────────────────── */
.bkw-wrap { display:flex; flex-direction:column; gap:1rem; }

.bkw-row { display:flex; flex-direction:column; gap:.5rem; background:var(--white); border-radius:var(--radius); padding:1.25rem 1.5rem; box-shadow:var(--shadow); }

.bkw-label { display:flex; align-items:center; gap:.6rem; font-size:.8rem; font-weight:800; color:var(--text-mid); text-transform:uppercase; letter-spacing:.06em; }

.bkw-step-num { display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; border-radius:50%; font-size:.72rem; font-weight:900; flex-shrink:0; background:var(--grey); color:var(--text-mid); transition:background .2s,color .2s; }
.bkw-step-num.active { background:var(--green-dark); color:#fff; }
.bkw-step-num.done { background:var(--green); color:#fff; }

.bkw-select { background:var(--off-white); border:1.5px solid var(--grey); border-radius:8px; padding:.75rem 1rem; font-family:var(--font); font-size:.92rem; font-weight:600; color:var(--text); outline:none; cursor:pointer; transition:border-color .2s; width:100%; }
.bkw-select:focus { border-color:var(--green); }

/* Step 4 form */
.bkw-form-box { background:var(--green-dark); border-radius:var(--radius); padding:2rem; }
.bkw-form-title { font-size:1.1rem; font-weight:900; color:#fff; margin-bottom:.4rem; }
.bkw-summary { font-size:.83rem; color:rgba(255,255,255,.65); margin-bottom:1.5rem; line-height:1.5; }
.bkw-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.bkw-fg { display:flex; flex-direction:column; gap:.4rem; margin-bottom:.9rem; }
.bkw-fg label { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.05em; }
.bkw-fg input { background:rgba(255,255,255,.08); border:1.5px solid rgba(255,255,255,.2); border-radius:8px; padding:.7rem 1rem; font-family:var(--font); font-size:.88rem; color:#fff; outline:none; width:100%; transition:border-color .2s; }
.bkw-fg input::placeholder { color:rgba(255,255,255,.3); }
.bkw-fg input:focus { border-color:var(--green-light); background:rgba(255,255,255,.12); }
.bkw-confirm-btn { font-family:var(--font); font-size:.92rem; font-weight:800; color:#fff; background:var(--orange); border:none; border-radius:10px; padding:.9rem; cursor:pointer; width:100%; margin-top:.25rem; transition:background .2s; }
.bkw-confirm-btn:hover { background:var(--orange-light); }

/* Toast */
.bkw-toast { position:fixed; bottom:2rem; left:50%; transform:translateX(-50%); background:var(--green-dark); color:#fff; font-family:var(--font); font-size:.9rem; font-weight:700; padding:.75rem 1.75rem; border-radius:100px; box-shadow:0 4px 20px rgba(0,0,0,.2); z-index:999; animation:bkwToastIn .3s ease; white-space:nowrap; }
@keyframes bkwToastIn { from{opacity:0;transform:translateX(-50%) translateY(10px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }

@media(max-width:600px){ .bkw-form-row{grid-template-columns:1fr;} }
