/* ═══════════════════════════════════════════
   JOHARI Wellness Spa Boutique – Shared CSS
   johariwellness.com.br
═══════════════════════════════════════════ */
:root{
  --B:#5f1214;--BD:#3d0b0d;--BL:#7a1a1d;
  --G:#d3ae39;--GL:#e8c85a;--GD:#a8892c;
  --CR:#faf7f2;--BE:#f0e9df;--SA:#e4d9cc;
  --IN:#110a06;--TX:#3d2b1f;--TM:#7a6555;--WH:#ffffff;
  --T:0.42s cubic-bezier(.25,.46,.45,.94);
  --FONT-SERIF:'Cormorant Garamond',serif;
  --FONT-TITLE:'Tenor Sans',sans-serif;
  --FONT-BODY:'Jost',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--FONT-BODY);background:var(--CR);color:var(--IN);overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none}

/* LOADER */
#ld{position:fixed;inset:0;z-index:9999;background:linear-gradient(160deg,var(--BD) 0%,var(--IN) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.2rem;transition:opacity 1s ease .3s,visibility 1s ease .3s}
#ld.out{opacity:0;visibility:hidden;pointer-events:none}
.ld-logo{width:138px;height:auto;opacity:0;animation:fup .9s ease .4s forwards;filter:drop-shadow(0 0 20px rgba(211,174,57,.18));object-fit:contain}
.ld-bar{width:0;height:1px;background:linear-gradient(to right,transparent,var(--G),var(--GL),var(--G));box-shadow:0 0 10px rgba(211,174,57,.4);animation:grow 1.8s cubic-bezier(.4,0,.2,1) .95s forwards}
.ld-lbl{font-family:var(--FONT-TITLE);font-size:.48rem;letter-spacing:.52em;text-transform:uppercase;color:rgba(211,174,57,.52);opacity:0;animation:fup .7s ease 1.5s forwards}
@keyframes fup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes grow{to{width:210px}}

/* CURSOR */
#cd,#cr{position:fixed;pointer-events:none;z-index:9990;transform:translate(-50%,-50%);border-radius:50%;transition:width .22s,height .22s}
#cd{width:5px;height:5px;background:var(--G)}
#cr{width:28px;height:28px;border:1px solid rgba(211,174,57,.5)}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:900;padding:1.5rem 4rem;display:flex;align-items:center;justify-content:space-between;transition:padding var(--T),background var(--T),box-shadow var(--T)}
#nav.on{padding:.9rem 4rem;background:rgba(250,247,242,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(211,174,57,.09);box-shadow:0 1px 0 rgba(211,174,57,.05),0 4px 32px rgba(0,0,0,.06)}
.nl a{display:flex;align-items:center}.nl img{height:52px;width:auto;transition:height var(--T);object-fit:contain}
#nav.on .nl img{height:42px}
.nlinks{display:flex;gap:2rem;list-style:none;align-items:center}
.nlinks a{font-family:var(--FONT-TITLE);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.82);transition:color .3s;position:relative;padding:.25rem 0}
.nlinks a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--G);transition:width .38s cubic-bezier(.25,.46,.45,.94)}
.nlinks a:hover::after,.nlinks a.active::after{width:100%}
#nav.on .nlinks a{color:var(--TX)}
.nlinks a:hover,.nlinks a.active{color:var(--G)!important}
.nend{display:flex;align-items:center;gap:.9rem}
.lbtn{font-family:var(--FONT-TITLE);font-size:.54rem;letter-spacing:.2em;border:1px solid rgba(211,174,57,.45);color:var(--G);background:transparent;padding:.26rem .65rem;cursor:pointer;transition:all .3s}
.lbtn:hover{background:var(--G);color:var(--BD)}
.nwa{font-family:var(--FONT-TITLE);font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;background:var(--G);color:var(--BD);padding:.52rem 1.25rem;font-weight:500;transition:background .3s,transform .3s;white-space:nowrap}
.nwa:hover{background:var(--GL);transform:translateY(-1px)}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem 0}
.hbg span{width:22px;height:1px;background:rgba(255,255,255,.85);transition:all .3s}
#nav.on .hbg span{background:var(--IN)}
.hbg.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hbg.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hbg.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* MOBILE MENU */
#mm{display:none;position:fixed;inset:0;z-index:850;background:linear-gradient(165deg,var(--BD) 0%,#150305 100%);flex-direction:column;align-items:center;justify-content:center;gap:1.6rem}
#mm.open{display:flex}
#mc{position:absolute;top:1.4rem;right:1.6rem;font-size:1rem;color:rgba(211,174,57,.65);background:none;border:1px solid rgba(211,174,57,.2);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;line-height:1;padding:0}
#mc:hover{color:var(--G);border-color:rgba(211,174,57,.5);background:rgba(211,174,57,.06)}
#mm a{font-family:var(--FONT-SERIF);font-size:1.85rem;font-weight:300;color:rgba(250,247,242,.72);transition:color .3s;letter-spacing:.06em;position:relative}
#mm a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--G);transition:width .38s ease}
#mm a:hover{color:var(--G)}
#mm a:hover::after{width:100%}
#mm .mm-wa{background:var(--G);color:var(--BD)!important;font-family:var(--FONT-TITLE);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;padding:.78rem 2.2rem;margin-top:.6rem;transition:background .3s}
#mm .mm-wa:hover{background:var(--GL)}
#mm .mm-wa::after{display:none}

/* BREADCRUMB */
.breadcrumb{max-width:1200px;margin:0 auto;padding:0 4rem;display:flex;align-items:center;gap:.5rem;font-family:var(--FONT-TITLE);font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(250,247,242,.35)}
.breadcrumb a{color:rgba(211,174,57,.55);transition:color .3s}
.breadcrumb a:hover{color:var(--G)}
.breadcrumb span{color:rgba(250,247,242,.25)}

/* PAGE HERO (inner pages) */
.page-hero{padding:10rem 4rem 6.5rem;background:var(--BD);position:relative;overflow:hidden;text-align:center}
.page-hero::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1600334129128-685c5582fd35?w=1600&q=70')center/cover no-repeat;opacity:.08;filter:saturate(0) brightness(.85)}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(211,174,57,.38),transparent)}
.ph-badge{font-family:var(--FONT-TITLE);font-size:.5rem;letter-spacing:.38em;text-transform:uppercase;color:rgba(211,174,57,.5);display:block;margin-bottom:1rem;position:relative}
.ph-title{font-family:var(--FONT-SERIF);font-size:clamp(2.8rem,6vw,4.8rem);font-weight:300;color:var(--CR);line-height:.95;letter-spacing:.06em;position:relative}
.ph-title em{font-style:italic;color:var(--G)}
.ph-sep{width:1px;height:46px;background:linear-gradient(to bottom,transparent,rgba(211,174,57,.5),transparent);margin:1.6rem auto;position:relative}
.ph-sub{font-family:var(--FONT-SERIF);font-size:1.05rem;font-style:italic;font-weight:300;color:rgba(250,247,242,.44);position:relative;max-width:520px;margin:0 auto;line-height:1.75}

/* SHARED BUTTONS */
.bg{font-family:var(--FONT-TITLE);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;background:var(--G);color:var(--BD);padding:.95rem 2.4rem;font-weight:500;transition:background .35s,transform .35s,box-shadow .35s;display:inline-block;border:none;cursor:pointer;position:relative;overflow:hidden}
.bg::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);transform:translateX(-120%);transition:transform .55s ease}
.bg:hover::after{transform:translateX(120%)}
.bg:hover{background:var(--GL);transform:translateY(-2px);box-shadow:0 8px 28px rgba(211,174,57,.28)}
.bo{font-family:var(--FONT-TITLE);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;background:transparent;padding:.95rem 2.4rem;border:1px solid rgba(211,174,57,.38);color:var(--G);transition:all .35s;display:inline-block;cursor:pointer}
.bo:hover{border-color:var(--G);background:rgba(211,174,57,.07);transform:translateY(-2px);box-shadow:0 6px 20px rgba(211,174,57,.1)}
.bo-w{color:rgba(255,255,255,.68);border-color:rgba(255,255,255,.22)}
.bo-w:hover{border-color:rgba(211,174,57,.6);color:var(--G)}

/* SHARED TYPOGRAPHY */
.ey{font-family:var(--FONT-TITLE);font-size:.5rem;letter-spacing:.44em;text-transform:uppercase;color:rgba(211,174,57,.72);display:block;margin-bottom:.9rem}
.st{font-family:var(--FONT-SERIF);font-size:clamp(2rem,4.5vw,3.4rem);font-weight:300;line-height:1.06;color:var(--B)}
.st em{font-style:italic}
.gl{width:44px;height:1px;background:linear-gradient(to right,var(--G),rgba(211,174,57,.35));margin:1.3rem 0}
.gl.c{margin:1.3rem auto}
.rv{opacity:0;transform:translateY(22px)}

/* FOOTER */
footer{background:var(--IN);padding:5rem 4rem 2.5rem}
.ft-g{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3.5rem;border-bottom:1px solid rgba(211,174,57,.07)}
.ft-b img{height:34px;margin-bottom:1.3rem;filter:brightness(1)}
.ft-b p{font-size:.75rem;font-weight:300;color:rgba(255,255,255,.25);line-height:1.9;margin-bottom:1.2rem}
.ft-b .ft-social{display:flex;gap:.5rem;margin-top:1rem}
.ft-b .ft-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.28);transition:all .3s}
.ft-b .ft-social a:hover{border-color:var(--G);color:var(--G);background:rgba(211,174,57,.07);transform:translateY(-2px)}
.ft-c h5{font-family:var(--FONT-TITLE);font-size:.52rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(211,174,57,.65);margin-bottom:1.1rem}
.ft-c ul{list-style:none}
.ft-c li{margin-bottom:.5rem}
.ft-c a{font-size:.75rem;font-weight:300;color:rgba(255,255,255,.25);transition:color .3s}
.ft-c a:hover{color:var(--G)}
.ft-c span,.ft-c p{font-size:.75rem;font-weight:300;color:rgba(255,255,255,.25)}
.ft-bt{max-width:1200px;margin:0 auto;padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.ft-bt p{font-size:.62rem;font-weight:300;color:rgba(255,255,255,.14)}
.ft-bt a{font-size:.62rem;font-weight:300;color:rgba(211,174,57,.32);transition:color .3s}
.ft-bt a:hover{color:var(--G)}

/* WA FLOAT */
.wf{position:fixed;bottom:1.8rem;right:1.8rem;z-index:800;display:flex;flex-direction:column;align-items:flex-end;gap:.35rem}
.wt{background:var(--WH);color:var(--TX);padding:.38rem .84rem;font-size:.67rem;font-weight:300;letter-spacing:.02em;border-left:2px solid var(--G);box-shadow:0 4px 16px rgba(0,0,0,.1);opacity:0;transform:translateX(8px);transition:all .3s;white-space:nowrap;pointer-events:none}
.wf:hover .wt{opacity:1;transform:none}
.wb{width:50px;height:50px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.35);transition:transform .3s,box-shadow .3s;position:relative}
.wb::before{content:'';position:absolute;inset:-5px;border-radius:50%;border:1px solid rgba(37,211,102,.28);animation:wapulse 2.6s ease-in-out infinite;pointer-events:none}
@keyframes wapulse{0%,100%{opacity:.75;transform:scale(1)}60%{opacity:0;transform:scale(1.55)}}
.wb:hover{transform:scale(1.08);box-shadow:0 6px 26px rgba(37,211,102,.5)}
.wb svg{width:24px;height:24px;fill:#fff}

/* RESPONSIVE NAV */
@media(max-width:1024px){
  #nav{padding:1.1rem 2rem}
  #nav.on{padding:.8rem 2rem}
  .nlinks{gap:1.4rem}
  .nlinks a{font-size:.54rem}
}
@media(max-width:768px){
  #nav{padding:1rem 1.5rem}
  #nav.on{padding:.8rem 1.5rem}
  .nlinks,.nwa{display:none}
  .hbg{display:flex}
  footer{padding:4.5rem 1.5rem 2.5rem}
  .ft-g{grid-template-columns:1fr 1fr;gap:2rem}
  .page-hero{padding:8rem 1.5rem 4.5rem}
  .breadcrumb{padding:0 1.5rem}
  .wf{bottom:1.4rem;right:1.4rem}
}
@media(max-width:480px){
  .ft-g{grid-template-columns:1fr}
  .ph-title{font-size:clamp(2.4rem,10vw,3.2rem)}
}

/* ═══ PHOTO QUALITY IMPROVEMENTS ═══ */
/* Prevent layout shift on images */
img{height:auto}
.sob-f img,.fd-photo img{color:transparent;background:var(--SA)}

/* Better image rendering */
img[loading="eager"]{image-rendering:-webkit-optimize-contrast}

/* ═══ FOCUS & ACCESSIBILITY ═══ */
:focus-visible{outline:2px solid rgba(211,174,57,.6);outline-offset:3px;border-radius:1px}

/* ═══ SELECTION COLOR ═══ */
::selection{background:rgba(211,174,57,.18);color:var(--B)}

/* ═══ SCROLL BAR PREMIUM ═══ */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--IN)}
::-webkit-scrollbar-thumb{background:var(--GD);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--G)}

/* ═══ PRINT OPTIMIZATION ═══ */
@media print{
  #nav,#mm,.wf,#ld,#cd,#cr{display:none!important}
  body{background:#fff;color:#000}
  .bg,.bo{border:1px solid #000;color:#000!important;background:#fff!important}
}

/* ═══ REDUCED MOTION ═══ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
