/* The Nail Editor - rebuilt static site
   Theme "Luxe": Playfair Display + Mulish, brand green #556D57 */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Mulish:wght@300;400;500;600;700&display=swap');

:root{
  --green:#556d57;
  --green-dark:#455a47;
  --green-soft:#6c7f6d;
  --cream:#f9f4f0;
  --ink:#33362f;
  --body:#464844;
  --muted:#6c6e68;
  --rule:#c9d1c5;
  --rule-white:rgba(255,255,255,.55);
  --maxw:1080px;
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:'Mulish', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  color:var(--body);
  background:#fff;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Header ---------- */
.site-header{background:var(--green);text-align:center;padding:26px 16px 22px;}
.site-header .logo{display:inline-block;margin:0 auto 16px;}
.site-header .logo img{width:150px;height:auto;margin:0 auto;}
.main-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:30px;}
.main-nav a{
  color:rgba(255,255,255,.9);
  text-transform:uppercase;
  font-size:12.5px;
  font-weight:600;
  letter-spacing:.14em;
  padding:4px 0;
  border-bottom:2px solid transparent;
  transition:border-color .2s, color .2s;
}
.main-nav a:hover{color:#fff;border-color:rgba(255,255,255,.6);}
.main-nav a.active{color:#fff;border-color:#fff;}

/* ---------- Section titles ---------- */
.section-title{
  display:flex;align-items:center;justify-content:center;gap:24px;
  max-width:840px;margin:0 auto 42px;
}
.section-title::before,.section-title::after{
  content:"";height:1px;background:var(--rule);flex:1;
}
.section-title h2{
  font-family:var(--serif);
  font-weight:600;
  color:var(--green);
  font-size:32px;
  margin:0;
  white-space:nowrap;
  letter-spacing:.01em;
}
.on-green .section-title h2{color:#fff;}
.on-green .section-title::before,.on-green .section-title::after{background:var(--rule-white);}

section{padding:74px 0;}

/* ---------- Hero (home) ---------- */
.hero{
  position:relative;
  min-height:560px;
  background:#3a2b2b center/cover no-repeat;
  display:flex;align-items:center;
}
.hero .hero-card{
  background:var(--cream);
  max-width:360px;
  margin-left:7%;
  padding:38px 34px;
  text-align:center;
  box-shadow:0 8px 30px rgba(0,0,0,.16);
}
.hero-card .word{font-family:var(--serif);color:var(--green);font-size:32px;margin:0 0 8px;}
.hero-card .pos{font-style:italic;color:var(--ink);margin:0 0 10px;font-size:16px;}
.hero-card .def{color:var(--ink);font-size:16.5px;line-height:1.55;margin:0;}

/* ---------- About columns ---------- */
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:38px;max-width:980px;margin:0 auto;}
.col-card{text-align:center;}
.col-card .thumb{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:3px;}
.col-card h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:21px;margin:20px 0 12px;}
.col-card p{font-size:15px;color:var(--body);max-width:300px;margin:0 auto;}
.col-card .badge{position:relative;display:inline-block;width:100%;}

/* ---------- Instagram carousel ---------- */
.carousel{position:relative;max-width:980px;margin:0 auto;}
.carousel-track{
  display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:4px 2px;
  scrollbar-width:none;
}
.carousel-track::-webkit-scrollbar{display:none;}
.carousel-track a{
  position:relative;flex:0 0 auto;width:calc((100% - 48px)/4);scroll-snap-align:start;
  border-radius:4px;overflow:hidden;
}
.carousel-track img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .4s;}
.carousel-track a:hover img{transform:scale(1.06);}
.carousel-track a::after{
  content:"";position:absolute;inset:0;background:rgba(85,109,87,0);transition:background .3s;
}
.carousel-track a:hover::after{background:rgba(85,109,87,.18);}
.carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);background:#fff;color:var(--green);
  border:1px solid var(--rule);width:42px;height:42px;border-radius:50%;cursor:pointer;
  font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 10px rgba(0,0,0,.14);z-index:3;transition:background .2s,color .2s;
}
.carousel-btn:hover{background:var(--green);color:#fff;}
.carousel-btn.prev{left:-16px;}
.carousel-btn.next{right:-16px;}
.gram-follow{text-align:center;margin-top:30px;color:var(--green);font-size:15px;letter-spacing:.03em;font-weight:600;}
.gram-follow a:hover{text-decoration:underline;}

/* ---------- Green section (contact) ---------- */
.on-green{background:var(--green);color:#fff;}
.on-green .lead{text-align:center;color:#fff;font-size:19px;margin:-20px 0 36px;font-weight:300;}

/* ---------- Contact form ---------- */
.contact-form{max-width:560px;margin:0 auto;}
.contact-form input,.contact-form textarea{
  width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.6);
  color:#fff;font-family:var(--sans);font-size:16px;padding:15px 16px;margin-bottom:18px;
  border-radius:3px;
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,.85);}
.contact-form textarea{min-height:130px;resize:vertical;}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#fff;background:rgba(255,255,255,.12);}
.btn-send{
  display:block;margin:6px auto 0;background:#fff;color:var(--green);
  border:none;border-radius:28px;padding:15px 46px;font-family:var(--sans);
  font-weight:700;font-size:13.5px;letter-spacing:.09em;text-transform:uppercase;cursor:pointer;
  transition:transform .15s, box-shadow .2s;
}
.btn-send:hover{box-shadow:0 8px 20px rgba(0,0,0,.22);transform:translateY(-1px);}
.recaptcha-note{text-align:center;font-size:12px;color:rgba(255,255,255,.8);margin:16px 0 0;}

/* policy blocks on green */
.policy{max-width:650px;margin:60px auto 0;text-align:center;color:#fff;}
.policy h3{text-decoration:underline;letter-spacing:.06em;font-weight:700;font-size:15px;text-transform:uppercase;margin:0 0 20px;}
.policy p{margin:0 0 16px;font-size:15.5px;}
.policy .strong{font-weight:700;text-decoration:underline;}
.hours{max-width:380px;margin:56px auto 0;text-align:center;color:#fff;}
.hours h3{font-family:var(--serif);font-weight:600;font-size:26px;margin:0 0 18px;}
.hours table{margin:0 auto;font-size:15.5px;border-collapse:collapse;}
.hours td{padding:4px 14px;}
.hours td:first-child{text-align:right;font-weight:600;width:76px;}
.hours td:last-child{text-align:left;}

/* ---------- Price list ---------- */
.price-cat{max-width:780px;margin:0 auto 50px;}
.price-cat > h3{font-family:var(--serif);color:var(--green);font-weight:600;font-size:28px;margin:0 0 4px;}
.price-cat > .cat-sub{font-size:13.5px;color:var(--muted);margin:0 0 28px;}
.price-item{display:flex;justify-content:space-between;gap:34px;padding:0 0 22px;margin-bottom:22px;}
.price-item .pi-body{max-width:80%;}
.price-item h4{font-family:var(--sans);font-weight:700;color:var(--ink);font-size:17.5px;margin:0 0 6px;}
.price-item p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.6;}
.price-item .price{font-size:17.5px;color:var(--green);white-space:nowrap;font-weight:600;}
.price-cat .divider{height:1px;background:var(--rule);margin:6px 0 0;}
.price-simple{display:flex;justify-content:space-between;padding:15px 0;border-bottom:1px solid #ececec;font-size:16px;}
.price-simple span:first-child{color:var(--ink);}
.price-simple span:last-child{color:var(--green);font-weight:600;}

/* ---------- Training feature rows ---------- */
.feature{max-width:920px;margin:0 auto;}
.feature .banner{width:100%;height:380px;object-fit:cover;margin:0 0 8px;border-radius:3px;}
.feature-row{display:grid;grid-template-columns:1.35fr 1fr;gap:34px;align-items:center;padding:36px 0 64px;}
.feature-row .ftxt{text-align:center;}
.feature-row .ftxt h4{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:20px;margin:0 0 14px;}
.feature-row .ftxt p{font-size:15px;color:var(--body);}
.feature-row .ftxt .bullets{text-align:left;max-width:420px;margin:14px auto;padding-left:20px;}
.feature-row .ftxt .bullets li{margin-bottom:6px;}
.btn-enquiry{
  display:inline-block;background:var(--green);color:#fff;border-radius:26px;
  padding:14px 32px;font-size:12.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  transition:background .2s, transform .15s;
}
.btn-enquiry:hover{background:var(--green-dark);transform:translateY(-1px);}
.feature-cta{display:flex;justify-content:center;}

/* ---------- Reviews ---------- */
.reviews-hero{
  position:relative;min-height:580px;background:#5a6470 center/cover no-repeat;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:#fff;padding:64px 20px;
}
.reviews-hero::before{content:"";position:absolute;inset:0;background:rgba(30,34,30,.34);}
.reviews-hero > *{position:relative;z-index:1;}
.reviews-hero h1{font-family:var(--serif);font-weight:600;font-size:42px;margin:0 0 30px;text-shadow:0 2px 12px rgba(0,0,0,.4);}
.recommend{margin-bottom:36px;}
.recommend .big{font-weight:700;font-size:23px;}
.recommend .sub{font-size:14px;opacity:.95;}
.review-cards{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;}
.review-card{background:#fff;color:var(--body);width:290px;border-radius:4px;padding:28px 24px;text-align:center;box-shadow:0 8px 26px rgba(0,0,0,.2);}
.review-card .avatar{width:66px;height:66px;border-radius:50%;object-fit:cover;margin:0 auto 14px;background:#dfe3dd;}
.review-card .rec{color:var(--green);font-weight:700;font-size:13.5px;margin-bottom:12px;}
.review-card .quote{font-size:15px;color:var(--ink);min-height:62px;line-height:1.55;}
.review-card .readmore{color:var(--green);font-size:13px;font-weight:600;margin:14px 0;display:inline-block;}
.review-card .meta{border-top:1px solid #eee;padding-top:12px;font-size:12.5px;color:var(--muted);}

/* ---------- Privacy ---------- */
.legal{max-width:820px;margin:0 auto;font-size:15.5px;color:var(--body);}
.legal .eff{font-style:italic;font-weight:700;color:var(--ink);margin-bottom:26px;}
.legal h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:19px;margin:30px 0 8px;}
.legal ul{margin:8px 0;padding-left:22px;}
.legal li{margin-bottom:7px;}

/* ---------- Social strip (footer) ---------- */
.social-strip{background:var(--green);color:#fff;}
.social-inner{max-width:var(--maxw);margin:0 auto;padding:34px 24px;display:flex;flex-direction:column;align-items:center;gap:18px;}
.social-label{font-family:var(--serif);font-size:23px;letter-spacing:.02em;color:#fff;}
.social-icons{display:flex;gap:18px;}
.social-btn{
  width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,.75);
  display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,transform .15s;
}
.social-btn svg{width:21px;height:21px;fill:#fff;transition:fill .2s;}
.social-btn:hover{background:#fff;border-color:#fff;transform:translateY(-2px);}
.social-btn:hover svg{fill:var(--green);}

/* ---------- Footer ---------- */
.site-footer{background:#f4f3f1;color:#7c7e78;font-size:13px;}
.site-footer .fwrap{max-width:var(--maxw);margin:0 auto;padding:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.site-footer a:hover{text-decoration:underline;color:var(--green);}
.site-footer .copyright{white-space:normal;}
.site-footer .foot-links{margin-left:auto;}

/* ---------- Responsive ---------- */
@media(max-width:800px){
  .cols3{grid-template-columns:1fr;max-width:380px;}
  .carousel-track a{width:calc((100% - 16px)/2);}
  .carousel-btn.prev{left:-6px;} .carousel-btn.next{right:-6px;}
  .feature-row{grid-template-columns:1fr;}
  .section-title h2{font-size:25px;white-space:normal;}
  .hero .hero-card{margin:0 auto;}
  .hero{justify-content:center;padding:40px 20px;}
  .reviews-hero h1{font-size:31px;}
  .site-footer .fwrap{justify-content:center;text-align:center;}
  .site-footer .foot-links{margin:0;}
}
@media(max-width:520px){
  .carousel-track a{width:calc((100% - 8px)/1.6);}
}
