
/* =============================
   GLO NAIL BAR — ULTRA LUXURY + BOLD MODERN
   ============================= */

:root{
  --cream:#f7f2ea;
  --offwhite:#fbf8f3;
  --ink:#111111;
  --charcoal:#1f1f1f;
  --soft:#e9e1d6;
  --line:rgba(17,17,17,.10);
  --shadow: 0 26px 80px rgba(0,0,0,.22);
  --radius:28px;
  --radius-lg:34px;
  --max:1200px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:
    radial-gradient(1200px 600px at 20% 10%, #ffffff 0%, rgba(255,255,255,0) 55%),
    radial-gradient(900px 500px at 85% 15%, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 60%),
    linear-gradient(to bottom, var(--offwhite), var(--cream));
  color:var(--ink);
  line-height:1.65;
}

.container{
  max-width:var(--max);
  margin:0 auto;
  padding:0 30px;
}

.eyebrow{
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:12px;
  opacity:.75;
}

/* ---------- Header / Nav ---------- */
header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
}

.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
}

.logo img{height:64px;width:auto;}

nav a{
  margin-left:26px;
  text-decoration:none;
  color:var(--ink);
  font-weight:500;
  font-size:14px;
  opacity:.92;
}

nav a:hover{opacity:1;}

.nav-cta{
  margin-left:28px;
  display:inline-flex;
  align-items:center;
  padding:10px 16px;
  border-radius:999px;
  background:var(--ink);
  color:#fff;
  font-size:13px;
  letter-spacing:.02em;
  box-shadow: 0 14px 34px rgba(0,0,0,.18);
}

/* ---------- Buttons ---------- */
.btn-primary, .btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 28px;
  border-radius:999px;
  text-decoration:none;
  font-weight:600;
  letter-spacing:.01em;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.btn-primary{
  background:var(--ink);
  color:#fff;
  box-shadow: 0 18px 44px rgba(0,0,0,.18);
}
.btn-primary:hover{transform: translateY(-1px); box-shadow: 0 22px 60px rgba(0,0,0,.22);}

.btn-secondary{
  border:1px solid rgba(17,17,17,.28);
  color:var(--ink);
  background: rgba(255,255,255,.55);
}
.btn-secondary:hover{transform: translateY(-1px);}

/* ---------- Hero ---------- */
.hero{
  padding:120px 0 80px;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 70px;
  align-items: center;
}

.hero h1{
  font-family:'Playfair Display', Georgia, serif;
  font-size:56px;
  line-height:1.05;
  margin: 14px 0 22px;
  letter-spacing:-.02em;
}

.hero p.hero-sub{
  font-size:18px;
  max-width:560px;
  margin-bottom:34px;
  color: rgba(17,17,17,.82);
}

.hero-actions{display:flex;gap:18px;flex-wrap:wrap;}

.hero-card{
  position:relative;
  border-radius: var(--radius-lg);
  overflow:hidden;
  background: #ddd;
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.55);
}

.hero-card::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,0) 55%);
  pointer-events:none;
}

.hero-image{
  width:100%;
  height: 560px;
  background-image: url('../images/hero.jpg');
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}

.hero-badge{
  position:absolute;
  top:18px; left:18px;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(17,17,17,.08);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.hero-caption{
  position:absolute;
  bottom:18px; left:18px; right:18px;
  color:#fff;
}
.hero-caption strong{display:block; font-size:16px; letter-spacing:.01em;}
.hero-caption span{display:block; font-size:13px; opacity:.9; margin-top:4px;}

/* Subtle entrance animation */
.reveal{opacity:0; transform: translateY(10px); animation: reveal .8s ease-out forwards;}
.reveal.delay1{animation-delay:.12s;}
.reveal.delay2{animation-delay:.24s;}
.reveal.delay3{animation-delay:.36s;}
@keyframes reveal{to{opacity:1; transform:none;}}

/* ---------- Sections ---------- */
.section{
  padding: 90px 0;
  background: rgba(255,255,255,.70);
  border-top:1px solid var(--line);
}

.section.alt{
  background: transparent;
  border-top: none;
}

.section h2{
  font-family:'Playfair Display', Georgia, serif;
  font-size:40px;
  line-height:1.15;
  margin-bottom:24px;
}

.lead{
  font-size:16px;
  color: rgba(17,17,17,.80);
  max-width: 820px;
}

.two-col{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 42px;
  align-items:start;
}

/* "Why clients love us" strip */
.why{
  padding: 34px 0;
  background: rgba(255,255,255,.55);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.why-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px;
  text-align:center;
}
.why-grid strong{
  display:block;
  font-size:14px;
  margin-bottom:8px;
  letter-spacing:.02em;
}
.why-grid p{
  font-size:13px;
  color: rgba(17,17,17,.78);
}

/* Glimpse */
.glimpse-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 34px;
}
.glimpse-grid img{
  width:100%;
  height: 320px;
  object-fit: cover;
  border-radius: var(--radius);
  box-shadow: 0 22px 70px rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.55);
}

/* Gallery grid (masonry-ish) */
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.gallery-item{
  height: 320px;
  border-radius: var(--radius);
  background: #ddd;
  box-shadow: 0 18px 60px rgba(0,0,0,.16);
  border: 1px solid rgba(255,255,255,.60);
  overflow:hidden;
  position:relative;
}
.gallery-item::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(circle at 20% 20%, rgba(255,255,255,.22), rgba(0,0,0,0) 55%);
  pointer-events:none;
}

/* Services list */
.service-list{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 24px;
}
.service-card{
  background: rgba(255,255,255,.72);
  border:1px solid var(--line);
  border-radius: 22px;
  padding: 18px 18px 16px;
}
.service-card strong{display:block; margin-bottom:6px;}
.service-card span{display:block; font-size:13px; color: rgba(17,17,17,.78);}

/* Contact form */
.form{ max-width: 560px; }
.label{ display:block; font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color: rgba(17,17,17,.62); margin-bottom:6px; }
.input, .textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius: 16px;
  padding: 12px 14px;
  font: inherit;
  background: rgba(255,255,255,.82);
  box-shadow: 0 12px 30px rgba(10,10,12,.08);
}
.textarea{ resize: vertical; min-height: 140px; }
.input:focus, .textarea:focus{ outline:none; border-color: rgba(10,10,12,.24); }

/* Footer */
footer{
  padding: 60px 0;
  background: var(--ink);
  color:#fff;
  text-align:center;
  font-size:13px;
  opacity:.95;
}

.footer-logo-img{
  height: 44px;
  width: auto;
  display:block;
  margin: 0 auto 12px;
  opacity: .95;
}

.footer-address{
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .2px;
  margin: 0 0 6px;
  color: rgba(255,255,255,.92);
}

.footer-phone{
  font-size: 13px;
  margin: 0;
  color: rgba(255,255,255,.80);
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr; gap: 38px;}
  .hero-image{height: 440px;}
  .two-col{grid-template-columns: 1fr; gap: 26px;}
  .why-grid{grid-template-columns: 1fr 1fr; gap: 18px;}
  .glimpse-grid{grid-template-columns: 1fr; }
  .glimpse-grid img{height: 280px;}
  .gallery-grid{grid-template-columns: 1fr;}
  .service-list{grid-template-columns: 1fr;}
  nav a{margin-left:16px;}
  .nav-cta{margin-left:16px;}
}



/* --- Glo: Ultra Luxury Mobile + High-End Polish --- */
:root{
  --glo-ink:#111111;
  --glo-ivory:#F7F4EE;
  --glo-ivory-2:#FBFAF7;
  --glo-shadow: 0 24px 70px rgba(0,0,0,.12);
  --glo-radius: 28px;
}

body{
  background: radial-gradient(1200px 600px at 70% 10%, rgba(0,0,0,.04), transparent 55%),
              radial-gradient(900px 520px at 20% 20%, rgba(0,0,0,.03), transparent 60%),
              var(--glo-ivory);
}

section{ scroll-margin-top: 90px; }
.section-divider{
  height:1px; width:100%;
  background: linear-gradient(90deg, transparent, rgba(17,17,17,.14), transparent);
  margin: 70px 0;
  border:0;
}

.hero-image, .hero-media, .hero-photo{
  position: relative;
  border-radius: var(--glo-radius);
  overflow:hidden;
  box-shadow: var(--glo-shadow);
  border: 1px solid rgba(17,17,17,.10);
}
.hero-image img, .hero-media img, .hero-photo img{
  width:100%; height:100%;
  object-fit: cover;
  transform: scale(1.02);
}
.hero-image::after, .hero-media::after, .hero-photo::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(600px 320px at 30% 10%, rgba(255,255,255,.25), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,.06), transparent 40%, rgba(0,0,0,.10));
  pointer-events:none;
}

.card, .panel, .tile{
  border-radius: 22px;
  border: 1px solid rgba(17,17,17,.10);
  background: rgba(255,255,255,.66);
  backdrop-filter: blur(6px);
}

a.button, .btn, button, .button{
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
a.button:hover, .btn:hover, button:hover, .button:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 40px rgba(0,0,0,.14);
}

.gallery-grid img{
  border-radius: 18px;
  box-shadow: 0 18px 55px rgba(0,0,0,.10);
  border: 1px solid rgba(17,17,17,.08);
}

/* --- Mobile spacing fixes --- */
@media (max-width: 980px){
  .container{ padding-left: 18px !important; padding-right: 18px !important; }
  .nav, header, .header{ padding-left: 14px !important; padding-right: 14px !important; }
}

@media (max-width: 820px){
  h1{ font-size: 44px !important; line-height: 1.05 !important; }
  h2{ font-size: 34px !important; line-height: 1.12 !important; }
  .hero{ padding-top: 22px !important; padding-bottom: 38px !important; }
  .hero-wrap, .hero-grid, .hero-inner{
    display:flex !important;
    flex-direction:column !important;
    gap: 18px !important;
    align-items: stretch !important;
  }
  .hero-image, .hero-media, .hero-photo{ min-height: 320px !important; }
  .glimpse-grid{
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .glimpse-grid img{ width:100% !important; height:auto !important; }
  .about-grid, .two-col, .split{
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }
  /* Center mobile typography for a cleaner luxury look */
  .hero-copy, .hero-text, .hero-content{ text-align: center !important; }
  .hero-sub{ margin-left:auto !important; margin-right:auto !important; font-size: 18px !important; line-height: 1.6 !important; }
  .cta-row{ justify-content: center !important; }
  .section h2{ text-align:center !important; }
  .card{ text-align:center !important; }
  .card span{ display:block !important; width:100% !important; }

  /* Header/nav: keep centered + readable */
  header .nav, .header .nav{ flex-wrap: wrap !important; justify-content: center !important; gap: 12px !important; }
  header nav{ flex-wrap: wrap !important; justify-content:center !important; }
  .logo img{ height: 42px !important; }
  .footer{ padding: 40px 18px !important; }
}

@media (max-width: 480px){
  h1{ font-size: 38px !important; }
  .hero-image, .hero-media, .hero-photo{ min-height: 280px !important; }
  .btn, a.button, .button{ width: 100% !important; justify-content:center !important; }
  .container{ padding-left: 16px !important; padding-right: 16px !important; }
  .hero{ padding-top: 18px !important; }
}
/* --- End polish --- */


/* Luxury Pricing Menu */
.page-hero { padding: 84px 0 28px; }
.page-hero .hero-kicker { letter-spacing: .22em; font-size: 12px; opacity: .7; }
.page-hero h1 { margin: 10px 0 10px; font-size: clamp(38px, 5vw, 64px); line-height: 1.02; }
.page-hero .hero-sub { max-width: 64ch; margin: 0; opacity: .75; }
.chip-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.chip { display:inline-flex; align-items:center; padding:10px 14px; border:1px solid rgba(0,0,0,.10); border-radius:999px; text-decoration:none; color:inherit; background:rgba(255,255,255,.55); backdrop-filter: blur(6px); }
.chip:hover { border-color: rgba(0,0,0,.18); }

.pricing { padding: 10px 0 90px; }
.pricing-card { background: rgba(255,255,255,.78); border: 1px solid rgba(0,0,0,.08); border-radius: 26px; padding: 22px 22px 16px; box-shadow: 0 18px 50px rgba(0,0,0,.06); margin: 18px 0; }
.card-head { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; }
.card-titles h2 { margin: 0; font-size: 30px; line-height: 1.15; }
.card-titles p { margin: 6px 0 0; opacity: .75; max-width: 62ch; }
.book-pill { display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:999px; text-decoration:none; background:#0a0a0a; color:#fff; font-weight:600; letter-spacing:.02em; box-shadow: 0 14px 34px rgba(0,0,0,.16); white-space:nowrap; }
.book-pill:hover { transform: translateY(-1px); }
.book-ic { display:inline-flex; }

.card-body { margin-top: 14px; border-top: 1px solid rgba(0,0,0,.08); }
.pricing-row { display:flex; justify-content:space-between; gap:16px; padding: 14px 4px; border-bottom: 1px dashed rgba(0,0,0,.12); }
.pricing-row:last-child { border-bottom:none; }
.item-name { font-weight: 650; letter-spacing: .01em; }
.item-desc { margin-top: 4px; opacity: .72; font-size: 14px; line-height: 1.35; max-width: 70ch; }
.item-price { font-weight: 700; letter-spacing: .02em; font-variant-numeric: tabular-nums; }

.card-foot { margin-top: 10px; display:flex; justify-content:flex-end; }
.fineprint { font-size: 12px; opacity: .6; }

/* Mobile tweaks */
@media (max-width: 720px) {
  .page-hero { padding: 64px 0 18px; }
  .pricing-card { padding: 18px 16px 14px; border-radius: 22px; }
  .card-head { flex-direction: column; align-items:flex-start; }
  .book-pill { width: 100%; justify-content:center; }
  .pricing-row { flex-direction: column; gap: 8px; }
  .item-price { font-size: 18px; }
}



/* Footer refinements */
.footer{background:#0f0f10;color:#111;padding:56px 0 28px;margin-top:80px}
.footer-inner{width:min(1100px,92vw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;align-items:start}
.footer-brand{display:flex;flex-direction:column;gap:14px}
.footer-logo-img{width:190px;max-width:72vw;height:auto;opacity:0.95;filter:drop-shadow(0 10px 24px rgba(0,0,0,0.35))}
.footer-tagline{color:rgba(255,255,255,0.72);margin:0;max-width:38ch}
.footer-col h4{margin:0 0 12px;font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,0.85)}
.footer-link{display:inline-flex;gap:10px;align-items:center;color:rgba(255,255,255,0.86);text-decoration:none;margin:0 0 10px}
.footer-link:hover{color:#fff}
.footer-link--icon .icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12)}
.footer-address{font-weight:600}
.footer-phone{color:rgba(255,255,255,0.76);margin-top:8px}
.footer-social{display:flex;gap:12px;align-items:center;margin-top:8px}
.social-icon{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);color:#fff;text-decoration:none}
.social-icon:hover{background:rgba(255,255,255,0.12)}
.footer-bottom{width:min(1100px,92vw);margin:26px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.6);font-size:13px}
@media (max-width:860px){
  .footer{padding:44px 0 26px}
  .footer-inner{grid-template-columns:1fr;gap:18px;text-align:center;justify-items:center}
  .footer-visit{align-items:center}
  .footer-social{justify-content:center}
  .footer-links{align-items:center}
  .footer-logo-img{width:160px}
}


/* --- Contact page: icon links + inquiry form --- */
.contact-meta{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 14px}
.meta-pill{display:flex;gap:10px;align-items:baseline;padding:10px 14px;border:1px solid rgba(0,0,0,.08);border-radius:999px;background:rgba(255,255,255,.6);backdrop-filter:saturate(120%) blur(6px)}
.meta-label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;opacity:.7}
.meta-value{font-weight:600}

.contact-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin:10px 0 22px}
.icon-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:999px;border:1px solid rgba(0,0,0,.10);background:#111;color:#fff;text-decoration:none;font-weight:600}
.icon-btn .icon{width:18px;height:18px;display:inline-block}
.icon-btn .icon svg{width:18px;height:18px;display:block}
.icon-btn:hover{transform:translateY(-1px)}
.icon-btn:active{transform:none}

.icon-divider{width:1px;height:26px;background:rgba(0,0,0,.15);margin:0 2px}

.icon-only{width:44px;height:44px;border-radius:999px;border:1px solid rgba(0,0,0,.10);display:grid;place-items:center;color:#111;background:rgba(255,255,255,.7);text-decoration:none}
.icon-only svg{width:20px;height:20px}
.icon-only:hover{transform:translateY(-1px)}
.icon-only:active{transform:none}

.form-card{margin-top:6px;padding:18px 18px 16px;border-radius:18px;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.75);backdrop-filter:saturate(120%) blur(6px)}
.form-title{margin:0 0 6px;font-size:20px}
.form-note{margin:0 0 14px;opacity:.75}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;opacity:.7}
.field input,.field textarea{border-radius:14px;border:1px solid rgba(0,0,0,.12);padding:12px 12px;background:#fff;font:inherit}
.field textarea{resize:vertical;min-height:120px}
.field-full{grid-column:1/-1}

@media (max-width: 720px){
  .form-grid{grid-template-columns:1fr}
  .meta-pill{width:100%;justify-content:space-between}
}
