/* ================================================================
   Aesthetica Skin, Hair & Cosmetic Clinic — Modern Design System
   ================================================================ */

:root{
  --brand:        #b07b54;
  --brand-2:      #c79a6f;
  --brand-dark:   #6f4a2f;
  --brand-soft:   #f4ece1;
  --accent:       #6f9b8b;
  --ink:          #3a302a;
  --body:         #5f564e;
  --muted:        #9a8d80;
  --line:         #ece1d3;
  --soft:         #faf5ee;
  --white:        #fffdf9;
  --radius:       18px;
  --radius-sm:    12px;
  --shadow-sm:    0 2px 10px rgba(74,52,33,.07);
  --shadow:       0 14px 40px rgba(74,52,33,.12);
  --shadow-lg:    0 26px 70px rgba(74,52,33,.18);
  --gradient:     #a87a52;
  --maxw:         1180px;
  --ease:         cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--body);
  background:var(--white);
  line-height:1.7;
  font-size:16px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--brand-dark)}
h1,h2,h3,h4,h5,h6{
  font-family:'Plus Jakarta Sans','Inter',sans-serif;
  color:var(--ink);
  line-height:1.22;
  font-weight:700;
  letter-spacing:-.01em;
}
section{position:relative}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Helpers ---------- */
.eyebrow{
  display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--brand);background:var(--brand-soft);
  padding:7px 16px;border-radius:999px;margin-bottom:18px;
}
.section{padding:96px 0}
.section-sm{padding:64px 0}
.center{text-align:center}
.lead{font-size:1.12rem;color:var(--body)}
.section-head{max-width:720px;margin:0 auto 56px}
.section-head.left{margin-left:0;text-align:left}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.6rem);margin-bottom:14px}
.section-head p{color:var(--muted);font-size:1.06rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.97rem;
  padding:14px 28px;border-radius:999px;border:0;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  white-space:nowrap;
}
.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 10px 24px rgba(29,111,184,.32)}
.btn-primary:hover{color:#fff;transform:translateY(-3px);box-shadow:0 16px 32px rgba(29,111,184,.42)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn-ghost:hover{background:#fff;color:var(--brand-dark)}
.btn-outline{background:#fff;color:var(--brand);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--brand);color:var(--brand-dark);transform:translateY(-3px)}

/* ---------- Top bar ---------- */
.topbar{background:var(--brand-dark);color:#cfe4f3;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap}
.topbar a{color:#cfe4f3}
.topbar a:hover{color:#fff}
.topbar .tb-group{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.topbar i{margin-right:7px;color:var(--brand-2)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line);
  transition:box-shadow .3s var(--ease)}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:52px;width:auto}
.brand-text{font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.05rem;color:var(--ink);line-height:1.1}
.brand-text small{display:block;font-size:.66rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.menu{list-style:none;display:flex;align-items:center;gap:4px}
.menu>li{position:relative}
.menu>li>a{
  display:block;padding:10px 15px;border-radius:10px;font-weight:600;font-size:.95rem;
  color:var(--ink);font-family:'Plus Jakarta Sans',sans-serif;
}
.menu>li>a:hover,.menu>li.active>a{color:var(--brand);background:var(--brand-soft)}
.menu .has-sub>a::after{content:"\f107";font-family:"FontAwesome";font-weight:900;margin-left:7px;font-size:.8rem;opacity:.7}
.submenu{
  list-style:none;position:absolute;top:calc(100% + 10px);left:0;min-width:220px;
  background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.22s var(--ease);
}
.menu .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:11px 14px;border-radius:9px;font-weight:500;color:var(--body)}
.submenu a:hover{background:var(--brand-soft);color:var(--brand)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--ink);cursor:pointer;padding:6px}
.menu-close{display:none;position:absolute;top:18px;right:18px;width:40px;height:40px;border:0;border-radius:50%;
  background:var(--brand-soft);color:var(--brand);font-size:1.15rem;cursor:pointer;align-items:center;justify-content:center}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:84vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.08);transition:opacity 1.4s var(--ease),transform 7s linear}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:rgba(58,42,28,.55)}
.hero .container{position:relative;z-index:2;padding-top:60px;padding-bottom:60px}
.hero-inner{max-width:620px}
.hero h1{color:#fff;font-size:clamp(2.1rem,5vw,3.5rem);margin-bottom:20px}
.hero h1 .hl{color:#f0d8b6}
.hero p{font-size:1.16rem;color:#e4eef6;margin-bottom:32px;max-width:540px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:10px}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer;transition:.3s}
.hero-dots button.active{background:#fff;width:30px;border-radius:999px}

/* ---------- Quick info strip ---------- */
.infostrip{background:var(--gradient);color:#fff;margin-top:-1px}
.infostrip .container{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;padding:34px 24px}
.infoitem{display:flex;gap:16px;align-items:flex-start}
.infoitem i{font-size:1.5rem;color:#bfe1f6;margin-top:4px}
.infoitem h4{color:#fff;font-size:1.02rem;margin-bottom:3px}
.infoitem p{color:#d4e7f5;font-size:.92rem;margin:0}

/* ---------- Service cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 26px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
  position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--gradient);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .ico{width:58px;height:58px;border-radius:16px;background:var(--brand-soft);display:grid;place-items:center;color:var(--brand);font-size:1.5rem;margin-bottom:20px}
.card h3{font-size:1.18rem;margin-bottom:10px}
.card p{font-size:.95rem;color:var(--body);margin-bottom:16px}
.card .more{font-weight:600;font-size:.9rem;font-family:'Plus Jakarta Sans';display:inline-flex;gap:6px;align-items:center}
.card .more i{transition:transform .25s}
.card:hover .more i{transform:translateX(4px)}

/* ---------- Split (about/feature) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.split.soft{background:var(--soft)}
.media-frame{position:relative}
.media-frame .badge{position:absolute;right:-18px;bottom:-18px;background:var(--gradient);color:#fff;border-radius:18px;padding:20px 26px;box-shadow:var(--shadow);text-align:center}
.media-frame .badge b{display:block;font-family:'Plus Jakarta Sans';font-size:2rem;line-height:1}
.media-frame .badge span{font-size:.82rem;color:#d4e7f5}

/* ---------- Feature grid (what we do) ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.feature{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .3s var(--ease),box-shadow .3s}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.feature .ph{height:210px;overflow:hidden}
.feature .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.feature:hover .ph img{transform:scale(1.07)}
.feature .body{padding:24px}
.feature h4{font-size:1.15rem;margin-bottom:8px}
.feature p{font-size:.93rem;margin:0}

/* ---------- Schedule ---------- */
.schedule-list{display:flex;flex-direction:column;gap:12px}
.sched-row{display:flex;justify-content:space-between;align-items:center;gap:16px;
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow-sm)}
.sched-row .day{font-family:'Plus Jakarta Sans';font-weight:700;color:var(--ink);display:flex;align-items:center;gap:10px}
.sched-row .day i{color:var(--brand)}
.sched-row .time{text-align:right;font-size:.92rem;color:var(--body)}

/* ---------- Testimonials ---------- */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);position:relative;transition:transform .3s var(--ease),box-shadow .3s}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.review .quote{font-size:2.4rem;color:var(--brand-soft);font-family:Georgia,serif;line-height:.6;margin-bottom:10px}
.review .stars{color:#f5b301;margin-bottom:14px;font-size:.9rem;letter-spacing:2px}
.review p{font-size:.95rem;color:var(--body);font-style:italic;margin-bottom:18px}
.review .who{display:flex;align-items:center;gap:12px}
.review .who .av{width:42px;height:42px;border-radius:50%;background:var(--gradient);color:#fff;display:grid;place-items:center;font-family:'Plus Jakarta Sans';font-weight:700}
.review .who b{display:block;color:var(--ink);font-family:'Plus Jakarta Sans';font-size:.95rem}
.review .who span{font-size:.82rem;color:var(--muted)}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:var(--gradient);color:#fff;padding:72px 0 64px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.07)}
.page-hero::before{content:"";position:absolute;left:-60px;bottom:-120px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.05)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:#fff;font-size:clamp(2rem,4.4vw,3rem);margin-bottom:12px}
.breadcrumb{font-size:.9rem;color:#cfe4f3}
.breadcrumb a{color:#cfe4f3}
.breadcrumb a:hover{color:#fff}

/* ---------- Treatment blocks ---------- */
.treatment{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:52px 0;border-bottom:1px solid var(--line)}
.treatment:last-child{border-bottom:0}
.treatment.rev .t-text{order:2}
.treatment h3{font-size:1.5rem;margin-bottom:14px;display:flex;align-items:center;gap:12px}
.treatment h3 .n{flex-shrink:0;width:40px;height:40px;border-radius:11px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;font-size:1rem;font-weight:800}
.treatment .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.treatment .tags span{background:var(--soft);border:1px solid var(--line);color:var(--body);font-size:.82rem;padding:6px 13px;border-radius:999px}
.ba-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ba-gallery.two{grid-template-columns:repeat(2,1fr)}
.ba-gallery figure{margin:0;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);position:relative}
.ba-gallery img{width:100%;height:170px;object-fit:cover;transition:transform .5s var(--ease)}
.ba-gallery figure:hover img{transform:scale(1.08)}
.ba-label{position:absolute;top:10px;left:10px;background:rgba(16,40,61,.78);color:#fff;font-size:.72rem;padding:4px 10px;border-radius:999px;letter-spacing:.04em}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 24px;
  font-family:'Plus Jakarta Sans';font-weight:600;font-size:1.05rem;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q i{color:var(--brand);transition:transform .3s var(--ease);flex-shrink:0}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a div{padding:0 24px 22px;color:var(--body)}

/* ---------- Doctor profile ---------- */
.doc{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
.doc .photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.doc .photo img{width:100%}
.cred-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
.cred{display:flex;gap:12px;align-items:flex-start;background:var(--soft);border-radius:12px;padding:14px 16px}
.cred i{color:var(--brand);font-size:1.05rem;margin-top:3px}
.cred span{font-size:.9rem}

/* ---------- CTA band ---------- */
.cta-band{background:var(--gradient);color:#fff;border-radius:24px;padding:54px;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-60px;bottom:-60px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.08)}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:12px;position:relative}
.cta-band p{color:#dcebf7;color:#d8eaf8;max-width:560px;margin:0 auto 26px;position:relative}
.cta-band .hero-actions{justify-content:center;position:relative}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.info-card img{width:100%;height:230px;object-fit:cover}
.info-card .pad{padding:30px}
.contact-line{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line)}
.contact-line:last-child{border-bottom:0}
.contact-line i{width:42px;height:42px;border-radius:12px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;flex-shrink:0;font-size:1.05rem}
.contact-line b{display:block;color:var(--ink);font-family:'Plus Jakarta Sans';font-size:.95rem;margin-bottom:2px}
.contact-line span{font-size:.92rem;color:var(--body)}
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);min-height:420px}
.map-wrap iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* ---------- Article (media) ---------- */
.article{max-width:820px;margin:0 auto}
.article .feat{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:36px}
.article h2{font-size:1.5rem;margin:32px 0 14px}
.article p{margin-bottom:18px}
.article .pull{background:var(--brand-soft);border-left:4px solid var(--brand);border-radius:0 12px 12px 0;padding:20px 24px;font-style:italic;color:var(--brand-dark);margin:26px 0}

/* ---------- Footer ---------- */
.site-footer{background:#2f2620;color:#cdbfb0;padding:70px 0 0;font-size:.93rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:44px;padding-bottom:50px}
.site-footer h5{color:#fff;font-family:'Plus Jakarta Sans';font-size:1.05rem;margin-bottom:20px;position:relative;padding-bottom:12px}
.site-footer h5::after{content:"";position:absolute;left:0;bottom:0;width:38px;height:3px;background:var(--brand-2);border-radius:2px}
.site-footer p{color:#cdbfb0;margin-bottom:14px}
.f-logo{height:50px;margin-bottom:18px}
.f-tags{display:flex;flex-wrap:wrap;gap:9px}
.f-tags a{background:rgba(255,255,255,.07);color:#e6d8c6;padding:8px 14px;border-radius:999px;font-size:.85rem;transition:.25s}
.f-tags a:hover{background:var(--brand);color:#fff}
.f-contact li{list-style:none;display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.f-contact i{color:var(--brand-2);margin-top:4px}
.f-contact a{color:#cdbfb0}
.f-contact a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;text-align:center;font-size:.86rem;color:#a3917f}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Float appointment button (mobile) ---------- */
.float-call{position:fixed;right:18px;bottom:18px;z-index:900;background:var(--gradient);color:#fff;
  width:58px;height:58px;border-radius:50%;display:none;place-items:center;font-size:1.3rem;
  box-shadow:0 12px 28px rgba(29,111,184,.45);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(42,147,213,.5)}70%{box-shadow:0 0 0 16px rgba(42,147,213,0)}100%{box-shadow:0 0 0 0 rgba(42,147,213,0)}}

/* ================= Responsive ================= */
@media(max-width:992px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .feature-grid,.reviews-grid{grid-template-columns:1fr 1fr}
  .infostrip .container{grid-template-columns:1fr;gap:18px}
  .split,.doc,.contact-grid,.treatment,.treatment.rev{grid-template-columns:1fr;gap:32px}
  .treatment.rev .t-text{order:0}
  .cred-list{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .nav-toggle{display:block}
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .topbar .tb-group.left{display:none}
  .menu{
    position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:#fff;flex-direction:column;
    align-items:stretch;gap:4px;padding:88px 20px 30px;box-shadow:var(--shadow-lg);
    transform:translateX(105%);transition:transform .35s var(--ease);overflow-y:auto;z-index:1100;
  }
  .menu.open{transform:translateX(0)}
  .menu>li>a{padding:13px 14px}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    border-left:2px solid var(--brand-soft);border-radius:0;margin:2px 0 6px 14px;padding:0}
  .menu .has-sub>a::after{float:right}
  .nav-cta .btn{display:none}
  .nav-backdrop{position:fixed;inset:0;background:rgba(8,24,38,.45);opacity:0;visibility:hidden;transition:.3s;z-index:995}
  .nav-backdrop.open{opacity:1;visibility:visible}
  .menu-close{display:flex}
  .float-call{display:grid}
  .cta-band{padding:38px 24px}
  .ba-gallery img{height:130px}
}
@media(max-width:560px){
  .cards,.feature-grid,.reviews-grid,.ba-gallery,.ba-gallery.two{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:78vh}
  .ba-gallery img{height:200px}
}
