:root{
  --sage:#b8cbb8;
  --sage-2:#dfe8dd;
  --sage-3:#edf4ea;
  --cream:#fbf8f0;
  --sand:#e8ddcc;
  --clay:#b68b73;
  --ink:#1d2822;
  --muted:#647067;
  --white:#ffffff;
  --line:rgba(29,40,34,.12);
  --shadow:0 22px 70px rgba(29,40,34,.12);
  --shadow-soft:0 14px 42px rgba(29,40,34,.09);
  --radius:14px;
  --radius-small:9px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,var(--cream),#fff 42%,var(--sage-3));
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}

.container{width:min(var(--container),calc(100% - 40px));margin:0 auto}
.section{padding:86px 0}
.section.compact{padding:56px 0}
.eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);font-weight:800;margin:0 0 12px}
h1,h2,h3{line-height:1.08;margin:0;color:var(--ink)}
h1{font-size:clamp(2.7rem,7vw,6.2rem);letter-spacing:-.07em}
h2{font-size:clamp(2rem,4vw,3.7rem);letter-spacing:-.045em}
h3{font-size:clamp(1.25rem,2vw,1.75rem);letter-spacing:-.025em}
p{margin:0;color:var(--muted)}
.lead{font-size:clamp(1.08rem,2vw,1.32rem);max-width:760px;color:#405045}
.small{font-size:.92rem;color:var(--muted)}
strong{color:var(--ink)}

.btn,
button.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:46px;padding:12px 20px;border-radius:var(--radius-small);
  border:1px solid rgba(29,40,34,.16);background:var(--ink);color:#fff;
  font-weight:800;cursor:pointer;transition:.22s ease;box-shadow:0 12px 30px rgba(29,40,34,.12)
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(29,40,34,.18)}
.btn.light{background:#fff;color:var(--ink)}
.btn.ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.38);box-shadow:none;backdrop-filter:blur(8px)}
.btn.sage{background:var(--sage);color:#172219}
.btn.full{width:100%}
.btn.danger{background:#fff5f3;color:#8b2e1d;border-color:#e3b9ac}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}

.gateway-body{height:100svh;overflow:hidden;background:#111}
.gateway{
  min-height:100svh;position:relative;display:grid;place-items:center;padding:28px;isolation:isolate;text-align:center;color:#fff;
  background-image:linear-gradient(120deg,rgba(12,18,14,.55),rgba(12,18,14,.34)),url('../images/main/soulution-main-background.webp');
  background-size:cover;background-position:center;
}
.gateway::before{content:"";position:absolute;inset:0;backdrop-filter:blur(4px);z-index:-1;background:rgba(0,0,0,.08)}
.gateway-card{width:min(840px,100%);padding:42px 24px;animation:fadeUp .9s ease both}
.gateway-logo{width:min(260px,52vw);margin:0 auto 34px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.22))}
.gateway h1{font-size:clamp(2.2rem,5vw,4.6rem);letter-spacing:-.045em;color:#fff;margin-bottom:18px}
.gateway h1 strong{color:#fff;font-weight:950}
.gateway p{color:rgba(255,255,255,.86);font-size:clamp(1.05rem,2vw,1.35rem);margin:8px auto;max-width:710px}
.gateway-actions{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.gateway-actions .btn{min-width:210px;background:rgba(255,255,255,.92);color:var(--ink);border-color:rgba(255,255,255,.45)}
.gateway-actions .btn:nth-child(2){background:rgba(184,203,184,.92)}
.gateway-footer,.floating-footer{
  position:fixed;right:18px;bottom:14px;z-index:20;display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end;
  font-size:.82rem;color:rgba(255,255,255,.74)
}
.gateway-footer a,.floating-footer a{text-decoration:underline;text-underline-offset:4px}
.floating-footer{color:rgba(29,40,34,.62);background:rgba(255,255,255,.72);backdrop-filter:blur(12px);padding:8px 10px;border:1px solid rgba(29,40,34,.08);border-radius:10px}
.loading-screen{position:fixed;inset:0;background:rgba(251,248,240,.92);backdrop-filter:blur(18px);z-index:100;display:grid;place-items:center;opacity:0;pointer-events:none;transition:.18s ease}
.loading-screen.active{opacity:1;pointer-events:auto}
.loading-box{text-align:center;color:var(--ink)}
.loader-orbit{width:78px;height:78px;border:1px solid rgba(29,40,34,.15);border-radius:50%;margin:0 auto 20px;position:relative;animation:breath 1.8s ease-in-out infinite}
.loader-orbit::before,.loader-orbit::after{content:"";position:absolute;width:13px;height:13px;border-radius:50%;background:var(--sage);top:-6px;left:50%;transform:translateX(-50%);box-shadow:0 0 32px rgba(184,203,184,.9)}
.loader-orbit::after{top:auto;bottom:-6px;background:var(--clay)}
.loading-box strong{font-size:1.35rem}

.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);width:100%;backdrop-filter:blur(16px)}
.navbar{height:78px;display:flex;align-items:center;justify-content:space-between;gap:22px;width:min(100% - 40px,1280px);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:-.02em;white-space:nowrap}
.brand img{width:42px;height:42px;object-fit:contain}
.brand span{font-size:1.02rem}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-link{position:relative;font-size:.95rem;font-weight:750;color:#253229;padding:26px 0 21px}
.nav-link::after{content:"";position:absolute;left:50%;bottom:11px;height:4px;width:0;background:var(--sage);border-radius:999px;transition:.28s ease;transform:translateX(-50%)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-toggle{display:none;width:46px;height:46px;border:0;background:#fff;border-radius:10px;position:relative;cursor:pointer}
.nav-toggle span{position:absolute;left:12px;right:12px;height:2px;background:var(--ink);transition:.25s ease}
.nav-toggle span:nth-child(1){top:15px}.nav-toggle span:nth-child(2){top:22px}.nav-toggle span:nth-child(3){top:29px}
.nav-toggle.open span:nth-child(1){top:22px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:22px;transform:rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:rgba(255,255,255,.76);backdrop-filter:blur(22px);z-index:45;display:none;padding:110px 34px 34px}
.mobile-menu.open{display:block;animation:fade .2s ease both}
.mobile-menu .nav-links{display:flex;flex-direction:column;align-items:flex-start;gap:12px}
.mobile-menu .nav-link{font-size:1.55rem;padding:10px 0 14px}
.mobile-menu .nav-link::after{bottom:5px;height:5px}

.hero-page{min-height:680px;display:flex;align-items:flex-end;position:relative;isolation:isolate;background:#0e1711;color:#fff;overflow:hidden}
.hero-page::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,18,13,.74),rgba(10,18,13,.22) 42%,rgba(10,18,13,.50));z-index:-1}
.hero-page::after{content:"";position:absolute;inset:0;background-image:var(--hero);background-size:cover;background-position:center;z-index:-2;transform:scale(1.02)}
.hero-page.business-hero::before{background:linear-gradient(90deg,rgba(10,18,13,.78),rgba(10,18,13,.08) 44%,rgba(10,18,13,.48))}
.hero-content{padding:126px 0 78px;width:100%}
.hero-panel{max-width:590px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(14px);padding:28px;border-radius:var(--radius);box-shadow:0 30px 70px rgba(0,0,0,.18)}
.business-hero .hero-panel{margin-left:0;margin-right:auto;transform:translateY(16px)}
.hero-panel h1{color:#fff;font-size:clamp(2.6rem,5vw,5.5rem)}
.hero-panel p{color:rgba(255,255,255,.88);font-size:1.08rem;margin-top:16px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}

.grid{display:grid;gap:22px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);overflow:hidden}
.card.pad{padding:26px}
.card h3{margin-bottom:12px}
.card p + p{margin-top:12px}
.card-image{aspect-ratio:16/10;object-fit:cover;width:100%}
.card-meta{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 0}
.badge{display:inline-flex;align-items:center;gap:6px;background:var(--sage-3);border:1px solid rgba(184,203,184,.7);padding:6px 10px;border-radius:999px;font-size:.82rem;font-weight:800;color:#405045}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.split.reverse{grid-template-columns:.95fr 1.05fr}
.photo-stack{position:relative;min-height:440px}
.photo-stack img{position:absolute;border-radius:var(--radius);box-shadow:var(--shadow);object-fit:cover}
.photo-stack img:first-child{width:78%;height:330px;left:0;top:0}
.photo-stack img:last-child{width:58%;height:260px;right:0;bottom:0;border:8px solid var(--cream)}
.soft-panel{background:linear-gradient(135deg,#fff,var(--sage-3));border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-soft)}
.quote-panel{padding:34px;background:#fff;border-left:6px solid var(--sage);box-shadow:var(--shadow-soft);border-radius:0 var(--radius) var(--radius) 0}
.quote-panel p{font-size:1.28rem;color:#2e3a32;font-weight:700;line-height:1.42}

.team-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:32px}
.team-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft)}
.team-card img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center top}
.team-card .content{padding:22px}
.team-card .role{font-size:.9rem;font-weight:800;color:var(--clay);margin:6px 0 12px}

.placeholder-card{background:linear-gradient(135deg,var(--sage-3),#fff 52%,#f4e9dc);border:1px dashed rgba(29,40,34,.18);border-radius:var(--radius);padding:28px;min-height:210px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-soft)}
.placeholder-mark{width:54px;height:54px;border-radius:12px;background:rgba(184,203,184,.55);display:grid;place-items:center;font-weight:900;color:#435347;margin-bottom:22px}

.shop-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;align-items:start}
.books-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.book-card{display:grid;grid-template-columns:112px 1fr;gap:16px;padding:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft)}
.book-card img{width:112px;aspect-ratio:2/3;object-fit:cover;border-radius:8px;box-shadow:0 12px 25px rgba(29,40,34,.12)}
.price-row{display:flex;align-items:baseline;gap:8px;margin:10px 0 14px;flex-wrap:wrap}
.old-price{text-decoration:line-through;color:#899189;font-size:.9rem}
.new-price{font-weight:950;color:var(--ink);font-size:1.12rem}
.cart-box{position:sticky;top:102px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.cart-items{display:grid;gap:12px;margin:16px 0;max-height:270px;overflow:auto}
.cart-item{display:grid;grid-template-columns:1fr auto;gap:10px;padding:10px;background:var(--sage-3);border-radius:10px}
.qty-control{display:flex;align-items:center;gap:8px}
.qty-control button{width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:900}
.cart-total{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:14px;margin-top:12px;font-weight:950}
.form-panel{margin-top:24px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-soft)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid .full{grid-column:1/-1}
.field{display:grid;gap:7px}
.field label{font-size:.86rem;font-weight:850;color:#334139}
.field input,.field textarea,.field select{width:100%;border:1px solid rgba(29,40,34,.18);border-radius:9px;padding:12px 13px;background:#fff;color:var(--ink);outline:none;transition:.2s ease}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--sage);box-shadow:0 0 0 4px rgba(184,203,184,.25)}
.field textarea{min-height:112px;resize:vertical}
.radio-row,.check-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.segmented{display:flex;background:var(--sage-3);padding:5px;border-radius:10px;border:1px solid var(--line);width:max-content;max-width:100%;margin:18px 0}
.segmented button{border:0;background:transparent;padding:10px 14px;border-radius:8px;cursor:pointer;font-weight:850;color:var(--muted)}
.segmented button.active{background:#fff;color:var(--ink);box-shadow:0 8px 20px rgba(29,40,34,.08)}
.hidden{display:none!important}
.notice{background:#fff8e8;border:1px solid #ead7a8;color:#6a5425;padding:12px 14px;border-radius:10px;font-size:.92rem}
.success{background:#eef7ee;border:1px solid #c8dfc8;color:#2e6132;padding:12px 14px;border-radius:10px;font-size:.92rem}
.error{background:#fff0ee;border:1px solid #f0c2b9;color:#8b2e1d;padding:12px 14px;border-radius:10px;font-size:.92rem}

.booking-layout{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}
.slots{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}
.slot{border:1px solid var(--line);background:#fff;border-radius:9px;padding:10px;cursor:pointer;font-weight:850;text-align:center;transition:.2s ease}
.slot:hover,.slot.active{background:var(--sage);color:#142017;transform:translateY(-1px)}
.slot.disabled{opacity:.35;cursor:not-allowed;transform:none;background:#f4f4f0}

.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:stretch}
.map-frame{width:100%;min-height:380px;border:0;border-radius:var(--radius);box-shadow:var(--shadow-soft)}
.contact-list{display:grid;gap:14px;margin-top:20px}
.contact-item{padding:16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-small)}
.facebook-link{display:inline-flex;align-items:center;gap:10px;margin-top:18px;font-weight:900;color:#274c79}
.facebook-icon{width:34px;height:34px;border-radius:9px;background:#1877f2;color:#fff;display:grid;place-items:center;font-weight:950}

.admin-body{background:linear-gradient(135deg,#f7f3e9,#eef5eb)}
.admin-shell{min-height:100svh;display:grid;grid-template-columns:290px 1fr}
.admin-sidebar{background:#fff;border-right:1px solid var(--line);padding:24px;position:sticky;top:0;height:100svh;overflow:auto}
.admin-main{padding:32px;min-width:0}
.admin-brand{display:flex;align-items:center;gap:12px;font-weight:950;margin-bottom:28px}
.admin-brand img{width:42px}
.admin-nav{display:grid;gap:8px}
.admin-nav button{border:0;text-align:left;background:transparent;padding:12px 14px;border-radius:9px;cursor:pointer;font-weight:850;color:var(--muted)}
.admin-nav button.active,.admin-nav button:hover{background:var(--sage-3);color:var(--ink)}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px;margin-bottom:20px}
.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden}
.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--line);padding:13px;vertical-align:top;font-size:.92rem}
.admin-table th{background:var(--sage-3);font-weight:950;color:#38473d}
.status-pill{display:inline-flex;padding:5px 9px;border-radius:999px;background:var(--sage-3);font-weight:900;font-size:.78rem}
.admin-login{min-height:100svh;display:grid;place-items:center;padding:24px}
.admin-login-card{width:min(440px,100%);background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.save-modal{position:fixed;inset:0;background:rgba(255,255,255,.72);backdrop-filter:blur(18px);z-index:200;display:none;place-items:center;padding:24px}
.save-modal.open{display:grid;animation:fade .2s ease both}
.save-box{width:min(520px,100%);background:rgba(255,255,255,.9);border:1px solid rgba(29,40,34,.12);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.save-options{display:grid;gap:10px;margin:18px 0}
.save-options label{display:flex;align-items:center;gap:10px;background:var(--sage-3);padding:12px;border-radius:10px;font-weight:850}

.legal-page{padding:80px 0}
.legal-page .container{max-width:900px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-soft)}
.legal-page h1{font-size:clamp(2rem,4vw,3.4rem);margin-bottom:18px}
.legal-page h2{font-size:1.45rem;margin:28px 0 10px}
.legal-page ul{color:var(--muted)}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes breath{0%,100%{transform:scale(1);opacity:.9}50%{transform:scale(1.08);opacity:1}}

@media (max-width:980px){
  .nav-links{display:none}.nav-toggle{display:block}.navbar{height:72px}
  .hero-page{min-height:620px}.hero-panel{max-width:100%}
  .grid.three,.grid.four,.team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split,.split.reverse,.shop-layout,.booking-layout,.contact-grid{grid-template-columns:1fr}
  .cart-box{position:relative;top:auto}
  .books-grid{grid-template-columns:1fr}
  .admin-shell{grid-template-columns:1fr}.admin-sidebar{position:relative;height:auto}.admin-main{padding:20px}.admin-nav{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:640px){
  .container{width:min(100% - 28px,var(--container))}.section{padding:62px 0}.section.compact{padding:42px 0}
  .gateway-actions{flex-direction:column}.gateway-actions .btn{width:100%}
  .gateway-footer,.floating-footer{position:static;margin:20px auto 0;width:min(100% - 28px,420px);justify-content:center;text-align:center}
  .gateway-body{height:auto;overflow:auto}.gateway{min-height:100svh}
  .grid.two,.grid.three,.grid.four,.team-grid,.form-grid{grid-template-columns:1fr}
  .book-card{grid-template-columns:92px 1fr}.book-card img{width:92px}
  .slots{grid-template-columns:repeat(2,minmax(0,1fr))}
  .photo-stack{min-height:360px}.photo-stack img:first-child{height:260px}.photo-stack img:last-child{height:210px}
  .admin-nav{grid-template-columns:1fr}.admin-main{padding:16px}.admin-table{display:block;overflow:auto}
}

:root{--container:1380px;--container-readable:1180px;--pastel-line:#b8cbb8;--mist:rgba(255,255,255,.82)}
body{overflow-x:hidden}.container{width:min(var(--container),calc(100% - 48px))}.section{position:relative}.section::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none}.section.alt::before{background:linear-gradient(135deg,rgba(223,232,221,.42),rgba(255,255,255,.2))}.section.wide-soft{background:linear-gradient(135deg,rgba(255,255,255,.68),rgba(223,232,221,.34))}.readable{max-width:var(--container-readable)}

.gateway-actions .btn,.gateway-actions .btn:nth-child(2){background:rgba(255,255,255,.93);color:var(--ink);border-color:rgba(255,255,255,.55)}
.gateway-actions .btn:hover{background:#fff}.loader-orbit{animation:none;border-color:rgba(29,40,34,.18)}.loader-orbit::before,.loader-orbit::after{top:50%;left:50%;bottom:auto;width:12px;height:12px;margin:-6px 0 0 -6px;transform:none;box-shadow:0 0 28px rgba(184,203,184,.95)}.loader-orbit::before{animation:orbitA .5s linear infinite}.loader-orbit::after{background:var(--clay);animation:orbitB .5s linear infinite}.loading-box strong::after{content:"…";letter-spacing:.08em}
@keyframes orbitA{from{transform:rotate(0deg) translateX(39px) rotate(0deg)}to{transform:rotate(360deg) translateX(39px) rotate(-360deg)}}
@keyframes orbitB{from{transform:rotate(180deg) translateX(39px) rotate(-180deg)}to{transform:rotate(540deg) translateX(39px) rotate(-540deg)}}

.site-header{background:rgba(255,255,255,.96)}.navbar{width:calc(100% - 48px);max-width:none;margin:0 auto}.nav-links{margin-left:auto}.brand{flex:0 0 auto}.brand img{width:46px;height:46px}.brand span{font-size:1.08rem}.nav-link{padding-left:2px;padding-right:2px}.mobile-menu{background:rgba(255,255,255,.78);text-align:center}.mobile-menu .nav-links{align-items:center;justify-content:center;min-height:calc(100svh - 160px);margin:0}.mobile-menu .nav-link{text-align:center;font-size:clamp(1.45rem,8vw,2.5rem)}

.hero-page{background:#132017}.hero-page::after{display:none}.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:-2;transform:scale(1.02);filter:saturate(.92)}.business-hero .hero-bg-img{object-position:center}.hero-content{position:relative;z-index:1}.hero-panel{animation:fadeUp .9s ease both}.business-hero .hero-panel{max-width:560px;margin-left:0;margin-right:auto}.hero-panel .eyebrow{color:#e6d8c2}.hero-actions{align-items:center}.section-band{border-top:1px solid rgba(29,40,34,.08);border-bottom:1px solid rgba(29,40,34,.08)}

.grid.three{gap:24px}.card,.soft-panel,.placeholder-card,.form-panel,.cart-box,.admin-card{transition:transform .25s ease,box-shadow .25s ease}.card:hover,.soft-panel:hover,.placeholder-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.card.pad{height:100%}.card-image{width:100%;height:260px;object-fit:cover}.image-card{overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-soft);border:1px solid var(--line);background:#fff}.image-card img{width:100%;height:100%;min-height:260px;object-fit:cover}.image-card.double{display:grid;grid-template-columns:1fr 1fr;gap:0}.image-card.double img{height:100%;min-height:420px}.crosslink-section{padding:42px 0}.crosslink-card{display:flex;align-items:center;justify-content:space-between;gap:24px;background:linear-gradient(135deg,#fff,var(--sage-3));border:1px solid var(--line);box-shadow:var(--shadow-soft);border-radius:var(--radius);padding:28px}.crosslink-card p{max-width:820px}.section-title-row{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:30px}.section-title-row .lead{margin-top:10px}

.team-card{display:flex;flex-direction:column}.team-card img{aspect-ratio:4/5;object-fit:cover;object-position:center 16%;background:var(--sage-3)}.team-card.team-biro-zoltan img{object-position:center 12%}.team-card.team-papp-levente img{object-position:center 8%}.team-card.team-csirke-beata img{object-position:center 6%}.team-card.team-barics-arnold img{object-position:center 8%}.team-card.team-brands-sagodi-lilla img{object-position:center 14%}.team-note{margin-top:22px;background:#fff;border:1px solid var(--line);border-left:5px solid var(--sage);border-radius:0 var(--radius-small) var(--radius-small) 0;padding:18px 20px;box-shadow:var(--shadow-soft)}

.buyer-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:18px 0 22px;max-width:560px;background:transparent;border:0;padding:0;width:100%}.buyer-switch button{background:#fff;border:1px solid rgba(29,40,34,.16);box-shadow:var(--shadow-soft);padding:13px 16px;border-radius:var(--radius-small);font-weight:900;cursor:pointer;color:var(--muted);transition:.22s ease}.buyer-switch button.active,.buyer-switch button:hover{background:var(--sage-3);color:var(--ink);border-color:rgba(184,203,184,.9);transform:translateY(-1px)}.check-row{display:flex!important;flex-direction:row!important;align-items:flex-start;gap:10px;flex-wrap:nowrap}.check-row input[type="checkbox"]{width:18px;height:18px;margin:3px 0 0;flex:0 0 18px}.check-row label{line-height:1.4}.privacy-check a{text-decoration:underline;text-underline-offset:3px;color:var(--ink);font-weight:900}

.contact-section-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;align-items:start}.contact-media{display:grid;gap:16px}.contact-media img{width:100%;height:250px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-soft);border:1px solid var(--line)}.contact-media img:first-child{height:330px}.contact-media .map-frame{min-height:320px}.contact-grid.enhanced{grid-template-columns:1fr;gap:20px}.facebook-link{color:#23362b}.facebook-icon{background:#fff;color:#1877f2;border:1px solid rgba(24,119,242,.22);box-shadow:0 10px 25px rgba(24,119,242,.12);font-family:Arial,sans-serif}.contact-form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-soft);margin-top:18px}.contact-form-card .form-grid{margin-top:14px}.contact-status{margin-top:12px}

.feature-service{background:linear-gradient(135deg,#fff,var(--sage-3));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);overflow:hidden}.feature-service .feature-media img{width:100%;height:100%;min-height:360px;object-fit:cover}.feature-service .feature-copy{padding:34px}.feature-service.grid-service{display:grid;grid-template-columns:.95fr 1.05fr}.handpan-section[data-hidden="true"]{display:none}.handpan-feature{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;overflow:hidden}.handpan-feature img{width:100%;height:100%;min-height:360px;object-fit:cover}.handpan-feature .pad{padding:34px}.service-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

.admin-login-card{text-align:center}.admin-login-card img{margin-left:auto!important;margin-right:auto!important}.admin-login-card .field{text-align:left}.admin-actions{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}.tiny-btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:7px 10px;font-weight:900;cursor:pointer}.tiny-btn:hover{background:var(--sage-3)}.tiny-btn.danger{color:#8b2e1d;background:#fff5f3;border-color:#e3b9ac}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px;background:var(--sage-3);border-radius:12px;margin-top:14px}.toggle-pill{display:inline-flex;align-items:center;gap:8px;font-weight:900}.toggle-pill input{width:18px;height:18px}.confirm-box{width:min(520px,100%);background:rgba(255,255,255,.92);border:1px solid rgba(29,40,34,.12);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.confirm-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}.reveal.in-view{opacity:1;transform:translateY(0)}

@media (max-width:1100px){.contact-section-wrap,.feature-service.grid-service,.handpan-feature{grid-template-columns:1fr}.image-card.double{grid-template-columns:1fr}.image-card.double img{min-height:260px}.section-title-row{display:block}.crosslink-card{align-items:flex-start;flex-direction:column}.navbar{width:calc(100% - 32px)}.nav-links{gap:18px}.nav-link{font-size:.88rem}.team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.container{width:min(100% - 28px,var(--container))}.buyer-switch{grid-template-columns:1fr}.contact-media img,.contact-media img:first-child{height:220px}.crosslink-card{padding:22px}.feature-service .feature-copy,.handpan-feature .pad{padding:24px}.team-card img{aspect-ratio:4/4.8}.mobile-menu .nav-link{font-size:1.55rem}.section-title-row{margin-bottom:20px}.admin-actions{flex-direction:column}.admin-actions .btn{width:100%}}
.gateway-actions-stacked{flex-direction:column;align-items:center;gap:16px}
.gateway-actions-stacked .gateway-main-choice{min-width:min(360px,100%);background:rgba(184,203,184,.94)}
.gateway-business-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;width:100%}
.gateway-business-row .btn{min-width:250px}
.space-switch{display:flex;align-items:baseline;gap:9px;margin-left:-6px;white-space:nowrap;color:#c2c8c3;flex:0 0 auto}
.space-switch a{color:#9aa39b;font-size:.88rem;font-weight:800;letter-spacing:.005em;transition:.2s ease}
.space-switch a:hover{color:var(--ink)}
.space-switch .divider{color:#c2c8c3;font-weight:900;font-size:1.14rem;line-height:1}
.mobile-space-switch{display:flex;flex-direction:column;align-items:center;gap:8px;margin:0 auto 28px;width:min(420px,100%)}
.mobile-space-switch a{font-weight:850;color:#9aa39b;text-align:center}
.mobile-space-switch .current{font-weight:950;color:var(--ink);font-size:1.18rem;text-align:center}
.team-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:20px;margin-top:32px}
.team-grid .team-card{flex:0 1 calc((100% - 40px)/3);max-width:calc((100% - 40px)/3);min-width:300px}
.compact-list{gap:16px}
.book-preview-actions{display:flex;justify-content:center;align-items:center;margin-top:28px;text-align:center}
.book-preview-actions .btn{margin-left:auto;margin-right:auto}
.book-preview-card .btn{display:none}
@media (max-width:1180px){.navbar{height:78px;padding:0}.site-header .nav-links{display:none}.site-header .nav-toggle{display:block;margin-left:auto}.space-switch{margin-left:0}}
@media (max-width:1100px){.team-grid{display:flex;flex-direction:column;align-items:center}.team-grid .team-card{width:100%;max-width:760px;min-width:0;flex-basis:auto}}
@media (max-width:980px){.space-switch{display:none}}
@media (max-width:640px){.gateway-business-row{flex-direction:column}.gateway-business-row .btn{width:100%;min-width:0}.team-grid .team-card{max-width:100%}.book-preview-actions .btn{width:100%;justify-content:center}}
.hero-panel strong{color:#fff}
.books-grid > .book-card:last-child:nth-child(odd) {
  grid-column: 1 / -1;
  justify-self: center;
  width: 100%;
  max-width: 520px;
}

.legal-container{max-width:980px!important}
.legal-intro-card{margin-bottom:26px}
.legal-date{margin:0 0 18px;color:var(--muted);font-weight:700}
.legal-summary{background:linear-gradient(135deg,var(--sage-3),#fff);border:1px solid rgba(184,203,184,.7);border-radius:var(--radius);padding:24px;margin:22px 0 0;box-shadow:var(--shadow-soft)}
.legal-summary h2{margin-top:0!important}
.legal-summary p + p,.legal-section p + p{margin-top:12px}
.legal-section{padding:24px 0;border-top:1px solid var(--line)}
.legal-section h2{margin:0 0 14px!important}
.legal-section h3{font-size:1.08rem;margin:22px 0 8px;color:#334238}
.legal-table{width:100%;border-collapse:collapse;margin:16px 0;background:#fff;border:1px solid var(--line);border-radius:var(--radius-small);overflow:hidden;display:block;overflow-x:auto}
.legal-table tbody,.legal-table thead,.legal-table tr{width:100%}
.legal-table th,.legal-table td{border-bottom:1px solid var(--line);padding:12px 13px;text-align:left;vertical-align:top;color:var(--muted);min-width:160px}
.legal-table th{color:var(--ink);background:var(--sage-3);font-weight:900}
.legal-table tr:last-child th,.legal-table tr:last-child td{border-bottom:0}
.cookie-table th,.cookie-table td{font-size:.88rem;min-width:150px}
.legal-back{margin-top:28px}
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:9999;display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;width:min(1040px,calc(100% - 40px));margin:0 auto;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);border:1px solid rgba(29,40,34,.12);border-radius:22px;box-shadow:0 24px 80px rgba(29,40,34,.18);padding:20px;color:var(--ink)}
.cookie-banner h2{font-size:1.35rem;margin:0 0 8px;letter-spacing:-.025em}
.cookie-banner p{max-width:760px}.cookie-banner-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.cookie-manage-button{position:fixed;left:16px;bottom:16px;z-index:9998;border:1px solid rgba(29,40,34,.14);background:rgba(255,255,255,.78);backdrop-filter:blur(12px);color:var(--ink);border-radius:999px;padding:9px 13px;font-size:.82rem;font-weight:850;box-shadow:0 10px 28px rgba(29,40,34,.12);cursor:pointer;transition:.2s ease}
.cookie-manage-button:hover{transform:translateY(-1px);background:#fff}
.cookie-modal-backdrop{position:fixed;inset:0;z-index:10000;background:rgba(18,27,21,.42);backdrop-filter:blur(14px);display:grid;place-items:center;padding:20px}
.cookie-modal{width:min(680px,100%);max-height:min(760px,calc(100svh - 40px));overflow:auto;background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.8);border-radius:24px;box-shadow:0 30px 90px rgba(0,0,0,.22);padding:24px}
.cookie-modal-head{display:flex;align-items:start;justify-content:space-between;gap:18px;margin-bottom:12px}.cookie-modal h2{font-size:clamp(1.8rem,4vw,2.6rem)}
.cookie-modal-close{width:42px;height:42px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:1.6rem;line-height:1;cursor:pointer}
.cookie-options{display:grid;gap:12px;margin:22px 0}.cookie-option{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:16px;padding:16px}.cookie-option strong{display:block;font-size:1rem}.cookie-option small{display:block;color:var(--muted);margin-top:4px;line-height:1.4}.cookie-option input{width:22px;height:22px;accent-color:var(--sage)}.cookie-option.is-required{background:var(--sage-3)}.cookie-option.is-muted{opacity:.78;background:#fafaf7}.cookie-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--sage-3);border:1px solid rgba(184,203,184,.7);padding:6px 10px;font-size:.78rem;font-weight:900;color:#405045;white-space:nowrap}.cookie-modal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:18px}
.cookie-map-placeholder{min-height:380px;border-radius:var(--radius);border:1px dashed rgba(29,40,34,.22);background:linear-gradient(135deg,var(--sage-3),#fff 55%,#f4e9dc);box-shadow:var(--shadow-soft);display:grid;place-items:center;padding:24px;text-align:center}.cookie-map-placeholder-inner{max-width:520px}.cookie-map-placeholder h3{margin:0 0 10px}.cookie-map-placeholder p{margin-bottom:16px}.map-frame[data-cookie-blocked="true"]{display:none}
@media (max-width:760px){.cookie-banner{grid-template-columns:1fr;bottom:12px;left:12px;right:12px;width:calc(100% - 24px);padding:16px;border-radius:18px}.cookie-banner-actions{justify-content:stretch}.cookie-banner-actions .btn{width:100%}.cookie-modal{padding:18px;border-radius:20px}.cookie-option{grid-template-columns:1fr;gap:10px}.cookie-modal-actions .btn{width:100%}.cookie-manage-button{left:12px;bottom:12px}.legal-page .container{padding:24px}.legal-table th,.legal-table td{min-width:180px}}

.location-section{padding-top:48px;padding-bottom:48px}
.location-card{background:linear-gradient(135deg,#fff,var(--sage-3));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:34px;display:grid;grid-template-columns:1fr auto;gap:26px;align-items:center}
.location-card h2{font-size:clamp(2rem,4vw,3.4rem)}
.location-card .lead{margin-top:14px;max-width:860px}
.location-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.handpan-application{margin-top:24px;background:linear-gradient(135deg,var(--sage-3),#fff);border:1px solid rgba(184,203,184,.8);border-radius:var(--radius-small);padding:22px;display:grid;gap:18px}
.handpan-application h3{margin-bottom:10px}
.handpan-application .btn{justify-self:flex-start}
.handpan-application[data-hidden="true"]{display:none}
.handpan-settings-form{margin-top:18px;display:grid;gap:14px}
.handpan-settings-form .check-row{align-items:center}
@media (max-width:760px){.location-card,.handpan-application{grid-template-columns:1fr;align-items:flex-start}.location-card .btn,.handpan-application .btn{width:100%}}

.gateway-actions .btn,
.gateway-actions .btn:nth-child(2),
.gateway-actions-stacked .gateway-main-choice,
.gateway-business-row .btn{
  background:rgba(255,255,255,.93);
  color:var(--ink);
  border-color:rgba(255,255,255,.55);
}
.gateway-actions .btn:hover,
.gateway-business-row .btn:hover{
  background:#fff;
}
.gateway-modal{
  position:fixed;
  inset:0;
  z-index:90;
  display:grid;
  place-items:center;
  padding:24px;
  background:rgba(12,18,14,.46);
  backdrop-filter:blur(22px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease;
}
.gateway-modal.open{
  opacity:1;
  pointer-events:auto;
}
.gateway-modal-panel{
  position:relative;
  width:min(940px,100%);
  max-height:calc(100svh - 48px);
  overflow:auto;
  background:rgba(251,248,240,.98);
  color:var(--ink);
  border:1px solid rgba(255,255,255,.75);
  border-radius:28px;
  box-shadow:0 38px 110px rgba(0,0,0,.32);
  padding:clamp(24px,4vw,42px);
  animation:fadeUp .28s ease both;
}
.gateway-modal-panel h2{
  max-width:760px;
  font-size:clamp(2rem,4vw,3.6rem);
}
.gateway-modal-panel p,
.business-choice-card p{
  color:#465148;
}
.gateway-modal-panel .eyebrow,
.business-choice-card .eyebrow{
  color:var(--clay);
}
.gateway-modal-intro{
  margin-top:14px;
  font-size:1.08rem;
}
.gateway-modal-close{
  position:absolute;
  top:18px;
  right:18px;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  font-size:1.55rem;
  line-height:1;
  cursor:pointer;
  box-shadow:var(--shadow-soft);
}
.business-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin-top:30px;
}
.business-choice-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:24px;
  min-height:330px;
  padding:24px;
  border:1px solid rgba(29,40,34,.12);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow-soft);
  text-align:left;
}
.business-choice-card h3{
  margin-bottom:14px;
}
.business-choice-card p + p{
  margin-top:12px;
}
.business-choice-card .btn{
  background:var(--ink);
  color:#fff;
  border-color:rgba(29,40,34,.16);
}
.program-highlight-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:28px;
}
.program-highlight-card .lead{
  margin:10px 0 12px;
}
.program-highlight-card .service-badges{
  margin-top:18px;
}
.program-facts-card{
  display:grid;
  gap:12px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
}
.program-facts-card div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.program-facts-card div:last-child{
  border-bottom:0;
}
.program-facts-card span{
  color:var(--muted);
  font-weight:750;
}
.program-facts-card strong{
  font-size:1.08rem;
  text-align:right;
}
.program-cta-panel .service-badges{
  margin-top:18px;
}
@media (max-width:860px){
  .business-choice-grid,
  .program-highlight-card{
    grid-template-columns:1fr;
  }
  .business-choice-card{
    min-height:auto;
  }
  .program-highlight-card .btn{
    width:100%;
  }
}
@media (max-width:640px){
  .gateway-modal{
    padding:14px;
  }
  .gateway-modal-panel{
    border-radius:22px;
    padding:22px 18px;
  }
  .gateway-modal-close{
    top:12px;
    right:12px;
  }
  .program-facts-card div{
    align-items:flex-start;
    flex-direction:column;
    gap:4px;
  }
  .program-facts-card strong{
    text-align:left;
  }
}
.business-choice-btn-compact{
  white-space:nowrap;
  font-size:.94rem;
  padding-inline:14px;
}

.mobile-menu{
  height:100svh;
  height:100dvh;
  max-height:100svh;
  max-height:100dvh;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.mobile-menu.open{
  display:block;
}
.mobile-menu .nav-links{
  justify-content:flex-start;
  min-height:auto;
  padding-bottom:48px;
}
.mobile-space-switch{
  flex-shrink:0;
}
.gateway-modal{
  height:100svh;
  height:100dvh;
  max-height:100svh;
  max-height:100dvh;
  overflow-y:auto;
  align-items:center;
  justify-items:center;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.gateway-modal-panel{
  width:min(980px,calc(100vw - 32px));
  max-height:calc(100svh - 32px);
  max-height:calc(100dvh - 32px);
  overflow-y:auto;
  overscroll-behavior:contain;
}
.gateway-modal-panel h2{
  padding-right:54px;
  overflow-wrap:anywhere;
}
.gateway-modal-panel p,
.business-choice-card p{
  color:#3e4a42;
}
.business-choice-grid{
  align-items:stretch;
}
.business-choice-card{
  min-width:0;
}
.business-choice-card .btn,
.business-choice-btn-compact{
  width:100%;
  max-width:100%;
  white-space:normal;
  text-align:center;
  line-height:1.22;
  min-height:54px;
  padding:13px 16px;
  font-size:.95rem;
}
@media (max-width:900px){
  .gateway-modal{
    align-items:flex-start;
    padding:16px;
  }
  .gateway-modal-panel{
    margin:auto 0;
    width:100%;
    max-height:none;
    overflow:visible;
    border-radius:24px;
    padding:28px 20px 22px;
  }
  .gateway-modal-panel h2{
    font-size:clamp(1.65rem,8vw,2.35rem);
    padding-right:48px;
  }
  .gateway-modal-intro{
    font-size:1rem;
  }
  .business-choice-grid{
    grid-template-columns:1fr;
    gap:14px;
    margin-top:22px;
  }
  .business-choice-card{
    min-height:auto;
    padding:20px;
    gap:18px;
  }
  .business-choice-card h3{
    font-size:1.32rem;
  }
}
@media (max-width:520px){
  .gateway-modal{
    padding:10px;
  }
  .gateway-modal-panel{
    border-radius:20px;
    padding:22px 16px 18px;
  }
  .gateway-modal-close{
    top:10px;
    right:10px;
    width:40px;
    height:40px;
  }
  .gateway-modal-panel h2{
    padding-right:42px;
  }
  .business-choice-card{
    padding:18px 16px;
  }
  .business-choice-card .btn,
  .business-choice-btn-compact{
    min-height:58px;
    padding-inline:12px;
  }
  .mobile-menu{
    padding:96px 24px 28px;
  }
  .mobile-menu .nav-links{
    align-items:center;
    justify-content:flex-start;
    min-height:auto;
    padding-bottom:80px;
  }
}
