/* =========================================================
   OH MY SKIN — SITEJET CLONE
   BLOCK 01 · TOKENS
   ========================================================= */
:root{
  --oms-bg:#faf6ef;
  --oms-bg-soft:#f3ede2;
  --oms-surface:#fffdf8;
  --oms-card:#ffffff;
  --oms-text:#2d342f;
  --oms-muted:#68756d;
  --oms-line:#ddd4c5;
  --oms-brand:#7f9c84;
  --oms-brand-2:#d4c4aa;
  --oms-brand-3:#efe7d8;
  --oms-accent:#ba6b5c;
  --oms-success:#5c7c61;
  --oms-danger:#a44f43;
  --oms-shadow:0 16px 40px rgba(59, 72, 63, 0.10);
  --oms-radius:22px;
  --oms-radius-sm:14px;
  --oms-max:1400px;
  --oms-font: "Inter", "Segoe UI", Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--oms-font);
  color:var(--oms-text);
  background:
    radial-gradient(circle at top right, rgba(212,196,170,.28), transparent 24%),
    linear-gradient(180deg, #faf7f2 0%, #f9f5ed 100%);
}
body.oms-lock{overflow:hidden}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
a{text-decoration:none;color:inherit}

/* =========================================================
   BLOCK 02 · SHELL
   ========================================================= */
.oms-site{min-height:100vh}
.oms-container{max-width:var(--oms-max);margin:0 auto;padding:0 24px}
.oms-section{padding:32px 0}
.oms-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(127,156,132,.12);color:#46614b;
  border:1px solid rgba(127,156,132,.18);
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase
}
.oms-btn{
  appearance:none;border:0;cursor:pointer;
  border-radius:999px;padding:14px 20px;font-weight:700;
  transition:.22s transform,.22s opacity,.22s box-shadow,.22s background;
  display:inline-flex;align-items:center;justify-content:center;gap:10px
}
.oms-btn:hover{transform:translateY(-1px)}
.oms-btn--brand{background:var(--oms-brand);color:#fff;box-shadow:0 10px 24px rgba(127,156,132,.24)}
.oms-btn--soft{background:var(--oms-brand-3);color:var(--oms-text)}
.oms-btn--ghost{background:transparent;border:1px solid var(--oms-line);color:var(--oms-text)}
.oms-btn--danger{background:var(--oms-accent);color:#fff}
.oms-link{color:#46614b;font-weight:700}
.oms-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;padding:7px 12px;border-radius:999px;
  background:#f5efe5;border:1px solid var(--oms-line);color:#5a665e
}
.oms-badge-sale,.oms-badge-stock{
  position:absolute;top:16px;left:16px;z-index:2;
  display:inline-flex;align-items:center;justify-content:center;
  min-height:30px;padding:6px 12px;border-radius:999px;
  font-size:12px;font-weight:800;letter-spacing:.02em
}
.oms-badge-sale{background:#fbe0da;color:#8f3f33}
.oms-badge-stock{background:#2e413114;color:#4d6c53}

/* =========================================================
   BLOCK 03 · TOPBAR + HEADER
   ========================================================= */
.oms-topbar{
  background:#314437;color:#f9f7f2;font-size:13px
}
.oms-topbar__inner{
  min-height:42px;display:flex;align-items:center;justify-content:center;gap:20px;
  text-align:center;flex-wrap:wrap;padding:8px 0
}
.oms-header{
  position:sticky;top:0;z-index:40;
  backdrop-filter:blur(12px);
  background:rgba(250,247,242,.9);
  border-bottom:1px solid rgba(221,212,197,.85)
}
.oms-header__inner{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;
  min-height:84px;align-items:center
}
.oms-logo{display:flex;align-items:center;gap:14px;font-weight:800}
.oms-logo__mark{
  width:46px;height:46px;border-radius:16px;
  background:linear-gradient(135deg, var(--oms-brand), #c3d5be);
  color:#fff;display:grid;place-items:center;
  font-size:20px;box-shadow:var(--oms-shadow)
}
.oms-logo__text span{display:block}
.oms-logo__text .sub{font-size:12px;color:var(--oms-muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.oms-nav{
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap
}
.oms-nav a{
  padding:10px 14px;border-radius:999px;color:#4b584f;font-weight:700;font-size:14px
}
.oms-nav a:hover,.oms-nav a.is-active{background:#efe7d8}
.oms-actions{display:flex;align-items:center;gap:10px}
.oms-iconbtn{
  width:46px;height:46px;border-radius:50%;border:1px solid var(--oms-line);
  background:#fff;display:grid;place-items:center;cursor:pointer;position:relative
}
.oms-count{
  position:absolute;top:-4px;right:-2px;background:var(--oms-accent);color:#fff;
  min-width:20px;height:20px;padding:0 5px;border-radius:999px;font-size:11px;
  display:grid;place-items:center;font-weight:800
}

/* =========================================================
   BLOCK 04 · HERO
   ========================================================= */
.oms-hero{padding:34px 0 18px}
.oms-hero__grid{
  display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:stretch
}
.oms-hero__card{
  position:relative;overflow:hidden;
  min-height:400px;border-radius:32px;background:
  linear-gradient(135deg, rgba(127,156,132,.18), rgba(255,255,255,.75) 42%, rgba(212,196,170,.38));
  border:1px solid rgba(221,212,197,.9);box-shadow:var(--oms-shadow)
}
.oms-hero__content{
  position:relative;z-index:1;max-width:700px;padding:40px
}
.oms-hero h1{
  margin:14px 0 16px;font-size:clamp(36px,5vw,62px);line-height:.96;letter-spacing:-.03em
}
.oms-hero p{
  margin:0 0 24px;color:#55645a;font-size:17px;line-height:1.65;max-width:60ch
}
.oms-hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.oms-hero__stats{
  display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:14px
}
.oms-stat{
  background:rgba(255,255,255,.76);border:1px solid rgba(221,212,197,.9);
  border-radius:22px;padding:18px 16px
}
.oms-stat strong{display:block;font-size:26px;margin-bottom:6px}
.oms-stat span{color:var(--oms-muted);font-size:13px;line-height:1.45}
.oms-hero__art{
  position:absolute;inset:0;background:
    radial-gradient(circle at 82% 30%, rgba(255,255,255,.85), transparent 18%),
    radial-gradient(circle at 66% 26%, rgba(127,156,132,.22), transparent 20%),
    radial-gradient(circle at 72% 66%, rgba(212,196,170,.42), transparent 18%);
}
.oms-sidecard{
  display:grid;gap:18px
}
.oms-sidebox{
  border-radius:28px;background:#fffdf9;border:1px solid var(--oms-line);
  box-shadow:var(--oms-shadow);padding:28px
}
.oms-sidebox h3{margin:0 0 10px;font-size:28px;line-height:1.05}
.oms-sidebox p{margin:0;color:var(--oms-muted);line-height:1.65}
.oms-list{display:grid;gap:10px;margin-top:18px}
.oms-list li{list-style:none;display:flex;gap:10px;align-items:flex-start;color:#4a564e}

/* =========================================================
   BLOCK 05 · FILTER BAR
   ========================================================= */
.oms-strip{padding-top:8px;padding-bottom:6px}
.oms-strip__row{
  display:flex;gap:10px;overflow:auto;padding-bottom:4px
}
.oms-chip{
  white-space:nowrap;padding:12px 16px;border-radius:999px;
  border:1px solid var(--oms-line);background:#fff;color:#4d5a51;
  font-weight:700;cursor:pointer
}
.oms-chip.is-active{background:#314437;color:#fff;border-color:#314437}

/* =========================================================
   BLOCK 06 · SHOP LAYOUT
   ========================================================= */
.oms-shop{padding:22px 0 56px}
.oms-shop__layout{
  display:grid;grid-template-columns:300px minmax(0,1fr);gap:24px;align-items:start
}
.oms-panel{
  position:sticky;top:112px;background:#fffdf9;border:1px solid var(--oms-line);
  border-radius:28px;padding:22px;box-shadow:var(--oms-shadow)
}
.oms-panel h3,.oms-panel h4{margin:0}
.oms-panel__group + .oms-panel__group{margin-top:18px;padding-top:18px;border-top:1px solid #eee3d3}
.oms-search{
  display:flex;align-items:center;gap:10px;background:#f7f3eb;border:1px solid var(--oms-line);
  border-radius:16px;padding:0 14px
}
.oms-search input{
  width:100%;height:48px;border:0;background:transparent;outline:0;color:var(--oms-text)
}
.oms-checklist{display:grid;gap:10px}
.oms-check{
  display:flex;gap:10px;align-items:flex-start;cursor:pointer;color:#4d5b52;font-size:14px
}
.oms-check input{margin-top:3px}
.oms-range{
  display:grid;gap:12px
}
.oms-range__inputs{
  display:grid;grid-template-columns:1fr 1fr;gap:10px
}
.oms-range input,.oms-form input,.oms-form select,.oms-form textarea{
  width:100%;padding:13px 14px;border-radius:14px;border:1px solid var(--oms-line);
  background:#fff;outline:0;color:var(--oms-text)
}
.oms-range input:focus,.oms-form input:focus,.oms-form select:focus,.oms-form textarea:focus{
  border-color:#9bb4a0;box-shadow:0 0 0 4px rgba(127,156,132,.12)
}
.oms-toolbar{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  margin-bottom:18px;background:#fffdf9;border:1px solid var(--oms-line);
  border-radius:22px;padding:14px 16px;box-shadow:var(--oms-shadow)
}
.oms-toolbar__meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.oms-toolbar select{
  min-width:200px;padding:12px 14px;border-radius:14px;border:1px solid var(--oms-line);background:#fff
}
.oms-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px
}
.oms-card{
  position:relative;overflow:hidden;background:var(--oms-card);
  border:1px solid var(--oms-line);border-radius:26px;box-shadow:var(--oms-shadow);
  display:flex;flex-direction:column
}
.oms-card__media{
  position:relative;aspect-ratio:1/1;background:linear-gradient(135deg,#f7f2e8,#ece3d3);
  overflow:hidden
}
.oms-card__media img{width:100%;height:100%;object-fit:cover}
.oms-card__body{padding:18px;display:grid;gap:12px}
.oms-card__title{
  font-size:18px;line-height:1.18;min-height:43px;font-weight:800;letter-spacing:-.02em
}
.oms-card__tags{display:flex;gap:8px;flex-wrap:wrap}
.oms-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.oms-price strong{font-size:24px;letter-spacing:-.02em}
.oms-price del{color:#9a9287}
.oms-card__footer{display:flex;gap:10px;align-items:center}
.oms-card__footer .oms-btn{flex:1}
.oms-empty{
  background:#fffdf9;border:1px dashed #ccbca2;border-radius:26px;padding:34px;text-align:center
}
.oms-pagination{
  display:flex;justify-content:center;align-items:center;gap:10px;margin-top:28px;flex-wrap:wrap
}
.oms-pagebtn{
  min-width:44px;height:44px;border-radius:999px;border:1px solid var(--oms-line);background:#fff;cursor:pointer;font-weight:700
}
.oms-pagebtn.is-active{background:#314437;color:#fff;border-color:#314437}
.oms-mobile-filters{display:none}

/* =========================================================
   BLOCK 07 · DRAWERS / MODALS
   ========================================================= */
.oms-backdrop{
  position:fixed;inset:0;background:rgba(34,38,36,.42);backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:.22s;z-index:80
}
.oms-backdrop.is-open{opacity:1;pointer-events:auto}
.oms-drawer,.oms-modal{
  position:fixed;z-index:90;background:#fffdf8;box-shadow:0 30px 80px rgba(18,21,19,.22);
  transition:.28s ease;border:1px solid rgba(221,212,197,.85)
}
.oms-drawer{
  top:0;right:0;height:100vh;width:min(480px,100vw);
  transform:translateX(104%);display:flex;flex-direction:column
}
.oms-drawer.is-open{transform:translateX(0)}
.oms-modal{
  left:50%;top:50%;transform:translate(-50%,-46%) scale(.96);
  width:min(1120px,calc(100vw - 28px));max-height:92vh;border-radius:28px;overflow:auto;opacity:0;pointer-events:none
}
.oms-modal.is-open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.oms-sheet-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 18px;border-bottom:1px solid #eee4d7;background:#fffaf2;position:sticky;top:0;z-index:2
}
.oms-sheet-body{padding:20px}
.oms-close{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--oms-line);background:#fff;cursor:pointer;font-size:20px
}
.oms-product-modal{
  display:grid;grid-template-columns:1.05fr .95fr;gap:22px
}
.oms-gallery{
  display:grid;gap:12px
}
.oms-gallery__main{
  aspect-ratio:1/1;border-radius:24px;overflow:hidden;background:#f4ecdf;border:1px solid var(--oms-line)
}
.oms-gallery__main img{width:100%;height:100%;object-fit:cover}
.oms-gallery__thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.oms-thumb{
  aspect-ratio:1/1;border-radius:16px;overflow:hidden;border:1px solid var(--oms-line);cursor:pointer;background:#f8f2e6
}
.oms-thumb.is-active{outline:2px solid #7f9c84;outline-offset:2px}
.oms-product-meta{display:grid;gap:16px}
.oms-product-meta h2{margin:0;font-size:clamp(28px,3vw,42px);line-height:1.02;letter-spacing:-.03em}
.oms-product-meta p{margin:0;color:#57655b;line-height:1.72}
.oms-product-buy{
  display:flex;gap:12px;align-items:center;flex-wrap:wrap
}
.oms-qty{
  display:inline-grid;grid-template-columns:44px 56px 44px;align-items:center;
  border:1px solid var(--oms-line);border-radius:999px;overflow:hidden;background:#fff
}
.oms-qty button{border:0;background:#fff;height:46px;cursor:pointer;font-size:22px}
.oms-qty input{border:0;text-align:center;height:46px;padding:0;background:#fff}
.oms-related{
  margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px
}
.oms-related .oms-card{border-radius:20px;box-shadow:none}
.oms-cart-items{display:grid;gap:12px}
.oms-cart-item{
  display:grid;grid-template-columns:84px minmax(0,1fr) auto;gap:12px;
  border:1px solid var(--oms-line);border-radius:18px;padding:10px;background:#fff
}
.oms-cart-item__media{
  width:84px;height:84px;border-radius:14px;overflow:hidden;background:#f4ecdf
}
.oms-cart-item__media img{width:100%;height:100%;object-fit:cover}
.oms-cart-item h4{margin:0 0 6px;font-size:15px;line-height:1.25}
.oms-cart-item p{margin:0;color:var(--oms-muted);font-size:13px}
.oms-cart-summary{
  margin-top:auto;border-top:1px solid #eee4d7;padding:18px;display:grid;gap:12px;background:#fffaf2
}
.oms-summary-row{display:flex;justify-content:space-between;gap:18px;color:#55645a}
.oms-summary-row strong{color:var(--oms-text)}
.oms-form{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px
}
.oms-form .full{grid-column:1/-1}
.oms-form textarea{min-height:110px;resize:vertical}
.oms-note{
  padding:14px 16px;background:#f6f1e6;border-radius:18px;color:#58665d;border:1px solid var(--oms-line);font-size:14px;line-height:1.6
}
.oms-mini-card{
  padding:16px;border-radius:18px;background:#f7f3eb;border:1px solid var(--oms-line)
}

/* =========================================================
   BLOCK 08 · FOOTER + FLOATING
   ========================================================= */
.oms-footer{
  padding:40px 0 58px;border-top:1px solid rgba(221,212,197,.9);
  background:linear-gradient(180deg, rgba(255,255,255,0), rgba(239,231,216,.38))
}
.oms-footer__grid{
  display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:24px
}
.oms-footer h4{margin:0 0 10px}
.oms-footer p,.oms-footer li{margin:0;color:var(--oms-muted);line-height:1.7}
.oms-footer ul{padding:0;list-style:none;display:grid;gap:10px}
.oms-bottom{
  margin-top:24px;padding-top:20px;border-top:1px solid rgba(221,212,197,.9);
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:#68756d;font-size:14px
}
.oms-float{
  position:fixed;right:18px;bottom:18px;z-index:60;display:grid;gap:12px
}
.oms-float .oms-iconbtn{box-shadow:var(--oms-shadow);width:58px;height:58px}

/* =========================================================
   BLOCK 09 · HELPERS
   ========================================================= */
.oms-hidden{display:none !important}
.oms-muted{color:var(--oms-muted)}
.oms-sr{
  position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0
}
.oms-sep{height:1px;background:#eee4d7;margin:2px 0}
.oms-kbd{font-family:ui-monospace, monospace;padding:2px 6px;border-radius:8px;background:#f2ede3;border:1px solid #e0d6c6}

/* =========================================================
   BLOCK 10 · RESPONSIVE
   ========================================================= */
@media (max-width:1180px){
  .oms-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .oms-hero__grid{grid-template-columns:1fr}
  .oms-product-modal{grid-template-columns:1fr}
}
@media (max-width:960px){
  .oms-header__inner{grid-template-columns:1fr auto;gap:16px}
  .oms-nav{display:none}
  .oms-shop__layout{grid-template-columns:1fr}
  .oms-panel{display:none}
  .oms-mobile-filters{display:inline-flex}
  .oms-footer__grid{grid-template-columns:1fr}
  .oms-form{grid-template-columns:1fr}
}
@media (max-width:680px){
  .oms-container{padding:0 16px}
  .oms-grid{grid-template-columns:1fr}
  .oms-hero__content{padding:26px}
  .oms-hero__stats{grid-template-columns:1fr}
  .oms-card__title{min-height:auto}
  .oms-toolbar{align-items:stretch}
  .oms-toolbar select{width:100%}
  .oms-gallery__thumbs{grid-template-columns:repeat(4, minmax(0,1fr))}
  .oms-related{grid-template-columns:1fr}
  .oms-modal{width:min(100vw - 16px, 1120px)}
}

/* =========================================================
   BLOCK 11 · CART DRAWER VISIBILITY FIX
   ========================================================= */
.oms-drawer{
  height:100dvh;
  display:flex;
  flex-direction:column;
}
.oms-drawer .oms-sheet-head{
  flex:0 0 auto;
}
.oms-drawer .oms-sheet-body{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding-bottom:16px;
}
.oms-drawer .oms-cart-items{
  padding-bottom:8px;
}
.oms-drawer .oms-cart-summary{
  flex:0 0 auto;
  position:sticky;
  bottom:0;
  z-index:3;
  background:#fffaf2;
  box-shadow:0 -10px 24px rgba(18,21,19,.08);
}

@media (max-width:640px){
  .oms-drawer .oms-sheet-body{
    padding:16px;
  }
  .oms-drawer .oms-cart-summary{
    padding:14px 16px calc(14px + env(safe-area-inset-bottom));
  }
  .oms-drawer .oms-cart-summary .oms-btn{
    width:100%;
  }
}



/* =========================================================
   BLOCK 12 · HEADER / LOGO CUSTOM
   ========================================================= */
.oms-topbar{
  background:#6f8f3a !important;
  color:#ffffff !important;
  font-size:13px;
  font-weight:700;
  letter-spacing:.2px;
}
.oms-header{
  background:#ffffff !important;
  backdrop-filter:none !important;
}
.oms-header__inner{
  height:84px !important;
  min-height:84px !important;
  max-height:84px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:24px;
}
.oms-logo{
  flex:0 0 260px;
  height:84px !important;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.oms-logo img{
  display:block;
  height:72px !important;
  width:auto !important;
  object-fit:contain;
  background:#fff;
}
.oms-nav,
.oms-header nav{
  margin-left:auto !important;
  flex:0 1 auto;
}

/* =========================================================
   BLOCK 13 · MOBILE LEFT MENU
   ========================================================= */
@media (max-width: 960px){
  .oms-nav{
    display:none !important;
  }

  .oms-mobile-filters{
    display:grid !important;
  }

  .oms-header__inner{
    grid-template-columns:auto 1fr auto !important;
    align-items:center !important;
  }

  .oms-actions{
    margin-left:auto;
  }

  .oms-mobile-menu{
    background:#fffdf8;
  }

  .oms-mobile-menu .oms-sheet-head{
    background:#fff;
  }

  .oms-mobile-menu__nav{
    display:grid;
    gap:10px;
  }

  .oms-mobile-menu__nav a{
    display:flex;
    align-items:center;
    min-height:52px;
    padding:0 6px;
    border-bottom:1px solid rgba(221,212,197,.6);
    color:#2f3a33;
    font-weight:700;
    font-size:17px;
    text-decoration:none;
  }

  .oms-mobile-menu__cta{
    margin-top:18px;
  }

  .oms-mobile-menu__wa{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:50px;
    border-radius:999px;
    background:#6f8f3a;
    color:#fff;
    font-weight:800;
    text-decoration:none;
  }
}
