/* Mobile-first overrides (loaded after beauty-studio.css)
   - Keep all viewport mobile changes inside 768px / 480px queries
   - Use touch/pointer feature queries only for interaction parity (hover → tap) */

@media (max-width: 768px) {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  body.mobile-nav-open {
    overflow: hidden;
  }

  #wrap,
  .sticky-wrapper,
  header,
  header .sticky,
  header .container,
  .container,
  .container-fluid,
  .row,
  [class*="col-"] {
    max-width: 100%;
  }

  .container {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }

  .row {
    margin-left: -8px;
    margin-right: -8px;
  }

  [class*="col-"] {
    padding-left: 8px;
    padding-right: 8px;
  }

  img,
  video,
  iframe {
    max-width: 100%;
    height: auto;
  }

  [data-stellar-background-ratio] {
    background-attachment: scroll !important;
    background-position: center center !important;
  }

  header,
  .sticky-wrapper {
    overflow: visible;
  }

  header .sticky {
    min-height: 68px;
  }

  header .sticky .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  header .logo,
  header .navbar {
    float: none;
    width: auto;
    margin: 0;
  }

  header .logo {
    max-width: calc(100% - 60px);
    min-width: 0;
  }

  header .logo a,
  .brand-name {
    display: block;
    max-width: 100%;
    white-space: normal;
    word-break: break-word;
  }

  .nav-right {
    display: none !important;
  }

  header .navbar {
    position: static;
  }

  .navbar-header {
    float: none;
    margin: 0;
  }

  .navbar-toggle {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    margin: 0;
    padding: 0;
    border: 1px solid rgba(182, 128, 99, 0.28);
    border-radius: 50%;
    background: rgba(255, 253, 249, 0.96);
  }

  .navbar-toggle .icon-bar,
  .navbar-toggle .icon-bar i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    margin: 0;
    font-size: 18px;
    color: #2d3a4b;
  }

  header .navbar-collapse,
  .collapse.navbar-collapse {
    position: fixed;
    top: 76px;
    left: 12px;
    right: 12px;
    width: auto !important;
    max-width: calc(100vw - 24px);
    max-height: calc(100dvh - 92px);
    overflow-y: auto;
    overflow-x: hidden;
    margin: 0;
    padding: 10px 0;
    border: 1px solid rgba(182, 128, 99, 0.12);
    border-radius: 24px;
    background: rgba(255, 252, 248, 0.98);
    box-shadow: 0 24px 70px rgba(27, 20, 15, 0.16);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-12px);
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
    display: block !important;
  }

  header .navbar-collapse.in,
  .collapse.navbar-collapse.in,
  .collapse.navbar-collapse.mobile-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  header .navbar .nav,
  .ownmenu .nav,
  .ownmenu {
    width: 100%;
  }

  header .navbar .nav,
  .ownmenu .nav {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 0;
    padding: 0;
  }

  header .navbar li,
  .ownmenu > li,
  .ownmenu .nav li {
    width: 100%;
    margin: 0;
    float: none;
  }

  header .navbar li a,
  .ownmenu > li > a,
  .ownmenu .nav li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 52px;
    padding: 15px 22px;
    white-space: normal;
    word-break: break-word;
    border-bottom: 1px solid rgba(182, 128, 99, 0.1);
    font-family: 'Montserrat', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.2em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    transition: color 0.2s ease, background 0.2s ease;
  }

  /* Beat specificity of .sticky-wrapper:not(.is-sticky) .navbar li a { color: #fff !important }
     by adding .sticky-wrapper to the selector — this wins both sticky and non-sticky states */
  .sticky-wrapper .navbar li a,
  .sticky-wrapper .navbar li.active a,
  .sticky-wrapper:not(.is-sticky) .navbar li a,
  .sticky-wrapper:not(.is-sticky) .navbar li.active a,
  .sticky-wrapper.is-sticky .navbar li a,
  .sticky-wrapper.is-sticky .navbar li.active a {
    color: #1a1612 !important;
    text-shadow: none !important;
  }

  .sticky-wrapper .navbar li a:hover,
  .sticky-wrapper:not(.is-sticky) .navbar li a:hover,
  .sticky-wrapper.is-sticky .navbar li a:hover {
    color: #b68063 !important;
    background: rgba(182, 128, 99, 0.05);
  }

  .sticky-wrapper .navbar li.active > a,
  .sticky-wrapper:not(.is-sticky) .navbar li.active > a,
  .sticky-wrapper.is-sticky .navbar li.active > a {
    color: #b68063 !important;
    font-weight: 700 !important;
  }

  header .navbar li:last-child > a,
  .ownmenu .nav li:last-child > a {
    border-bottom: 0;
  }

  .ownmenu ul.dropdown,
  .ownmenu ul.dropdown li ul.dropdown,
  header .navbar .nav .dropdown-menu,
  .ownmenu .nav .dropdown-menu {
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    width: 100% !important;
    min-width: 0;
    margin: 0;
    padding: 0 0 8px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    float: none;
    display: none;
    opacity: 1;
    visibility: visible;
    transform: none;
  }

  .ownmenu li.touch-open > .dropdown-menu,
  .ownmenu li.open > .dropdown-menu,
  .ownmenu li.touch-open > ul.dropdown,
  .ownmenu li.open > ul.dropdown {
    display: block !important;
  }

  .ownmenu ul.dropdown li a,
  .ownmenu .nav .dropdown-menu li a {
    padding: 12px 26px;
    min-height: 44px;
    font-size: 12px;
    letter-spacing: 0.14em;
  }

  .home-slider .tp-caption,
  .tp-banner img,
  .owl-carousel .owl-item img,
  .images-slider img,
  #shop-thumb img,
  #slider-shop img {
    max-width: 100%;
    height: auto;
  }

  .lighter-container {
    max-width: calc(100vw - 24px) !important;
    max-height: calc(100dvh - 24px) !important;
  }

  .lighter img {
    width: 100%;
    height: auto;
    max-height: calc(100dvh - 24px);
    object-fit: contain;
  }

  .lighter-close {
    top: 10px;
    right: 10px;
    width: 44px;
    height: 44px;
    margin: 0;
    line-height: 44px;
    font-size: 26px;
  }

  #map {
    width: 100% !important;
    max-width: 100%;
  }

  /* Reduce hero height on mobile to prevent extreme zoom on landscape video */
  .home-editorial-hero,
  .home-editorial-video {
    height: 56vh;
    min-height: 340px;
  }

  .home-editorial-video {
    object-position: center center;
  }

  @supports (height: 100dvh) {
    .home-editorial-hero,
    .home-editorial-video {
      height: 56dvh;
      min-height: 340px;
    }
  }

  .home-editorial-inner {
    padding: 1.2rem 1rem 2.3rem;
  }

  .home-editorial-hero.is-mobile-pending .home-editorial-brand,
  .home-editorial-hero.is-mobile-pending .home-editorial-nav a,
  .home-editorial-hero.is-mobile-pending .home-editorial-main h1,
  .home-editorial-hero.is-mobile-pending .home-editorial-vertical,
  .home-editorial-hero.is-mobile-pending .home-editorial-note,
  .home-editorial-hero.is-mobile-pending .home-editorial-scroll,
  .home-editorial-hero.is-mobile-pending .home-editorial-scroll-text {
    opacity: 0 !important;
    transform: translateY(20px) !important;
    animation: none !important;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-brand {
    animation: fadeInUp 0.7s ease forwards;
    animation-delay: 0.15s;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-nav a {
    animation: fadeInUp 0.7s ease forwards;
    animation-delay: 0.3s;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-main h1 {
    animation: fadeInUp 0.8s ease forwards;
    animation-delay: 0.45s;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-vertical {
    animation: fadeInUp 0.75s ease forwards;
    animation-delay: 0.55s;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-note {
    animation: fadeInUp 0.75s ease forwards;
    animation-delay: 0.65s;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-scroll {
    animation: fadeInUp 0.75s ease forwards;
    animation-delay: 0.8s;
  }

  .home-editorial-hero.is-mobile-inview .home-editorial-scroll-text {
    animation: fadeInUp 0.75s ease forwards;
    animation-delay: 0.9s;
  }

  .home-editorial-top {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0.7rem;
    text-align: center;
  }

  .home-editorial-brand {
    width: 100%;
    font-size: 0.88rem;
    letter-spacing: 0.18em;
    padding: 0;
    text-align: center;
  }

  .home-editorial-nav {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5rem 0.7rem;
    padding: 0;
    overflow: visible;
    -webkit-overflow-scrolling: auto;
    scrollbar-width: none;
  }

  .home-editorial-nav::-webkit-scrollbar {
    width: 0;
    height: 0;
  }

  .home-editorial-nav a {
    padding: 0.72rem 0.9rem;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    touch-action: manipulation;
  }

  /* Turn the vertical label into a subtle horizontal stamp */
  .home-editorial-vertical {
    left: 1rem;
    top: 5.4rem;
    transform: none;
    writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 0.66rem;
    letter-spacing: 0.28em;
    opacity: 0.85;
  }

  .home-editorial-note {
    left: 1rem;
    right: 1rem;
    bottom: 4.2rem;
    max-width: none;
    line-height: 1.75;
  }

  .home-editorial-scroll-wrap {
    bottom: 1rem;
  }

  .home-focus-head {
    margin-bottom: 34px;
  }

  /* ── Focus bento: uniform 2-column grid ── */
  .focus-bento-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  /* All cards: consistent flex column, image then text */
  .focus-card,
  .focus-card-hero,
  .focus-card-wide,
  .focus-card-tall {
    grid-column: auto;
    grid-row: auto;
    align-self: auto;
    border-radius: 18px;
    min-height: 0;
    display: flex;
    flex-direction: column;
  }

  /* Uniform image height across all cards */
  .focus-card .focus-card-media,
  .focus-card-hero .focus-card-media,
  .focus-card-wide .focus-card-media,
  .focus-card-tall .focus-card-media {
    min-height: 0;
    height: 0;
    padding-bottom: 100%;  /* 1:1 square images for all cards */
    flex-shrink: 0;
  }

  /* Text block: uniform padding and font size — no positional properties */
  .focus-card-copy,
  .focus-card-hero .focus-card-copy,
  .focus-card-tall .focus-card-copy {
    position: static;
    left: auto; right: auto; bottom: auto;
    padding: 10px 4px 0;
    border-radius: 0;
    background: none;
    backdrop-filter: none;
  }

  /* Uniform heading size across all cards */
  .focus-card-copy h5,
  .focus-card-hero .focus-card-copy h5,
  .focus-card-tall .focus-card-copy h5 {
    font-size: 15px;
    line-height: 1.25;
  }

  .focus-card-kicker {
    font-size: 8px;
    letter-spacing: 0.22em;
    margin-bottom: 3px;
  }

  /* Hide paragraph — not enough space in 2-col layout */
  .focus-card-copy p {
    display: none !important;
  }

  /* ── Editorial gallery: uniform full-width stacked cards ── */
  .editorial-gallery-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  /* Reset all desktop stagger padding and mobile stagger margins */
  .editorial-gallery-card-left,
  .editorial-gallery-card-center,
  .editorial-gallery-card-right {
    padding-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .editorial-gallery-card {
    transform: translate3d(0, 0, 0);
  }

  /* Uniform image aspect ratio for all three cards */
  .editorial-gallery-card-left .editorial-gallery-media,
  .editorial-gallery-card-center .editorial-gallery-media,
  .editorial-gallery-card-right .editorial-gallery-media {
    height: auto;
    aspect-ratio: 16 / 9;
    border-radius: 20px;
  }

  /* Uniform text block */
  .editorial-gallery-copy {
    margin-top: 14px;
    margin-left: 0;
    max-width: 100%;
    padding: 0 2px;
  }

  .editorial-gallery-copy h6 {
    font-size: 16px;
    letter-spacing: 0.06em;
    margin-bottom: 6px;
  }

  .editorial-gallery-copy p {
    font-size: 14px;
    line-height: 1.75;
    max-width: none;
  }

  .home-kinetic-categories {
    display: none !important;
  }

  /* ── Kinetic rows → stacked card layout on mobile ── */
  /* Image on top, text block below — no absolute overlapping */

  .kinetic-row {
    height: auto;
    overflow: visible;
    display: flex;
    flex-direction: column;
    border-top: 1px solid rgba(160, 130, 100, 0.22);
    transition: none;
  }

  /* Image area: relative so it sits in the document flow */
  .kinetic-row-media {
    position: relative;
    width: 100%;
    height: 220px;
    overflow: hidden;
    flex-shrink: 0;
  }

  .kinetic-row-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 1;
    transform: scale(1);
    clip-path: inset(0 0 0 0);
    display: block;
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
  }

  /* Overlay gradient on the image */
  .kinetic-row:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 220px;
    opacity: 0.28;
    z-index: 1;
  }

  /* Text shell: static block below the image */
  .kinetic-row-shell {
    position: relative;
    inset: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 18px 18px 24px;
    width: 100%;
    max-width: none;
    text-align: left;
    box-sizing: border-box;
    z-index: auto;
  }

  .kinetic-row-num {
    position: static;
    top: auto;
    left: auto;
    transform: none;
    margin-bottom: 8px;
    color: rgba(109, 87, 72, 0.55);
  }

  .kinetic-row h5 {
    justify-content: flex-start;
    text-align: left;
    letter-spacing: 0.09em;
    font-size: clamp(1.55rem, 7vw, 2.2rem);
    color: #2d2d2d;
    transform: none;
    width: 100%;
  }

  /* Reveal section: static flow, not absolutely positioned */
  .kinetic-row-reveal {
    position: static;
    left: auto;
    top: auto;
    transform: none;
    opacity: 1;
    width: 100%;
    max-width: none;
    text-align: left;
    margin-top: 10px;
  }

  .kinetic-row-reveal p {
    font-size: 14px;
    line-height: 1.75;
    color: rgba(45, 45, 45, 0.74);
    text-align: left;
  }

  .kinetic-row-reveal span {
    color: rgba(45, 45, 45, 0.9);
    font-size: 12px;
  }

  /* Give the marquee room by moving the heading to the top on mobile */
  .home-brand-head {
    top: 28px;
    transform: translateX(-50%);
  }

  .brand-ghost-marquee {
    padding: 132px 0 22px;
  }

  .brand-ghost-track {
    padding-left: 18px;
    gap: clamp(28px, 5vw, 56px);
  }

  .brand-ghost-item {
    min-height: 44px;
    touch-action: manipulation;
  }

  .home-story-editorial {
    overflow: hidden;
  }

  .home-story-media img {
    transform: none;
  }

  .journal-cover-copy,
  .journal-card-copy {
    max-width: 100%;
  }

  .journal-grid {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .journal-sidebar {
    position: static;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    margin-bottom: 18px;
  }

  .journal-sidebar span,
  .journal-sidebar a {
    width: auto;
    min-height: 44px;
    padding: 10px 14px;
  }

  .journal-card,
  .journal-card-team,
  .journal-card-pmu,
  .journal-card-studio,
  .journal-card-glow {
    grid-column: auto !important;
    margin: 0 !important;
  }

  .journal-card-team {
    transform: rotate(-1deg) !important;
  }

  .journal-card-pmu,
  .journal-card-studio,
  .journal-card-glow {
    transform: rotate(1deg) !important;
  }

  .journal-card-media img {
    aspect-ratio: 4 / 3;
  }

  .team-accordion {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    min-height: auto;
    overflow: visible;
  }

  .team-accordion-card,
  .team-accordion-card.is-active {
    min-width: 0;
    min-height: 420px;
    flex: none;
  }

  .team-accordion-card img {
    min-height: 420px;
    filter: grayscale(0.1);
  }

  .team-accordion-overlay,
  .team-accordion-card.is-active .team-accordion-overlay {
    padding: 20px 18px;
  }

  .team-accordion-overlay p {
    max-width: none;
  }

  .signature-arc-shell {
    padding: 18px 16px 24px;
  }

  .signature-arc-stage.is-mobile {
    display: flex;
    align-items: stretch;
    gap: 14px;
    height: auto;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 8px 4px 14px;
    margin: 0 -4px 14px;
    perspective: none;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .signature-arc-stage.is-mobile::-webkit-scrollbar {
    height: 0;
  }

  .signature-arc-stage.is-mobile .signature-card {
    position: relative;
    flex: 0 0 68vw;
    width: 68vw !important;
    height: 360px !important;
    top: auto !important;
    left: auto !important;
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
    scroll-snap-align: center;
  }

  .signature-arc-stage.is-mobile .signature-card.is-active {
    box-shadow: 0 22px 56px rgba(109, 87, 72, 0.2);
  }

  .shop-page .item-display .row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 0;
  }

  .shop-page .item-display .col-xs-6 {
    width: 100%;
  }

  .shop-page .item-display .pull-right {
    float: none !important;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-start;
  }

  .shop-page .item-display .bootstrap-select,
  .shop-page .item-display .selectpicker,
  .shop-page .item-display .grid-style,
  .shop-page .item-display .list-style {
    min-height: 44px;
  }

  .shop-page .papular-block.row > [class*="col-"] {
    width: 50%;
    margin-bottom: 16px;
  }

  .shop-page .papular-block .item {
    min-height: 100%;
  }

  .item-decribe .nav-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    border-bottom: 0;
  }

  .item-decribe .nav-tabs > li,
  .item-decribe .nav-tabs li {
    float: none;
    width: auto;
    flex: 1 1 calc(50% - 5px);
    margin: 0;
  }

  .item-decribe .nav-tabs > li > a,
  .item-decribe .nav-tabs a {
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: normal;
    text-align: center;
  }
}

@media (max-width: 480px) {
  header .sticky .container {
    gap: 10px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  header .logo {
    max-width: calc(100% - 54px);
  }

  header .navbar-collapse,
  .collapse.navbar-collapse {
    top: 68px;
  }

  .home-editorial-inner {
    padding: 1.05rem 0.9rem 2.1rem;
  }

  .home-editorial-main h1 {
    letter-spacing: 0.05em;
    font-size: clamp(2rem, 10.5vw, 3.1rem);
  }

  .home-editorial-note {
    font-size: 0.95rem;
    bottom: 4rem;
  }

  /* Focus bento: single column on tiny screens */
  .focus-bento-grid {
    grid-template-columns: 1fr;
  }

  .focus-card .focus-card-media,
  .focus-card-hero .focus-card-media,
  .focus-card-wide .focus-card-media,
  .focus-card-tall .focus-card-media {
    padding-bottom: 62%;  /* slightly wider landscape ratio on single col */
  }

  .focus-card-copy h5,
  .focus-card-hero .focus-card-copy h5,
  .focus-card-tall .focus-card-copy h5 {
    font-size: 16px;
  }

  .editorial-gallery-copy h6 {
    font-size: 16px;
  }

  .kinetic-row-shell {
    padding: 16px 16px 20px;
  }

  .kinetic-row-media {
    height: 190px;
  }

  .home-brand-head h4 {
    font-size: 1.8rem;
  }

  .signature-arc-stage.is-mobile .signature-card {
    flex-basis: 82vw;
    width: 82vw !important;
    height: 320px !important;
  }

  .shop-page .papular-block.row > [class*="col-"] {
    width: 100%;
  }

  .item-decribe .nav-tabs > li,
  .item-decribe .nav-tabs li {
    width: 100%;
  }
}

/* ── Section padding compression on mobile ─────────────────────────── */
@media (max-width: 768px) {
  .padding-top-100 { padding-top: 60px !important; }
  .padding-bottom-100 { padding-bottom: 60px !important; }
  .padding-top-150 { padding-top: 72px !important; }
  .padding-bottom-150 { padding-bottom: 72px !important; }
  .padding-top-80 { padding-top: 44px !important; }
  .padding-bottom-80 { padding-bottom: 44px !important; }

  /* Studio gallery section top gap */
  .home-gallery { padding-top: 0 !important; }

  /* Brand section */
  .bg-section { padding-top: 64px !important; }
  .bg-head { padding-bottom: 36px; }
  .bg-head h4 { font-size: clamp(1.55rem, 7vw, 2.2rem); }
  .bg-head p { font-size: 13px; }

  /* Home heading sizes */
  .heading h4,
  .home-kinetic-head h4,
  .home-journal-head h4 {
    font-size: clamp(1.5rem, 7vw, 2.1rem);
    line-height: 1.2;
  }

  /* Newsletter section */
  .news-letter .heading h4 {
    font-size: clamp(1.4rem, 6.5vw, 2rem);
  }
  .news-letter .heading span {
    font-size: 14px;
    line-height: 1.75;
  }
  .news-letter form {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    max-width: 420px;
    margin: 0 auto;
  }
  .news-letter form input {
    width: 100%;
    min-height: 48px;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 15px;
    box-sizing: border-box;
  }
  .news-letter form button {
    width: 100%;
    min-height: 48px;
    margin: 0;
    font-size: 14px;
    border-radius: 8px;
    letter-spacing: 0.14em;
  }

  /* Footer — stack 4 columns vertically */
  footer .container > [class*="col-md-"] {
    width: 100% !important;
    float: none;
    margin-bottom: 32px;
    padding-left: 16px;
    padding-right: 16px;
  }
  footer .container > [class*="col-md-"]:last-child {
    margin-bottom: 0;
  }
  footer h6 {
    margin-top: 0;
    font-size: 13px;
    letter-spacing: 0.2em;
  }
  footer p, footer li a { font-size: 14px; line-height: 1.85; }
  footer .social_icons { margin-top: 12px; }
  footer .social_icons a { font-size: 18px; margin-right: 12px; }
  .sub-footer .container { text-align: center; }
  .sub-footer .col-md-6 { width: 100% !important; float: none; }
  .sub-footer .col-md-6.text-right { text-align: center !important; margin-top: 8px; }

  /* Shop cards 2-up on phones */
  .shop-page .papular-block.row > [class*="col-md-3"] { width: 50% !important; }

  /* Story/about section inner padding */
  .home-story-editorial { padding-top: 72px !important; padding-bottom: 72px !important; }
  .home-story-connector { padding: 40px 0 46px; }

  /* Journal scrapbook */
  .home-journal-head { text-align: center; }
  .home-journal-head h4 { font-size: clamp(1.55rem, 7vw, 2.2rem); }
  .home-journal-kicker { display: block; margin-bottom: 10px; }
  .home-journal-head p { font-size: 14px; line-height: 1.8; }
  .scrapbook-card { margin-bottom: 0; }

  /* Editorial gallery text */
  .home-gallery-head { text-align: center; }
  .home-gallery-title { font-size: clamp(1.2rem, 5vw, 1.6rem); }
  .home-gallery-head p { font-size: 14px; }

  /* Focus section head */
  .home-focus-head { text-align: center; }
  .home-focus-head h4 { font-size: clamp(1.5rem, 6.5vw, 2.2rem); }
  .home-focus-head span { font-size: 14px; line-height: 1.8; }
}

/* ── Comprehensive mobile polish ──────────────────────────────────────── */
@media (max-width: 768px) {

  /* ── Treatments hero (shop_04.html) ── */
  .treatments-hero {
    height: 48vh;
    min-height: 280px;
  }
  .treatments-hero-inner .container {
    padding-left: 24px;
    padding-right: 24px;
    text-align: center;
  }
  .treatments-hero h4 {
    font-size: clamp(1.6rem, 7vw, 2.4rem) !important;
    letter-spacing: 0.06em;
    margin-bottom: 10px;
  }
  .treatments-hero p {
    font-size: 14px !important;
    line-height: 1.75;
    max-width: 480px;
    margin: 0 auto;
  }

  /* ── Category overview (shop_04.html) ── */
  .cat-overview-section {
    padding: 52px 0 64px;
  }
  .cat-overview-head {
    margin-bottom: 32px;
    padding: 0 8px;
  }
  .cat-overview-title {
    font-size: clamp(1.5rem, 6.5vw, 2rem);
  }

  /* ── Category cards — tighter on small screens ── */
  .cat-card-name {
    font-size: 13px;
  }
  .cat-card-count {
    font-size: 8px;
  }
  .cat-card-body {
    padding: 14px 12px 16px;
  }

  /* ── Category detail list section (category.html) ── */
  .cat-detail-list-section .container {
    padding-left: 16px;
    padding-right: 16px;
  }
  .cat-list-meta {
    margin-bottom: 28px;
  }
  .cat-list-meta-title {
    font-size: clamp(1.4rem, 6vw, 1.9rem);
  }
  .cat-list-header-row {
    padding: 0 0 10px;
  }
  .cat-book-wrap {
    margin-top: 36px;
  }
  .cat-book-btn {
    padding: 14px 36px;
    font-size: 10px;
  }

  /* ── Category intro & FAQ ── */
  .cat-info-intro p,
  .cat-faq-a p {
    font-size: 14px;
    line-height: 1.8;
  }
  .cat-faq-q {
    font-size: 13px;
    padding: 16px 0;
  }

  /* ── Signature treatments glance cards ── */
  .glance-item {
    padding: 12px 10px 14px;
  }
  .glance-item span {
    font-size: 10px !important;
    line-height: 1.4;
    word-break: normal;
    overflow-wrap: normal;
  }

  /* ── Blog / Beauty Journal (blog-list_01.html) ── */
  .journal-cover-copy h2 {
    font-size: clamp(1.8rem, 8vw, 3rem);
    line-height: 1.15;
  }
  .journal-cover-copy p {
    font-size: 14px;
  }
  .journal-card-copy h3 {
    font-size: clamp(1.4rem, 6vw, 2rem);
  }
  .journal-card-copy p {
    font-size: 14px;
    line-height: 1.75;
  }
  .journal-quote-break p {
    font-size: clamp(1.2rem, 5.5vw, 1.7rem);
    line-height: 1.45;
  }

  /* ── Product detail / Signature treatments ── */
  .signature-arc-stage {
    gap: 16px;
    padding: 0 16px 16px;
  }

  /* ── Studio team accordion (about-us_01.html) ── */
  .team-accordion-overlay h4 {
    font-size: 20px;
  }
  .team-accordion-overlay p {
    font-size: 13px;
  }
  .studio-team-accordion {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }

  /* ── Sub-banner (page header on non-homepage pages) ── */
  .sub-bnr {
    min-height: 220px;
    padding: 80px 0 60px;
  }

  /* ── Brands & Partners section — homepage + about page ── */
  .studio-brand-ribbon {
    padding: 44px 0 52px;
  }
  .studio-brand-heading {
    margin-bottom: 28px;
    padding: 0 8px;
  }
  .studio-brand-title {
    font-size: clamp(1.4rem, 6vw, 2rem);
    margin-bottom: 10px;
  }
  .studio-brand-subtitle {
    font-size: 13px;
    line-height: 1.7;
  }
  /* 2 columns instead of 4 — chips stay readable */
  .studio-brand-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .studio-brand-chip {
    min-height: 64px;
    border-radius: 16px;
    padding: 10px 8px;
  }
  .studio-brand-chip span {
    font-size: 12px;
    letter-spacing: 0.1em;
    text-align: center;
  }

  /* ── About page — studio intro (studio-vogue-hero) ── */
  .studio-vogue-copy .studio-vogue-kicker {
    font-size: 9px;
    letter-spacing: 0.16em;
    white-space: nowrap;
  }

  .studio-vogue-intro {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }
  .studio-vogue-hero {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 20px;
    border-radius: 22px;
  }
  .studio-vogue-portrait {
    height: 280px;
    min-height: 0;
    border-radius: 18px;
  }
  .studio-vogue-copy h2 {
    font-size: clamp(1.5rem, 6.5vw, 2rem);
    margin-bottom: 12px;
  }
  .studio-vogue-copy p {
    font-size: 14px;
    line-height: 1.75;
    margin-bottom: 18px;
  }

  /* ── About page — specialties grid ── */
  .studio-specialties {
    padding-top: 52px !important;
    padding-bottom: 60px !important;
  }
  .studio-specialty-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .studio-specialty-card {
    min-height: 0;
    padding: 24px 20px;
    border-radius: 18px;
  }
  .studio-specialty-card i {
    width: 48px;
    height: 48px;
    font-size: 22px;
    margin-bottom: 14px;
    border-radius: 14px;
  }
  .studio-section-heading h3 {
    font-size: clamp(1.4rem, 6vw, 1.9rem);
  }
  .studio-section-heading p {
    font-size: 14px;
    line-height: 1.75;
  }
}

/* ── 480px and below: extra small phones ── */
@media (max-width: 480px) {
  /* Treatments hero: very compact on small phones */
  .treatments-hero {
    height: 44vh;
    min-height: 240px;
  }
  .treatments-hero h4 {
    font-size: clamp(1.3rem, 7.5vw, 1.9rem) !important;
  }
  .treatments-hero p {
    font-size: 13px !important;
  }

  /* Category cards: single column if very narrow */
  .cat-card-name {
    font-size: 12px;
  }

  /* Book button on tiny screens */
  .cat-book-btn {
    display: inline-block;
    text-align: center;
    padding: 12px 28px;
    font-size: 10px;
    max-width: 260px;
    width: 100%;
  }

  /* Footer rights text */
  .rights p {
    font-size: 12px;
    line-height: 1.7;
    text-align: center;
  }

}

/* Touch interaction parity (hover → tap) */
@media (hover: none) and (pointer: coarse) {
  .focus-card:active {
    box-shadow: 0 30px 70px rgba(109, 87, 72, 0.16);
  }

  .focus-card:active img {
    transform: scale(1.04);
  }

  .brand-ghost-item:active {
    filter: blur(0);
  }

  .kinetic-row:active .kinetic-row-media img {
    transform: scale(1.02);
  }
}

/* WhatsApp button — compact on all mobile sizes */
@media (max-width: 768px) {
  .df-wa-btn {
    padding: 11px 24px !important;
    font-size: 11px !important;
    letter-spacing: 0.12em !important;
    white-space: normal !important;
    display: inline-block !important;
    width: auto !important;
    max-width: 260px !important;
  }
}

@media (max-width: 480px) {
  .df-wa-btn {
    padding: 10px 20px !important;
    font-size: 10px !important;
    max-width: 240px !important;
  }
}
