
:root {
  --page-max: 1500px;
  --black: #101010;
  --cream: #fbf1ea;
  --cream-light: #fff8f2;
  --cream-card: #f4e4d9;
  --brown: #2b1812;
  --brown-btn: #4a2416;
  --gold: #a87556;
  --gold-dark: #7a3f29;
  --text: #201916;
  --muted: #5f5650;
  --line: rgba(168, 117, 86, 0.24);
  --line-strong: rgba(168, 117, 86, 0.42);
  --shadow: 0 18px 42px rgba(36, 22, 14, 0.11);
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; scroll-behavior: smooth; }
body { font-family: "Inter", Arial, sans-serif; color: var(--text); background: #f6ebe4; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
.section-gap { width: min(100%, var(--page-max)); height: 48px; margin: 0 auto; background: linear-gradient(180deg, #fffaf6, #fbf1ea); }
.section-gap--before-selling-points { height: 54px; }
.section-gap--before-shop-by-style { height: 50px; }
.section-gap--before-luxury-hair-texture { height: 54px; }
.section-gap--before-brand-story { height: 56px; }
.section-gap--before-trust-reviews { height: 50px; }
.section-gap--before-faq { height: 56px; }
.section-gap--before-footer { height: 44px; }

/* 01 Header */
.ailsas-header { position: relative; z-index: 30; width: min(100%, var(--page-max)); margin: 0 auto; background: #fff; box-shadow: 0 1px 0 rgba(17,17,17,.08); }
.top-strip { height: 48px; display: flex; align-items: center; justify-content: center; gap: 34px; color: #fff; background: var(--black); border-radius: 58px 58px 0 0; font-size: 13px; font-weight: 600; }
.top-strip a { display: inline-flex; align-items: center; gap: 8px; opacity: .96; }
.top-strip img { width: 18px; height: 18px; filter: brightness(0) invert(1); }
.top-strip span { width: 1px; height: 18px; background: rgba(255,255,255,.36); }
.brand-row { min-height: 84px; display: grid; grid-template-columns: 320px 1fr 150px; align-items: center; column-gap: 20px; padding: 0 36px; background: radial-gradient(circle at 12% 12%, rgba(184,133,95,.07), transparent 26%), #fff; }
.site-logo { justify-self: start; font-family: "Playfair Display", Georgia, serif; font-size: 56px; line-height: 1; font-weight: 500; letter-spacing: -.075em; color: #000; }
.site-logo span { color: #8f5a8f; }
.header-actions { grid-column: 3; justify-self: end; display: flex; align-items: center; gap: 23px; }
.header-actions a { display: inline-flex; align-items: center; justify-content: center; color: #050505; }
.header-actions img { width: 28px; height: 28px; }
.mobile-toggle { display: none; }
.main-nav { position: relative; min-height: 56px; border-top: 1px solid rgba(17,17,17,.04); background: #fff; }
.main-nav > ul { max-width: 1120px; margin: 0 auto; padding: 0 28px; list-style: none; display: flex; align-items: center; justify-content: center; gap: clamp(18px,2vw,30px); min-height: 56px; }
.main-nav li { position: relative; flex: 0 0 auto; }
.main-nav a, .main-nav button { font: inherit; border: 0; background: transparent; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; padding: 19px 0 16px; color: #111; font-size: 13px; line-height: 1; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; white-space: nowrap; }
.main-nav button::after { content: ""; width: 7px; height: 7px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg) translateY(-2px); margin-left: 2px; }
.main-nav a:hover, .main-nav button:hover, .has-dropdown.is-open > button { color: var(--gold); }
.dropdown { position: absolute; top: calc(100% - 3px); left: 50%; min-width: 260px; padding: 18px 22px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow); transform: translate(-50%, 12px); opacity: 0; visibility: hidden; transition: opacity .18s ease, transform .18s ease, visibility .18s ease; }
.dropdown a { display: block; padding: 10px 0; font-size: 14px; line-height: 1.25; font-weight: 600; letter-spacing: 0; text-transform: none; color: #201915; }
.has-dropdown:hover .dropdown, .has-dropdown:focus-within .dropdown, .has-dropdown.is-open .dropdown { opacity: 1; visibility: visible; transform: translate(-50%, 0); }
.mega-menu { display: none; }
.demo-space { display: none; }

/* 02 Hero Banner */
.la-hero-pc { position: relative; width: min(100%, var(--page-max)); height: 700px; margin: 0 auto; overflow: hidden; background: #f7e8dc; isolation: isolate; }
.hero-bg { position: absolute; inset: 0; z-index: 0; background-image: url("./assets/02-hero-banner/images/hero-bg-pc-1500x700.webp"); background-size: cover; background-position: center; }
.hero-copy { position: relative; z-index: 3; width: 46%; min-width: 560px; height: 100%; padding: 125px 30px 74px 116px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.hero-ornament { display: flex; align-items: center; justify-content: center; gap: 14px; color: var(--gold); margin-bottom: 18px; }
.hero-ornament span { width: 102px; height: 1px; background: rgba(154,106,79,.45); }
.hero-ornament b { font-size: 21px; line-height: 1; font-weight: 400; }
.hero-brand { margin: 0; font-family: "Playfair Display", Georgia, serif; font-size: 83px; line-height: .92; font-weight: 500; color: #9a6a4f; letter-spacing: -.045em; }
.hero-tagline { margin: 18px 0 0; padding: 0 34px; font-size: 16px; font-weight: 500; letter-spacing: .30em; text-transform: uppercase; color: #9a6a4f; position: relative; }
.hero-product-note { margin: 54px 0 0; display: flex; align-items: center; gap: 26px; color: #9a6a4f; font-size: 16px; font-weight: 500; letter-spacing: .36em; text-transform: uppercase; }
.hero-product-note span { width: 86px; height: 1px; background: rgba(154,106,79,.32); }
.hero-copy h1 { margin: 34px 0 0; font-family: "Playfair Display", Georgia, serif; font-size: 50px; line-height: 1.05; font-weight: 500; letter-spacing: -.045em; color: var(--brown); }
.hero-subtitle { margin: 31px 0 0; font-size: 22px; line-height: 1.35; font-weight: 400; color: #21130f; }
.hero-actions { margin-top: 47px; display: flex; justify-content: center; gap: 18px; }
.btn { width: 220px; height: 62px; display: inline-flex; align-items: center; justify-content: center; border-radius: 5px; text-decoration: none; text-transform: uppercase; font-size: 16px; font-weight: 800; letter-spacing: .02em; transition: transform .2s ease, box-shadow .2s ease; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(74,36,22,.18); }
.btn-primary { background: linear-gradient(180deg,#5a2b1a,#4a2416); color: #fff; border: 1px solid #4a2416; }
.btn-secondary { background: rgba(230,198,178,.62); color: #4a2416; border: 1px solid rgba(154,106,79,.72); }
.hero-models { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.hero-model { position: absolute; bottom: -2px; object-fit: contain; object-position: bottom center; filter: drop-shadow(0 18px 30px rgba(65,33,18,.12)); }
.hero-model-main { width: 44%; max-width: 720px; height: auto; right: 26.6%; z-index: 3; }
.hero-model-secondary { width: 35.2%; max-width: 560px; height: auto; right: 4.2%; z-index: 2; }

/* Shared light sections */
.la-benefits, .la-style, .la-texture, .la-story, .la-trust, .la-faq { width: min(100%, var(--page-max)); margin: 0 auto; overflow: hidden; background: radial-gradient(circle at 12% 8%, rgba(205,151,112,.13), transparent 28%), radial-gradient(circle at 88% 12%, rgba(205,151,112,.10), transparent 30%), linear-gradient(180deg, #fff8f2 0%, #fbf1ea 100%); }

/* 03 Selling Points */
.la-benefits__inner { max-width: var(--page-max); margin: 0 auto; padding: 62px 54px 78px; text-align: center; }
.la-benefits__eyebrow { margin: 0 auto 22px; display: flex; align-items: center; justify-content: center; gap: 17px; font-size: 17px; font-weight: 800; letter-spacing: .29em; text-transform: uppercase; color: var(--gold-dark); }
.la-benefits__eyebrow span { width: 66px; height: 1px; background: rgba(168,117,86,.38); }
.la-benefits__eyebrow b { color: #cc835f; font-size: 24px; font-weight: 400; letter-spacing: 0; }
.la-benefits__title { margin: 0 auto 62px; max-width: 1020px; font-family: "Playfair Display", Georgia, serif; font-size: clamp(52px,5.4vw,78px); line-height: 1.04; font-weight: 600; letter-spacing: -.04em; color: var(--brown); }
.la-benefits__grid { display: grid; grid-template-columns: repeat(6,1fr); align-items: start; }
.la-benefit-card { position: relative; min-height: 298px; padding: 0 28px; transition: opacity .7s ease, transform .7s ease; }
.la-benefit-card:not(:last-child) { border-right: 1px solid var(--line); }
.la-benefit-card img { display: block; width: 112px; height: 112px; margin: 0 auto 24px; object-fit: contain; }
.la-benefit-card h2, .la-benefit-card h3 { margin: 0; min-height: 58px; font-family: "Playfair Display", Georgia, serif; font-size: 25px; line-height: 1.14; font-weight: 700; letter-spacing: -.035em; color: var(--brown); }
.la-benefit-card i { display: block; width: 62px; height: 14px; margin: 7px auto 13px; background: linear-gradient(45deg, transparent 38%, #cc835f 38% 62%, transparent 62%) center / 8px 8px no-repeat; }
.la-benefit-card p { margin: 0 auto; max-width: 205px; font-size: 17px; line-height: 1.55; font-weight: 500; color: #151515; }

/* 04 Shop by Style */
.la-style__inner { max-width: var(--page-max); margin: 0 auto; padding: 46px 36px 54px; }
.la-style__header { text-align: center; margin-bottom: 42px; }
.la-style__eyebrow { margin: 0; display: flex; align-items: center; justify-content: center; gap: 18px; font-size: 17px; font-weight: 800; letter-spacing: .34em; text-transform: uppercase; color: var(--gold-dark); }
.la-style__eyebrow span { width: 40px; height: 1px; background: rgba(168,117,86,.38); }
.la-style__diamond { display: block; width: 10px; height: 10px; margin: 19px auto 12px; background: rgba(168,117,86,.48); transform: rotate(45deg); }
.la-style h2#style-title, .la-style h1 { margin: 0; font-family: "Playfair Display", Georgia, serif; font-size: clamp(52px,5vw,70px); line-height: 1.03; font-weight: 600; letter-spacing: -.045em; color: var(--brown); }
.la-style__subtitle { margin: 17px 0 0; font-size: 26px; line-height: 1.25; font-weight: 500; color: #222; }
.la-style__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.la-style-card { position: relative; min-height: 374px; overflow: hidden; border-radius: 10px; background: radial-gradient(circle at 78% 38%, rgba(255,255,255,.35), transparent 34%), linear-gradient(135deg,#f4e6dd 0%,#f8ece5 100%); box-shadow: 0 1px 0 rgba(122,63,41,.04); transition: opacity .72s ease, transform .72s ease; }
.la-style-card__copy { position: relative; z-index: 2; width: 52%; padding: 78px 0 34px 31px; }
.la-style-card h2 { margin: 0; font-family: "Playfair Display", Georgia, serif; font-size: 41px; line-height: 1; font-weight: 500; letter-spacing: -.045em; color: var(--brown); }
.la-style-card__copy i { display: block; width: 150px; height: 16px; margin: 25px 0 31px; background: linear-gradient(45deg, transparent 38%, #cc835f 38% 62%, transparent 62%) 25px center / 8px 8px no-repeat; border-top: 1px solid rgba(168,117,86,.30); transform: translateY(8px); }
.la-style-card p { margin: 0; font-size: 16px; line-height: 1.58; font-weight: 500; color: #222; }
.la-style-card a { display: inline-flex; align-items: center; gap: 13px; margin-top: 58px; color: var(--brown); text-decoration: none; text-transform: uppercase; font-size: 14px; font-weight: 800; border-bottom: 1px solid rgba(74,36,22,.88); padding-bottom: 5px; }
.la-style-card img { position: absolute; z-index: 1; right: -24px; bottom: 0; width: 56%; height: 100%; object-fit: contain; object-position: bottom right; pointer-events: none; }
.la-style__all { text-align: center; margin-top: 23px; }
.la-style__all-button { width: 250px; height: 50px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(168,117,86,.62); border-radius: 6px; background: rgba(255,248,242,.40); color: var(--brown); text-transform: uppercase; font-size: 15px; font-weight: 800; letter-spacing: .08em; }

/* 05 Luxury Hair Texture */
.la-texture__inner { max-width: var(--page-max); min-height: 650px; margin: 0 auto; display: grid; grid-template-columns: 48% 52%; align-items: stretch; }
.la-texture__copy { position: relative; z-index: 2; padding: 90px 30px 58px 86px; }
.la-texture__eyebrow { margin: 0; font-size: 17px; font-weight: 700; letter-spacing: .42em; text-transform: uppercase; color: var(--gold-dark); }
.la-texture__ornament { width: 165px; height: 22px; margin: 19px 0 5px 69px; display: flex; align-items: center; justify-content: center; gap: 16px; }
.la-texture__ornament span { width: 65px; height: 1px; background: rgba(168,117,86,.25); }
.la-texture__ornament b { width: 9px; height: 9px; display: block; transform: rotate(45deg); background: rgba(168,117,86,.48); }
.la-texture h2#texture-title, .la-texture h1 { margin: 0; max-width: 720px; font-family: "Playfair Display", Georgia, serif; font-size: clamp(52px,5.1vw,76px); line-height: 1.06; font-weight: 600; letter-spacing: -.045em; color: var(--brown); }
.la-texture__intro { margin: 32px 0 0; max-width: 610px; font-size: 22px; line-height: 1.45; font-weight: 500; color: #222; }
.la-texture__features { margin-top: 44px; display: grid; grid-template-columns: repeat(4,1fr); max-width: 620px; }
.la-texture__feature { min-height: 180px; padding: 0 20px; text-align: center; border-right: 1px solid var(--line); }
.la-texture__feature:last-child { border-right: 0; }
.la-texture__feature img { width: 74px; height: 74px; margin: 0 auto 15px; object-fit: contain; }
.la-texture__feature h2, .la-texture__feature h3 { margin: 0; min-height: 48px; font-size: 18px; line-height: 1.16; font-weight: 800; color: var(--brown); }
.la-texture__feature p { margin: 13px auto 0; max-width: 130px; font-size: 15px; line-height: 1.35; font-weight: 500; color: #222; }
.la-texture__button { margin-top: 38px; width: 282px; height: 54px; display: inline-flex; align-items: center; justify-content: center; gap: 22px; border: 1px solid var(--gold-dark); border-radius: 5px; background: rgba(255,248,242,.68); color: var(--brown); text-transform: uppercase; font-size: 16px; font-weight: 800; }
.la-texture__visual { min-height: 650px; }
.la-texture__visual picture, .la-texture__visual img { display: block; width: 100%; height: 100%; }
.la-texture__visual img { object-fit: cover; object-position: center right; }

/* 06 Brand Story */
.la-story__inner { max-width: var(--page-max); min-height: 720px; margin: 0 auto; display: grid; grid-template-columns: 52% 48%; align-items: stretch; }
.la-story__image { min-height: 720px; overflow: hidden; }
.la-story__image picture, .la-story__image img { display: block; width: 100%; height: 100%; }
.la-story__image img { object-fit: cover; object-position: center left; }
.la-story__copy { padding: 48px 72px 42px 76px; background: radial-gradient(circle at 35% 12%, rgba(255,255,255,.66), transparent 34%), linear-gradient(90deg, rgba(255,246,239,.78), rgba(251,239,231,.96)); }
.la-story__eyebrow { margin: 0; font-size: 17px; font-weight: 700; letter-spacing: .42em; text-transform: uppercase; color: var(--gold-dark); }
.la-story__ornament { width: 190px; height: 22px; margin: 14px 0 17px 132px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.la-story__ornament span { width: 72px; height: 1px; background: rgba(168,117,86,.22); }
.la-story__ornament b { width: 7px; height: 7px; border: 1px solid rgba(168,117,86,.65); transform: rotate(45deg); }
.la-story h2#story-title, .la-story h1 { margin: 0 0 30px; font-family: "Playfair Display", Georgia, serif; font-size: clamp(60px,5.2vw,82px); line-height: 1.02; font-weight: 500; letter-spacing: -.05em; color: var(--brown); }
.la-story__text p { margin: 0 0 20px; font-size: 19px; line-height: 1.43; font-weight: 500; color: #161616; }
.la-story__text strong { color: var(--gold-dark); font-weight: 800; }
.la-story__values { margin-top: 32px; display: grid; grid-template-columns: 1fr 1fr 1.16fr; gap: 0; max-width: 650px; }
.la-story-value { display: grid; grid-template-columns: 58px 1fr; gap: 12px; align-items: center; padding-right: 18px; }
.la-story-value:not(:last-child) { border-right: 1px solid var(--line); margin-right: 20px; }
.la-story-value img { width: 56px; height: 56px; object-fit: contain; }
.la-story-value h2, .la-story-value h3 { margin: 0 0 3px; font-size: 13px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: var(--brown); }
.la-story-value p { margin: 0; font-size: 13px; line-height: 1.25; font-weight: 500; }
.la-story__actions { margin-top: 33px; display: flex; gap: 24px; }
.la-story__button { height: 58px; min-width: 244px; padding: 0 28px; display: inline-flex; align-items: center; justify-content: center; border-radius: 5px; text-transform: uppercase; font-size: 16px; font-weight: 800; }
.la-story__button--primary { background: linear-gradient(180deg,#5a2b1a,#4a2416); color: #fff; }
.la-story__button--secondary { background: rgba(230,198,178,.66); border: 1px solid rgba(168,117,86,.45); color: var(--brown); }

/* 07 Trust / Reviews */
.la-trust__inner { max-width: var(--page-max); margin: 0 auto; padding: 25px 92px 20px; }
.la-trust__header { text-align: center; }
.la-trust__eyebrow { margin: 0; display: flex; align-items: center; justify-content: center; gap: 18px; color: var(--brown); font-size: 17px; font-weight: 800; letter-spacing: .36em; text-transform: uppercase; }
.la-trust__eyebrow span { width: 38px; height: 1px; background: rgba(122,63,41,.48); }
.la-trust__diamond { display: block; width: 8px; height: 8px; margin: 15px auto 0; border: 1px solid rgba(168,117,86,.65); transform: rotate(45deg); }
.la-trust h2#trust-title, .la-trust h1 { margin: -6px 0 14px; font-family: "Playfair Display", Georgia, serif; font-size: clamp(50px,4.9vw,74px); line-height: 1.02; font-weight: 500; letter-spacing: -.045em; color: var(--brown); }
.la-trust__intro { margin: 0; font-size: 17px; line-height: 1.4; font-weight: 600; }
.la-trust__services { margin-top: 33px; display: grid; grid-template-columns: repeat(4,1fr); }
.la-service { text-align: center; padding: 0 48px; min-height: 150px; border-right: 1px solid var(--line); }
.la-service:last-child { border-right: 0; }
.la-service img { width: 72px; height: 72px; object-fit: contain; margin-bottom: 10px; }
.la-service h2, .la-service h3 { margin: 0 0 8px; font-size: 14px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--brown); }
.la-service p { margin: 0 auto; max-width: 210px; font-size: 13px; line-height: 1.55; font-weight: 600; }
.la-trust__reviews { margin-top: 28px; padding-top: 18px; border-top: 1px solid rgba(168,117,86,.20); display: grid; grid-template-columns: 220px 1fr 382px; gap: 42px; align-items: center; }
.la-rating h2 { margin: 0; font-family: "Playfair Display", Georgia, serif; font-size: 32px; line-height: 1.05; font-weight: 600; color: var(--brown); }
.la-rating p { margin: 0 0 15px; font-size: 13px; line-height: 1.45; font-weight: 600; }
.la-stars { color: var(--gold-dark); letter-spacing: .18em; font-size: 21px; line-height: 1; margin: 0 0 14px; }
.la-customer-gallery { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; text-align: center; }
.la-customer-gallery img { width: 100%; aspect-ratio: 1/1; border-radius: 6px; object-fit: cover; }
.la-handwriting { grid-column: 1 / -1; margin: 8px 0 0; font-family: "Allura", cursive; font-size: 25px; line-height: 1; color: var(--gold-dark); }
.la-testimonial { min-height: 205px; padding: 26px 42px; border: 1px solid rgba(168,117,86,.28); border-radius: 10px; text-align: center; background: rgba(255,247,241,.36); margin: 0; }
.la-testimonial > span { display: block; height: 32px; font-family: Georgia, serif; font-size: 78px; line-height: .85; color: var(--gold-dark); }
.la-testimonial p { margin: 8px auto 18px; max-width: 330px; font-size: 14px; line-height: 1.55; font-weight: 700; }
.la-trust__promise { background: rgba(244,228,218,.78); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.la-trust__promise-inner { max-width: var(--page-max); margin: 0 auto; padding: 17px 92px; display: grid; grid-template-columns: repeat(4,1fr); }
.la-trust__promise article { display: grid; grid-template-columns: 48px 1fr; gap: 14px; align-items: center; min-height: 52px; padding: 0 34px; border-right: 1px solid var(--line); }
.la-trust__promise article:last-child { border-right: 0; }
.la-trust__promise img { width: 43px; height: 43px; object-fit: contain; }
.la-trust__promise h2, .la-trust__promise h3 { margin: 0; font-size: 13px; line-height: 1.35; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--brown); }
.la-trust__footer { max-width: var(--page-max); margin: 0 auto; padding: 13px 20px 20px; text-align: center; }
.la-trust__footer p { margin: 0 0 7px; font-size: 14px; line-height: 1.2; letter-spacing: .04em; }

/* 08 FAQ */
.la-faq__inner { width: min(100%, var(--page-max)); min-height: 640px; margin: 0 auto; padding: 86px 86px 92px; display: grid; grid-template-columns: 37% 63%; gap: 78px; align-items: start; }
.la-faq__intro { position: sticky; top: 34px; }
.la-faq__eyebrow { margin: 0 0 22px; color: var(--gold-dark); font-size: 15px; font-weight: 800; letter-spacing: .36em; text-transform: uppercase; }
.la-faq__intro h2, .la-faq__intro h1 { margin: 0; max-width: 430px; font-family: "Playfair Display", Georgia, serif; font-size: 58px; line-height: 1.03; font-weight: 600; letter-spacing: -.045em; color: var(--brown); }
.la-faq__intro > p { max-width: 455px; margin: 26px 0 0; color: var(--muted); font-size: 17px; line-height: 1.65; font-weight: 500; }
.la-faq__cards { margin-top: 32px; display: grid; gap: 13px; max-width: 430px; }
.la-faq__cards article { display: grid; grid-template-columns: 34px 1fr; gap: 13px; align-items: center; padding: 13px 15px; border: 1px solid var(--line); background: rgba(255,255,255,.34); border-radius: 10px; }
.la-faq__cards img { width: 30px; height: 30px; }
.la-faq__cards span { color: var(--brown); font-size: 14px; font-weight: 700; }
.la-faq__button { width: 260px; height: 58px; margin-top: 30px; display: inline-flex; align-items: center; justify-content: center; gap: 11px; border-radius: 5px; background: linear-gradient(180deg,#5a2b1a,#4a2416); color: #fff; text-transform: uppercase; font-size: 15px; font-weight: 800; letter-spacing: .04em; }
.la-faq__button img { width: 24px; height: 24px; filter: brightness(0) invert(1); }
.la-faq__accordion { border-top: 1px solid var(--line-strong); }
.faq-item { border-bottom: 1px solid var(--line); background: transparent; transition: background .2s ease; }
.faq-item.is-open { background: linear-gradient(90deg, rgba(255,255,255,.32), rgba(255,255,255,0)); }
.faq-question { width: 100%; min-height: 78px; padding: 0; border: 0; background: transparent; color: var(--brown); cursor: pointer; display: grid; grid-template-columns: 54px 1fr 34px; gap: 22px; align-items: center; text-align: left; font-family: "Inter", Arial, sans-serif; font-size: 18px; line-height: 1.32; font-weight: 800; letter-spacing: .02em; }
.faq-question span { color: var(--gold); font-family: "Playfair Display", Georgia, serif; font-size: 22px; font-weight: 600; }
.faq-question i { justify-self: end; width: 28px; height: 28px; border: 1px solid var(--line-strong); border-radius: 50%; position: relative; }
.faq-question i::before, .faq-question i::after { content: ""; position: absolute; background: var(--gold-dark); left: 8px; right: 8px; top: 50%; height: 1.5px; transform: translateY(-50%); }
.faq-question i::after { top: 8px; bottom: 8px; left: 50%; width: 1.5px; height: auto; right: auto; transform: translateX(-50%); }
.faq-item.is-open .faq-question i::after { opacity: 0; }
.faq-answer { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .28s ease; }
.faq-item.is-open .faq-answer { grid-template-rows: 1fr; }
.faq-answer > p { overflow: hidden; margin: 0; padding: 0 68px 26px 76px; max-width: 760px; color: var(--muted); font-size: 16px; line-height: 1.65; font-weight: 500; }

/* 09 Footer */
.demo-content { display:none; }
.ailsas-footer { width: min(100%, var(--page-max)); margin: 0 auto; background: var(--cream); overflow: hidden; box-shadow: 0 -1px 0 rgba(0,0,0,.06); }
.footer-newsletter { background: radial-gradient(circle at 20% 0, rgba(255,255,255,.09), transparent 28%), radial-gradient(circle at 82% 0, rgba(255,255,255,.08), transparent 30%), var(--black); color: #fff; text-align: center; padding: 44px 24px 42px; }
.newsletter-lines { max-width: 1040px; margin: 0 auto 10px; display: flex; align-items: center; justify-content: center; gap: 16px; color: var(--gold); }
.newsletter-lines span { width: min(24vw,270px); height: 1px; background: rgba(168,117,86,.62); }
.newsletter-lines b { font-size: 20px; font-weight: 400; }
.footer-newsletter h2 { margin: 0; font-family: "Playfair Display", Georgia, serif; font-size: 40px; line-height: 1.1; font-weight: 600; letter-spacing: -.035em; }
.footer-newsletter h2 em { color: var(--gold); font-style: normal; }
.footer-newsletter p { margin: 12px 0 24px; font-size: 16px; line-height: 1.5; color: rgba(255,255,255,.86); }
.newsletter-form { width: min(100%,520px); height: 54px; margin: 0 auto; display: grid; grid-template-columns: 1fr 62px; border: 1px solid rgba(168,117,86,.74); background: rgba(255,255,255,.02); }
.newsletter-form input { min-width: 0; border: 0; outline: 0; background: transparent; color: #fff; padding: 0 22px; font-size: 18px; font-family: inherit; }
.newsletter-form input::placeholder { color: rgba(255,255,255,.74); }
.newsletter-form button { border: 0; background: transparent; color: var(--gold); font-size: 34px; cursor: pointer; }
.footer-main { background: radial-gradient(circle at 8% 6%, rgba(168,117,86,.10), transparent 26%), radial-gradient(circle at 92% 10%, rgba(168,117,86,.08), transparent 28%), linear-gradient(180deg,#fffaf6,#fbf4ee); padding: 42px 78px 18px; }
.footer-grid { display: grid; grid-template-columns: 1.28fr 1fr 1fr 1.15fr; gap: 52px; max-width: 1320px; margin: 0 auto; }
.footer-column { position: relative; padding-right: 34px; }
.footer-column:not(:last-child)::after { content: ""; position: absolute; right: 0; top: 12px; width: 1px; height: 82%; background: var(--line); }
.footer-column h2 { margin: 0 0 20px; display: flex; align-items: center; gap: 12px; font-family: "Playfair Display", Georgia, serif; font-size: 27px; line-height: 1.1; font-weight: 600; color: var(--brown); }
.footer-column h2 img { width: 28px; height: 28px; }
.contact-intro { display: block; margin: 0 0 20px; font-size: 14px; line-height: 1.65; font-weight: 500; color: #2d2d2d; }
.contact-card { display: grid; grid-template-columns: 28px 1fr; gap: 13px; padding: 15px 0; border-top: 1px solid rgba(168,117,86,.18); color: #262626; font-size: 14px; line-height: 1.58; font-weight: 500; }
.contact-card img { width: 24px; height: 24px; margin-top: 1px; }
.contact-card strong { color: #111; font-weight: 800; }
.footer-column ul { margin: 0; padding: 0; list-style: none; }
.footer-column li { margin: 0 0 16px; }
.footer-column li a { display: inline-flex; align-items: center; gap: 11px; color: #26211e; font-size: 15px; line-height: 1.2; font-weight: 500; transition: color .18s ease, transform .18s ease; }
.footer-column li a::before { content: "›"; color: var(--gold); font-size: 18px; }
.footer-column li a:hover, .contact-card:hover, .contact-intro:hover { color: var(--gold); }
.social-row { max-width: 1320px; margin: 36px auto 0; display: grid; grid-template-columns: 1fr repeat(6,44px) 1fr; align-items: center; gap: 22px; }
.social-row > span { height: 1px; background: var(--line); }
.social-row a { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--line-strong); border-radius: 50%; color: #111; background: rgba(255,255,255,.42); }
.social-row img { width: 22px; height: 22px; }
.footer-promises { background: rgba(246,232,222,.88); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.promise-inner { max-width: 1320px; margin: 0 auto; padding: 18px 40px; display: grid; grid-template-columns: repeat(4,1fr); }
.promise-inner article { display: grid; grid-template-columns: 38px 1fr; align-items: center; gap: 13px; min-height: 48px; padding: 0 28px; border-right: 1px solid var(--line-strong); }
.promise-inner article:last-child { border-right: 0; }
.promise-inner img { width: 34px; height: 34px; }
.promise-inner h2 { margin: 0; color: var(--brown); font-size: 12px; line-height: 1.35; font-weight: 800; letter-spacing: .09em; text-transform: uppercase; }
.footer-bottom { padding: 14px 24px 22px; text-align: center; background: var(--cream); }
.footer-bottom p { margin: 0 0 7px; font-size: 14px; line-height: 1.35; color: #222; }
.footer-bottom strong { letter-spacing: .12em; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* Animations */
.la-benefit-card, .la-style-card, .la-texture__feature, .la-story-value, .la-service, .la-rating, .la-customer-gallery, .la-testimonial, .la-trust__promise article { opacity: 0; transform: translateY(12px); transition: opacity .65s ease, transform .65s ease; }
.is-visible { opacity: 1 !important; transform: translateY(0) !important; }

@media (max-width: 1180px) {
  .brand-row { grid-template-columns: 1fr auto; }
  .site-logo { font-size: 46px; }
  .header-actions { grid-column: 2; }
  .main-nav > ul { overflow-x: auto; justify-content: flex-start; max-width: none; padding: 0 24px; }
  .la-hero-pc { height: 620px; }
  .hero-copy { min-width: 500px; padding-left: 70px; padding-top: 102px; }
  .hero-brand { font-size: 68px; }
  .hero-copy h1 { font-size: 42px; }
  .la-benefits__grid { grid-template-columns: repeat(3,1fr); gap: 44px 0; }
  .la-benefit-card:nth-child(3) { border-right: 0; }
  .la-style__grid, .la-texture__inner, .la-story__inner, .la-faq__inner { grid-template-columns: 1fr; }
  .la-style__grid { max-width: 760px; margin: 0 auto; }
  .la-texture__copy, .la-story__copy { padding: 62px 42px 48px; }
  .la-story__image { min-height: 560px; }
  .la-trust__reviews { grid-template-columns: 1fr; text-align: center; gap: 28px; }
  .la-trust__services, .la-trust__promise-inner, .footer-grid, .promise-inner { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 768px) {
  .section-gap { height: 26px; }
  .top-strip { border-radius: 0; height: auto; min-height: 42px; gap: 12px; font-size: 11px; flex-wrap: wrap; padding: 8px 10px; }
  .top-strip span { display: none; }
  .brand-row { min-height: 72px; padding: 0 18px; grid-template-columns: 1fr auto auto; }
  .site-logo { font-size: 39px; }
  .mobile-toggle { display: inline-flex; width: 34px; height: 34px; margin-left: 8px; border: 0; background: transparent; flex-direction: column; justify-content: center; gap: 5px; }
  .mobile-toggle span { width: 24px; height: 2px; background: #111; display: block; }
  .main-nav { display: none; }
  .main-nav.is-mobile-open { display: block; }
  .main-nav > ul { display: block; padding: 10px 22px 22px; }
  .main-nav li { border-bottom: 1px solid rgba(168,117,86,.16); }
  .dropdown { position: static; min-width: 0; border: 0; box-shadow: none; padding: 0 0 12px 14px; transform: none; display: none; opacity: 1; visibility: visible; }
  .has-dropdown.is-open .dropdown { display: block; }
  .la-hero-pc { height: auto; min-height: 780px; }
  .hero-copy { width: 100%; min-width: 0; padding: 50px 22px 380px; }
  .hero-model-main { width: 72%; right: 24%; }
  .hero-model-secondary { width: 52%; right: 0; }
  .la-benefits__grid, .la-texture__features, .la-trust__services, .la-trust__promise-inner, .footer-grid, .promise-inner { grid-template-columns: 1fr; }
  .la-style__grid, .la-customer-gallery { grid-template-columns: repeat(2,1fr); }
  .la-style-card { min-height: 520px; }
  .la-style-card__copy { width: 100%; padding: 34px 24px 0; }
  .la-style-card img { width: 78%; height: 62%; right: 6px; }
  .la-texture__copy, .la-story__copy, .la-faq__inner { padding: 52px 22px 40px; text-align: center; }
  .la-faq__intro { position: static; }
  .footer-main { padding: 34px 20px 18px; }
}


/* =========================================================
   PC FORCE LAYOUT FIX - Lewis & Ailsa
   This block intentionally applies from 769px upward because many
   laptop / browser zoom situations report viewport width under 1181px.
   It overrides the earlier max-width:1180 tablet rules.
   ========================================================= */

@media (min-width: 769px) {
  :root {
    --page-max: 1500px;
  }

  body {
    background: #f6ebe4;
  }

  .ailsas-header,
  .la-hero-pc,
  .la-benefits,
  .la-style,
  .la-texture,
  .la-story,
  .la-trust,
  .la-faq,
  .ailsas-footer,
  .section-gap {
    width: min(100%, 1500px);
    margin-left: auto;
    margin-right: auto;
  }

  .section-gap {
    height: 64px;
    background: linear-gradient(180deg, #fff8f2 0%, #fbf1ea 100%);
  }

  .section-gap--before-selling-points { height: 56px; }
  .section-gap--before-shop-by-style { height: 70px; }
  .section-gap--before-luxury-hair-texture { height: 76px; }
  .section-gap--before-brand-story { height: 76px; }
  .section-gap--before-trust-reviews { height: 70px; }
  .section-gap--before-faq { height: 76px; }
  .section-gap--before-footer { height: 64px; }

  /* Header */
  .top-strip {
    height: 42px;
    font-size: 13px;
  }

  .brand-row {
    min-height: 92px;
    padding: 0 54px;
    grid-template-columns: 360px 1fr 170px;
  }

  .site-logo {
    font-size: 58px;
  }

  .header-actions {
    grid-column: 3;
  }

  .main-nav {
    display: block;
    min-height: 62px;
  }

  .main-nav > ul {
    max-width: 1260px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    justify-content: center;
    gap: clamp(16px, 1.45vw, 27px);
    overflow: visible;
  }

  .main-nav a,
  .main-nav button {
    font-size: 11.5px;
    padding: 22px 0 19px;
    letter-spacing: .04em;
  }

  /* Hero: make text and models fully separated */
  .la-hero-pc {
    height: 700px;
  }

  .hero-copy {
    width: 49%;
    min-width: 0;
    padding: 116px 26px 72px 90px;
    text-align: center;
  }

  .hero-brand {
    font-size: clamp(60px, 4.6vw, 74px);
    line-height: .96;
  }

  .hero-tagline {
    font-size: 13px;
    letter-spacing: .27em;
  }

  .hero-product-note {
    margin-top: 44px;
    font-size: 13px;
    letter-spacing: .32em;
  }

  .hero-copy h1 {
    margin-top: 28px;
    font-size: clamp(38px, 3.35vw, 48px);
    line-height: 1.06;
  }

  .hero-subtitle {
    margin-top: 24px;
    font-size: 18px;
    line-height: 1.4;
  }

  .hero-actions {
    margin-top: 34px;
    gap: 16px;
  }

  .btn {
    width: 190px;
    height: 54px;
    font-size: 14px;
  }

  .hero-model-main {
    width: 31%;
    max-width: 465px;
    right: 23%;
    bottom: -4px;
  }

  .hero-model-secondary {
    width: 25%;
    max-width: 375px;
    right: 4.5%;
    bottom: -4px;
  }

  /* Selling Points */
  .la-benefits__inner {
    padding: 72px 60px 88px;
  }

  .la-benefits__grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 0;
  }

  .la-benefit-card {
    min-height: 290px;
    padding: 0 22px;
  }

  .la-benefit-card:nth-child(3) {
    border-right: 1px solid var(--line);
  }

  .la-benefit-card img {
    width: 100px;
    height: 100px;
  }

  .la-benefit-card h2,
  .la-benefit-card h3 {
    font-size: 21px;
  }

  .la-benefit-card p {
    font-size: 14px;
    line-height: 1.55;
  }

  /* Shop by Style */
  .la-style__inner {
    padding: 60px 54px 68px;
  }

  .la-style__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    max-width: none;
    gap: 28px;
  }

  .la-style-card {
    min-height: 430px;
    border-radius: 12px;
  }

  .la-style-card__copy {
    width: 50%;
    padding: 86px 0 38px 36px;
  }

  .la-style-card h2 {
    font-size: 42px;
  }

  .la-style-card p {
    font-size: 15px;
    line-height: 1.62;
  }

  .la-style-card a {
    margin-top: 60px;
    font-size: 13px;
  }

  .la-style-card img {
    width: 68%;
    height: 100%;
    right: -46px;
    bottom: 0;
    object-fit: contain;
    object-position: bottom right;
  }

  .la-style-card:nth-child(2) img {
    width: 66%;
    right: -34px;
  }

  .la-style-card:nth-child(3) img {
    width: 61%;
    right: -30px;
  }

  /* Luxury texture */
  .la-texture__inner {
    display: grid;
    grid-template-columns: 47% 53%;
    min-height: 690px;
  }

  .la-texture__copy {
    padding: 94px 42px 64px 84px;
    text-align: left;
  }

  .la-texture h2#texture-title,
  .la-texture h1 {
    font-size: clamp(56px, 4.8vw, 72px);
  }

  .la-texture__intro {
    font-size: 19px;
  }

  .la-texture__features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    max-width: 610px;
  }

  .la-texture__visual,
  .la-texture__visual picture,
  .la-texture__visual img {
    min-height: 690px;
  }

  /* Brand Story */
  .la-story__inner {
    display: grid;
    grid-template-columns: 52% 48%;
    min-height: 720px;
  }

  .la-story__image {
    min-height: 720px;
  }

  .la-story__copy {
    padding: 58px 76px 48px 82px;
    text-align: left;
  }

  .la-story h2#story-title,
  .la-story h1 {
    font-size: clamp(60px, 4.9vw, 74px);
    line-height: 1.02;
  }

  .la-story__text p {
    font-size: 16.5px;
    line-height: 1.48;
  }

  .la-story__values {
    grid-template-columns: 1fr 1fr 1.16fr;
  }

  .la-story__button {
    height: 56px;
    min-width: 232px;
    font-size: 14px;
  }

  /* Trust Reviews */
  .la-trust__inner {
    padding: 42px 92px 28px;
  }

  .la-trust__services {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }

  .la-service {
    min-height: 160px;
    padding: 0 40px;
  }

  .la-service img {
    width: 76px;
    height: 76px;
  }

  .la-trust__reviews {
    display: grid;
    grid-template-columns: 230px minmax(500px, 1fr) 390px;
    gap: 42px;
    text-align: left;
  }

  .la-customer-gallery {
    grid-template-columns: repeat(4, minmax(118px, 1fr));
    gap: 14px;
  }

  .la-customer-gallery img {
    aspect-ratio: 1 / 1;
    min-height: 126px;
    object-fit: cover;
    object-position: center top;
    border-radius: 8px;
  }

  .la-testimonial {
    min-height: 220px;
    padding: 30px 40px;
  }

  .la-trust__promise-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    padding: 20px 92px;
  }

  /* FAQ */
  .la-faq__inner {
    display: grid;
    grid-template-columns: 36% 64%;
    gap: 84px;
    padding: 92px 88px 98px;
    text-align: left;
  }

  .la-faq__intro {
    position: sticky;
    top: 34px;
  }

  .la-faq__intro h2,
  .la-faq__intro h1 {
    font-size: 56px;
  }

  .faq-question {
    font-size: 17px;
  }

  /* Footer */
  .footer-grid {
    display: grid;
    grid-template-columns: 1.28fr 1fr 1fr 1.15fr;
  }

  .promise-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }

  .footer-main {
    padding: 48px 78px 22px;
  }
}

/* Very small desktop / big tablet: still keep PC layout, only reduce typography */
@media (min-width: 769px) and (max-width: 1180px) {
  .la-hero-pc {
    height: 620px;
  }

  .hero-copy {
    width: 50%;
    padding: 86px 20px 54px 56px;
  }

  .hero-brand {
    font-size: 56px;
  }

  .hero-copy h1 {
    font-size: 36px;
  }

  .hero-subtitle {
    font-size: 16px;
  }

  .hero-model-main {
    width: 30%;
    right: 23%;
  }

  .hero-model-secondary {
    width: 24%;
    right: 4%;
  }

  .main-nav > ul {
    gap: 12px;
  }

  .main-nav a,
  .main-nav button {
    font-size: 10px;
  }

  .la-benefit-card h2,
  .la-benefit-card h3 {
    font-size: 18px;
  }

  .la-benefit-card p {
    font-size: 12px;
  }

  .la-style-card {
    min-height: 360px;
  }

  .la-style-card__copy {
    padding: 58px 0 28px 24px;
  }

  .la-style-card h2 {
    font-size: 32px;
  }

  .la-style-card p,
  .la-style-card a {
    font-size: 12px;
  }

  .la-trust__reviews {
    grid-template-columns: 190px 1fr 310px;
    gap: 26px;
  }
}
