/* ===== The Piano Cottage — shared site styles ===== */
:root{
  --ink:#23332b; --green:#1e6b4f; --green2:#2f9168; --green-deep:#154d39;
  --cream:#faf6ec; --cream2:#f3ecdc; --paper:#ffffff; --gold:#c8a24a; --gold-deep:#9a6b00;
  --grey:#6a7a71; --line:#e3ddcd;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.7;font-weight:300;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.14;color:var(--green-deep);}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:1140px;margin:0 auto;padding:0 26px;}
.narrow{max-width:820px;margin:0 auto;padding:0 26px;}
.btn{display:inline-block;font-family:var(--sans);font-weight:500;font-size:13.5px;letter-spacing:.05em;
  padding:13px 30px;border-radius:30px;background:var(--green);color:#fff;border:1.5px solid var(--green);
  cursor:pointer;transition:.2s;text-transform:uppercase;}
.btn:hover{background:var(--green-deep);border-color:var(--green-deep);}
.btn.ghost{background:transparent;color:var(--green);}
.btn.ghost:hover{background:var(--green);color:#fff;}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#3a2c08;}
.btn.gold:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#fff;}

/* ===== Header / nav ===== */
header.site{position:sticky;top:0;z-index:80;background:rgba(236,228,209,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;max-width:1240px;margin:0 auto;padding:13px 26px;}
.brand{display:flex;align-items:center;gap:11px;white-space:nowrap;}
.brand .blogo{display:flex;align-items:center;}
.brand img{height:48px;width:auto;}
.brand .bt{display:flex;flex-direction:column;line-height:1;}
.brand .bt>a:first-child{font-family:var(--serif);font-size:23px;font-weight:700;color:var(--green-deep);transition:.18s;}
.brand .bt>a:first-child:hover{color:var(--green2);}
.brand .bt .brandsub{font-family:var(--sans);font-size:9px;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:3px;transition:.18s;}
.brand .bt .brandsub:hover{color:var(--gold-deep);}
.menu{display:flex;align-items:center;gap:22px;font-size:13px;font-weight:400;letter-spacing:.02em;}
.menu>li{position:relative;list-style:none;}
.menu>li>a{display:inline-block;padding:6px 0;border-bottom:1.5px solid transparent;transition:.18s;color:var(--ink);cursor:pointer;}
.menu>li>a:hover{border-bottom-color:var(--gold);color:var(--green-deep);}
.menu .login{background:var(--green);color:#fff;padding:8px 16px;border-radius:22px;}
.menu .login:hover{background:var(--green-deep);border-color:transparent;}
.menu .book{border:1.5px solid var(--green);color:var(--green);padding:7px 15px;border-radius:22px;}
.menu .book:hover{background:var(--green);color:#fff;}
/* dropdown */
.has-sub>.sub{position:absolute;top:100%;left:-14px;min-width:230px;background:var(--paper);border:1px solid var(--line);
  border-radius:12px;box-shadow:0 16px 40px -16px rgba(21,77,57,.4);padding:8px;opacity:0;visibility:hidden;
  transform:translateY(6px);transition:.18s;}
.has-sub:hover>.sub{opacity:1;visibility:visible;transform:translateY(0);}
.sub li{list-style:none;}
.sub a{display:block;padding:9px 12px;border-radius:8px;font-size:12.5px;color:var(--ink);}
.sub a:hover{background:var(--cream2);color:var(--green-deep);}
.has-sub>a:after{content:"⌄";font-size:11px;margin-left:5px;color:var(--gold);}
.burger{display:none;background:none;border:none;font-size:26px;color:var(--green-deep);cursor:pointer;}

@media(max-width:980px){
  .burger{display:block;}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;
    background:var(--cream);border-bottom:1px solid var(--line);padding:12px 26px 20px;gap:2px;max-height:80vh;overflow:auto;}
  .menu.open{display:flex;}
  .menu>li{width:100%;}
  .menu>li>a{display:block;width:100%;padding:11px 0;border-bottom:1px solid var(--line);}
  .has-sub>.sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;
    background:transparent;padding:0 0 8px 14px;min-width:0;}
  .sub a{padding:8px 0;font-size:13px;}
  .has-sub>a:after{float:right;}
}

/* ===== Hero ===== */
.hero{position:relative;text-align:center;padding:96px 26px 104px;overflow:hidden;
  background:#ece4d1 center 38%/cover no-repeat;}
.hero.path{background-image:url('../images/path.jpg');}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(245,238,221,.5),rgba(238,230,212,.42));}
.hero .wrap{position:relative;z-index:1;}
.hero .panel{background:rgba(250,246,236,.92);border:1px solid rgba(200,162,74,.45);border-radius:18px;
  padding:44px 38px 48px;max-width:760px;margin:0 auto;box-shadow:0 26px 64px -32px rgba(21,77,57,.55);}
.kicker{font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:16px;}
.hero h1{font-size:clamp(40px,7.5vw,76px);color:var(--green-deep);letter-spacing:.01em;}
.hero .tag{font-family:var(--serif);font-style:italic;font-size:clamp(19px,3vw,28px);color:var(--green2);margin-top:8px;}
.hero p.lead{max-width:560px;margin:20px auto 0;font-size:16px;color:var(--grey);}
.hero .cta{margin-top:30px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}

/* ===== Sections ===== */
section{padding:74px 0;}
section.tint{background:var(--paper);}
.eyebrow{text-align:center;font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:10px;}
.sec-title{text-align:center;font-size:clamp(28px,4.4vw,42px);margin-bottom:14px;}
.sec-sub{text-align:center;max-width:640px;margin:0 auto 46px;color:var(--grey);font-size:16px;}
.prose{font-size:16px;color:var(--ink);}
.prose p{margin:0 0 16px;}
.prose h3{font-size:26px;margin:30px 0 10px;color:var(--green);}
.prose .small{font-size:13px;color:var(--grey);}
.center{text-align:center;}

/* ===== Pillars (entry page) ===== */
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:34px;}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 14px 40px -28px rgba(21,77,57,.5);transition:.25s;}
.pillar:hover{transform:translateY(-4px);box-shadow:0 22px 50px -26px rgba(21,77,57,.55);}
.pillar .body{padding:30px 30px 34px;display:flex;flex-direction:column;flex:1;}
.pillar h3{font-size:29px;margin-bottom:12px;}
.pillar p{color:var(--grey);font-size:15px;flex:1;}
.pillar .btn{margin-top:22px;align-self:flex-start;}

/* image placeholder system */
.imgwrap{position:relative;width:100%;aspect-ratio:16/10;background:var(--cream2);}
.imgwrap.tall{aspect-ratio:3/4;}
.imgwrap img{width:100%;height:100%;object-fit:cover;}
.imgph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;
  text-align:center;color:#7f938a;padding:18px;background:linear-gradient(155deg,#f4faf6,#eef4ec 52%,#f2eee1);}
.imgph:before{content:"";width:58px;height:58px;flex:none;opacity:.92;
  background:url("data:image/svg+xml,%3Csvg%20xmlns=%27http://www.w3.org/2000/svg%27%20width=%2764%27%20height=%2764%27%20viewBox=%270%200%2064%2064%27%3E%3Cg%20fill=%27none%27%20stroke=%27%232f9168%27%20stroke-width=%271.5%27%3E%3Crect%20x=%2712%27%20y=%2718%27%20width=%2740%27%20height=%2730%27%20rx=%273%27/%3E%3Cline%20x1=%2722%27%20y1=%2718%27%20x2=%2722%27%20y2=%2748%27/%3E%3Cline%20x1=%2732%27%20y1=%2718%27%20x2=%2732%27%20y2=%2748%27/%3E%3Cline%20x1=%2742%27%20y1=%2718%27%20x2=%2742%27%20y2=%2748%27/%3E%3C/g%3E%3Cg%20fill=%27%23154d39%27%3E%3Crect%20x=%2718.5%27%20y=%2718%27%20width=%276%27%20height=%2718%27%20rx=%271.2%27/%3E%3Crect%20x=%2728.5%27%20y=%2718%27%20width=%276%27%20height=%2718%27%20rx=%271.2%27/%3E%3Crect%20x=%2738.5%27%20y=%2718%27%20width=%276%27%20height=%2718%27%20rx=%271.2%27/%3E%3C/g%3E%3Cpath%20d=%27M12%2018%20q20%20-9%2040%200%27%20fill=%27none%27%20stroke=%27%23c8a24a%27%20stroke-width=%271.6%27/%3E%3C/svg%3E") center/contain no-repeat;}
.imgph .pi{display:none;}
.imgph span{font-size:10.5px;letter-spacing:.14em;line-height:1.6;max-width:220px;text-transform:uppercase;opacity:.72;}

/* ===== Cards / reasons ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:26px 24px;}
.card .num{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.card h3{font-size:24px;margin:6px 0 10px;}
.card p{color:var(--grey);font-size:14.5px;}
.card .ico{font-size:30px;margin-bottom:8px;}

/* ===== Lessons / pricing ===== */
.path-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.path-grid.cols-3{grid-template-columns:repeat(3,1fr);max-width:960px;margin-left:auto;margin-right:auto;}
@media(max-width:760px){ .path-grid.cols-3{grid-template-columns:1fr;max-width:420px;} }
.lcard{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.22s;}
.lcard:hover{transform:translateY(-4px);box-shadow:0 18px 44px -24px rgba(21,77,57,.5);}
.lcard .body{padding:20px;display:flex;flex-direction:column;flex:1;}
.lcard .tier{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.lcard h3{font-size:21px;margin:4px 0 8px;}
.lcard .price{font-family:var(--serif);font-size:26px;color:var(--green);font-weight:700;}
.lcard .price small{font-size:13px;color:var(--grey);font-family:var(--sans);font-weight:400;}
.lcard p{font-size:13.5px;color:var(--grey);flex:1;margin:8px 0 14px;}
.pricebar{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;background:#f3faf6;border:1px solid var(--green2);
  border-radius:12px;padding:18px 22px;margin:8px 0 22px;}
.pricebar .big{font-family:var(--serif);font-size:40px;color:var(--green);font-weight:700;line-height:1;}
.pricebar .unit{color:var(--grey);font-size:14px;}
.pricebar .note{color:var(--grey);font-size:13px;margin-left:auto;}

/* ===== Pricing tables (blocks) ===== */
.ptables{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start;margin-top:8px;}
.ptable{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px 22px 18px;box-shadow:0 14px 40px -30px rgba(21,77,57,.5);}
.ptable.wide{grid-column:1 / -1;}
.solobar{display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap;margin-top:4px;}
.solobar .solo{margin:0;}
.solobar p.fine{margin:0;max-width:560px;}
.ptable h3{font-size:23px;color:var(--green);margin-bottom:2px;}
.ptable .ptier{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:12px;}
.ptable table{width:100%;border-collapse:collapse;font-size:14.5px;}
.ptable th,.ptable td{text-align:right;padding:9px 6px;border-bottom:1px solid var(--line);}
.ptable th:first-child,.ptable td:first-child{text-align:left;color:var(--ink);}
.ptable thead th{font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.05em;color:var(--grey);text-transform:uppercase;border-bottom:1.5px solid var(--green2);}
.ptable td .money{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--green);}
.ptable td .per{display:block;font-size:11px;color:var(--grey);margin-top:2px;font-family:var(--sans);font-weight:400;}
.ptable tr.star td{background:#f3faf6;}
.ptable tr.star td:first-child{border-left:3px solid var(--gold);}
.ptable .best{display:inline-block;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;background:rgba(200,162,74,.16);border-radius:20px;padding:2px 8px;margin-left:7px;vertical-align:middle;}
.ptable .solo{display:flex;align-items:baseline;gap:10px;margin:6px 0 4px;}
.ptable .solo .money{font-size:34px;}
.ptable .solo .u{color:var(--grey);font-size:14px;}
.ptable p.fine{font-size:12.5px;color:var(--grey);margin-top:12px;line-height:1.55;}
.pnote{max-width:760px;margin:26px auto 0;background:var(--cream2);border:1px solid var(--line);border-radius:12px;padding:18px 22px;font-size:13.5px;color:var(--ink);line-height:1.6;}
.pnote b{color:var(--green-deep);}
@media(max-width:720px){ .ptables{grid-template-columns:1fr;} }

/* ===== Crest / badge watermark hero ===== */
.hero-crest{position:relative;text-align:center;background:var(--cream);padding:132px 26px 140px;overflow:hidden;}
.hero-crest .wm{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);height:min(340px,46vw);width:auto;
  opacity:.12;filter:blur(1px);pointer-events:none;user-select:none;}
.hero-crest .wm-cottage{opacity:.16;filter:saturate(.55) blur(1px);}
.hero-crest .inner{position:relative;z-index:1;}
.hero-crest h1{font-family:var(--serif);font-weight:700;font-size:clamp(46px,8.4vw,90px);color:var(--ink);line-height:1;letter-spacing:.01em;margin:0;}
.hero-crest .hrule{width:118px;height:1px;background:var(--gold);opacity:.75;margin:22px auto 0;}
.hero-crest .htag{margin-top:16px;font-family:var(--sans);font-weight:400;font-size:clamp(14px,1.8vw,18px);letter-spacing:.05em;color:var(--grey);}
.hero-crest .cta{margin-top:30px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}
/* dark green variant */
.hero-crest.dark{background:#103328;}
.hero-crest.dark .wm{opacity:.18;filter:blur(.5px);}
.hero-crest.dark h1{color:#fbf8ef;}
.hero-crest.dark .hrule{background:var(--gold);opacity:.85;}
.hero-crest.dark .htag{color:#cfe0d6;}

/* ===== XinRu Piano page — all dark green ===== */
body.xrp{background:#103328;}
.xrp section.tint{background:transparent;}
.xrp .sec-sub{color:#cfe0d6;}
.xrp .pillar{background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.16);box-shadow:0 18px 46px -28px rgba(0,0,0,.6);}
.xrp .pillar:hover{box-shadow:0 26px 56px -26px rgba(0,0,0,.7);}
.xrp .pillar h3{color:#fbf8ef;}
.xrp .pillar p{color:#cfe0d6;}
.xrp .pillar .btn{background:var(--gold);border-color:var(--gold);color:#28210a;}
.xrp .pillar .btn:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#fff;}
/* dark header on XinRu page */
.xrp header.site{background:#103328;border-bottom-color:rgba(255,255,255,.14);}
.xrp .menu{background:#103328;}
.xrp .menu>li>a{color:#eaf2ec;}
.xrp .menu>li>a:hover{color:#fff;border-bottom-color:var(--gold);}
.xrp .brand .bt>a:first-child{color:#fbf8ef;}
.xrp .brand .bt>a:first-child:hover{color:var(--gold);}
.xrp .menu .login{background:var(--gold);color:#28210a;}
.xrp .menu .login:hover{background:#fff;color:var(--green-deep);}
/* flat dark banner on XinRu page */
.xrp .banner{background:#103328;}
.xrp .banner:before{display:none;}
.xrp .pillar .imgwrap{aspect-ratio:1/1;}

/* ===== Big banner (Relax) ===== */
.banner{position:relative;text-align:center;padding:100px 26px;overflow:hidden;
  background:#123c2c url('../images/path.jpg') center 40%/cover no-repeat;}
.banner:before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(18,55,40,.72),rgba(18,55,40,.84));}
.banner .wrap{position:relative;z-index:1;}
.banner-h{font-family:var(--serif);font-weight:600;font-size:clamp(34px,6vw,60px);color:#fbf8ef;line-height:1.1;}
.banner-p{max-width:600px;margin:18px auto 0;color:#dbe7df;font-size:17px;}
.banner .cta{margin-top:32px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}
.btn.ghost.light{color:#fbf8ef;border-color:rgba(251,248,239,.65);background:transparent;}
.btn.ghost.light:hover{background:#fbf8ef;color:var(--green-deep);border-color:#fbf8ef;}

/* ===== Broadcast / featured figure ===== */
figure.broadcast{margin:14px auto 0;max-width:640px;}
figure.broadcast img{width:100%;border-radius:12px;border:2px solid var(--gold);
  box-shadow:0 22px 55px -28px rgba(21,77,57,.55);}
figure.broadcast figcaption{margin-top:12px;font-size:14px;color:var(--grey);font-style:italic;font-family:var(--serif);font-size:17px;}
figure.broadcast figcaption b{color:var(--green-deep);font-style:normal;}

/* ===== Press quote band ===== */
.pressband{background:linear-gradient(160deg,#154d39,#123c2c);color:#eef4ec;padding:70px 26px;text-align:center;position:relative;overflow:hidden;}
.pressband:before{content:"\201C";position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-family:var(--serif);font-size:150px;color:rgba(200,162,74,.22);line-height:1;}
.pressband .inner{max-width:820px;margin:0 auto;position:relative;z-index:1;}
.pressband blockquote{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(22px,3.4vw,32px);line-height:1.4;color:#fbf8ef;margin:0;}
.pressband .attrib{margin-top:22px;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:500;}
.pressband .attrib .pub{font-family:var(--serif);font-style:italic;font-size:17px;letter-spacing:.02em;text-transform:none;color:#f3ecdc;display:block;margin-top:6px;}

/* ===== Letter (welcome) ===== */
.letter{background:#fffdf7;border:1px solid var(--line);border-radius:16px;padding:40px 44px;
  box-shadow:0 22px 60px -34px rgba(21,77,57,.5);position:relative;text-align:left;}
.letter:before{content:"";position:absolute;left:0;top:26px;bottom:26px;width:3px;border-radius:3px;
  background:linear-gradient(var(--gold),rgba(200,162,74,.25));}
.letter p{font-size:16px;color:var(--ink);margin:0 0 15px;line-height:1.75;}
.letter .greet{font-family:var(--serif);font-size:22px;color:var(--green-deep);font-style:italic;margin-bottom:18px;}
.letter a{color:var(--green);border-bottom:1px solid var(--green2);}
.letter a:hover{color:var(--green-deep);}
.letter .ticks{margin:12px 0 20px;}
.letter .ticks li{font-size:15.5px;}
.letter .sign-off{margin-top:24px;margin-bottom:2px;color:var(--grey);}
.letter .sign{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--green);line-height:1;margin:0;}
@media(max-width:560px){ .letter{padding:30px 24px;} }

/* ===== Timeline ===== */
.timeline{max-width:760px;margin:0 auto;border-left:2px solid var(--line);padding-left:26px;}
.tl{position:relative;margin-bottom:30px;}
.tl:before{content:"";position:absolute;left:-33px;top:5px;width:11px;height:11px;border-radius:50%;background:var(--gold);border:2px solid var(--cream);}
.tl .yr{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.tl h3{font-size:22px;margin:2px 0 8px;}
.tl p{color:var(--grey);font-size:14.5px;}

/* lists */
.ticks{list-style:none;margin:14px 0;}
.ticks li{position:relative;padding:6px 0 6px 28px;font-size:15px;color:var(--ink);}
.ticks li:before{content:"♪";position:absolute;left:0;color:var(--gold);font-size:15px;}

/* ===== Contact / forms ===== */
#contact{position:relative;background:#16412f url('../images/path.jpg') center/cover no-repeat;}
#contact:before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(18,55,40,.32),rgba(18,55,40,.42));}
#contact .wrap{position:relative;z-index:1;}
.contact-panel{background:rgba(250,246,236,.96);border:1px solid rgba(200,162,74,.4);border-radius:18px;padding:46px 40px;
  box-shadow:0 30px 70px -34px rgba(0,0,0,.6);}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:44px;align-items:start;}
.cinfo h3{color:var(--green-deep);font-size:26px;margin-bottom:16px;}
.cinfo p{color:var(--ink);font-size:15px;margin-bottom:10px;}
.cinfo .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:block;}
.cinfo a{color:var(--green);border-bottom:1px solid rgba(30,107,79,.4);}
.socials{display:flex;gap:14px;margin-top:20px;}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(30,107,79,.4);color:var(--green);
  display:flex;align-items:center;justify-content:center;font-size:18px;transition:.2s;}
.socials a:hover{background:var(--green);color:#fff;border-color:var(--green);}
form.enquiry{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
form.enquiry label{display:block;font-size:12px;letter-spacing:.04em;color:var(--grey);margin:14px 0 6px;}
form.enquiry input,form.enquiry textarea{width:100%;font-family:var(--sans);font-size:14px;font-weight:300;padding:11px 13px;
  border:1px solid var(--line);border-radius:9px;background:#fdfcf8;color:var(--ink);}
form.enquiry input:focus,form.enquiry textarea:focus{outline:none;border-color:var(--green2);box-shadow:0 0 0 3px rgba(47,145,104,.18);}
form.enquiry textarea{min-height:104px;resize:vertical;}
form.enquiry .btn{margin-top:20px;width:100%;}

/* ===== Booking mock ===== */
.bk-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:26px;align-items:start;}
.bk-cal{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;}
.bk-week{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:14px;}
.bk-day{text-align:center;}
.bk-day .dh{font-size:11px;font-weight:600;color:var(--green);margin-bottom:8px;}
.bk-slot{display:block;font-size:12px;border:1px solid var(--green2);color:var(--green);background:#f3faf6;border-radius:7px;
  padding:7px 4px;margin-bottom:7px;cursor:pointer;transition:.15s;}
.bk-slot:hover{background:var(--green);color:#fff;}
.bk-slot.taken{border-color:var(--line);color:#bbb;background:#f6f6f4;cursor:not-allowed;text-decoration:line-through;}
.bk-side{background:#f3faf6;border:1px solid var(--green2);border-radius:14px;padding:22px;}
.note-box{background:var(--cream2);border:1px dashed var(--gold);border-radius:12px;padding:16px 18px;font-size:13.5px;color:var(--ink);margin-top:16px;}

/* login */
.login-card{max-width:420px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px;}
.login-card h2{font-size:28px;text-align:center;margin-bottom:6px;}
.login-card label{display:block;font-size:12px;color:var(--grey);margin:14px 0 6px;}
.login-card input{width:100%;font-family:var(--sans);font-size:14px;padding:11px 13px;border:1px solid var(--line);border-radius:9px;background:#fdfcf8;}

/* ===== Footer ===== */
footer.site{background:#123c2c;color:#9fb6a9;padding:46px 26px 30px;}
footer.site .cols{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;}
footer.site .fbrand{font-family:var(--serif);font-size:22px;color:#f3ecdc;margin-bottom:8px;}
footer.site h4{color:#e7c878;font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px;font-family:var(--sans);font-weight:600;}
footer.site a{color:#cfe0d6;font-size:14px;display:block;padding:3px 0;}
footer.site a:hover{color:#fff;}
footer.site .copy{max-width:1140px;margin:30px auto 0;border-top:1px solid rgba(255,255,255,.12);padding-top:16px;font-size:12.5px;color:#7f998c;text-align:center;}

@media(max-width:860px){
  .pillars,.contact-grid,.bk-grid{grid-template-columns:1fr;}
  .cards{grid-template-columns:1fr;}
  .path-grid{grid-template-columns:1fr 1fr;}
  footer.site .cols{grid-template-columns:1fr;gap:22px;}
}
@media(max-width:520px){ .path-grid{grid-template-columns:1fr;} .frow{grid-template-columns:1fr;} section{padding:54px 0;} }
