/* Aline — Cuir Cognac & Crème · Mobile-first */

:root{
  --cognac:           #6B3A1F;
  --cognac-deep:      #4A270F;
  --cognac-light:     #8C4F2A;
  --chocolat:         #2A1810;
  --chocolat-deep:    #1A0E08;
  --bronze:           #B89272;
  --bronze-light:     #D4B391;
  --bronze-deep:      #8A6A52;
  --vermeil:          #A8431E;
  --creme:            #F2E8D4;
  --creme-warm:       #E5D4B8;
  --whisky:           #B17132;
  --cognac-card:      #3A2418;
  --line:             rgba(184, 146, 114, .22);
  --line-strong:      rgba(184, 146, 114, .45);
  --shadow-sm:        0 2px 8px rgba(0, 0, 0, .4);
  --shadow-md:        0 8px 24px rgba(0, 0, 0, .55);
  --shadow-lg:        0 16px 48px rgba(0, 0, 0, .7);
  --glow-cognac:      0 0 22px rgba(107, 58, 31, .55);
  --glow-bronze:      0 0 22px rgba(184, 146, 114, .45);

  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Manrope', system-ui, -apple-system, sans-serif;

  --container: 1200px;
  --container-narrow: 1040px;
  --gutter: 1.25rem;
  --section-y: clamp(3rem, 7vw, 6rem);
  --radius: 6px;
  --radius-lg: 14px;
  --radius-xl: 24px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ margin:0; font-family:var(--sans); font-size:17px; line-height:1.65; color:var(--creme); background:var(--chocolat); -webkit-font-smoothing:antialiased; }
img,svg{ display:block; max-width:100%; height:auto; }
a{ color:var(--bronze); text-decoration:none; }
a:hover{ color:var(--bronze-light); }
button{ font-family:inherit; cursor:pointer; }
ol,ul{ padding-left:1.4rem; }

h1,h2,h3{ font-family:var(--serif); color:var(--creme); line-height:1.15; font-weight:600; letter-spacing:-.01em; margin:0 0 .75em; }
h1{ font-size:clamp(2rem, 5.5vw, 3.5rem); }
h2{ font-size:clamp(1.65rem, 3.5vw, 2.4rem); margin-top:0; }
h3{ font-size:clamp(1.2rem, 2.2vw, 1.5rem); color:var(--bronze); font-style:italic; }
p{ margin:0 0 1em; }
strong{ color:#FFFFFF; font-weight:600; }
em{ color:var(--bronze-light); font-style:italic; }
::selection{ background:var(--cognac); color:var(--creme); }

.age-banner{ background:var(--chocolat-deep); color:var(--bronze); text-align:center; font-size:.78rem; padding:.5rem 1rem; letter-spacing:.02em; border-bottom:1px solid var(--cognac); }
.age-banner strong{ color:var(--bronze); font-weight:700; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--gutter); }
.container-narrow{ max-width:var(--container-narrow); }

.hero{
  position:relative;
  background:
    radial-gradient(ellipse at top right, rgba(107,58,31,.55) 0%, transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(184,146,114,.35) 0%, transparent 60%),
    linear-gradient(135deg, var(--chocolat-deep) 0%, var(--chocolat) 50%, var(--cognac) 100%);
  color:var(--creme);
  overflow:hidden;
}
.hero-image{ position:relative; width:100%; aspect-ratio:3/4; max-height:65vh; overflow:hidden; }
.hero-image::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(42,24,16,0) 0%, rgba(42,24,16,0) 55%, rgba(42,24,16,.85) 100%); pointer-events:none; }
.hero-image img{ width:100%; height:100%; object-fit:cover; object-position:center 25%; filter:contrast(1.05) saturate(1.05); }
.hero-content{ position:relative; padding:2rem var(--gutter) 3rem; text-align:center; max-width:680px; margin:0 auto; }
.brand{ font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--bronze); letter-spacing:.18em; text-transform:uppercase; margin:0 0 .8rem; text-shadow:0 0 12px rgba(184,146,114,.4); }
.hero h1{ color:#FFFFFF; font-size:clamp(2.1rem, 6vw, 3.4rem); font-weight:600; text-shadow:0 2px 18px rgba(0,0,0,.6); }
.hero h1 .accent{ color:var(--bronze-light); font-style:italic; font-weight:700; text-shadow:0 0 18px rgba(184,146,114,.6); }
.hero-sub{ font-size:1.1rem; color:var(--creme-warm); max-width:560px; margin:0 auto 2rem; line-height:1.55; }
.phone-display{ margin-top:1.6rem; display:flex; flex-direction:column; gap:.3rem; }
.phone-number{ font-family:var(--serif); font-size:1.85rem; font-weight:700; color:#FFFFFF; letter-spacing:.04em; text-shadow:0 0 18px rgba(184,146,114,.45); }
.phone-meta{ font-size:.85rem; color:var(--creme-warm); opacity:.85; }

@media(min-width:900px){
  .hero{ display:grid; grid-template-columns:4fr 7fr; align-items:stretch; max-height:620px; overflow:hidden; }
  .hero-image{ aspect-ratio:auto; max-height:620px; height:100%; grid-column:1; overflow:hidden; }
  .hero-image img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; }
  .hero-image::after{ background:linear-gradient(90deg, rgba(42,24,16,0) 60%, rgba(42,24,16,.55) 100%); }
  .hero-content{ grid-column:2; display:flex; flex-direction:column; justify-content:center; text-align:left; padding:2.5rem 3rem; max-width:none; }
  .hero h1{ font-size:clamp(2rem, 3.2vw, 2.6rem); margin-bottom:.5em; line-height:1.18; }
  .hero-sub{ margin:0 0 1.3rem; font-size:1.05rem; }
  .phone-display{ align-items:flex-start; margin-top:1rem; }
  .phone-number{ font-size:1.55rem; }
  .brand{ margin-bottom:.6rem; font-size:1rem; }
  .btn-cta-primary{ align-self:flex-start; }
}
@media(min-width:1280px){ .hero-content{ padding:3rem 4rem; } .hero h1{ font-size:2.7rem; } }

.btn-cta-primary, .btn-cta-secondary, .btn-cta-final{ display:inline-flex; align-items:center; gap:.6rem; padding:1rem 1.8rem; font-family:var(--sans); font-weight:700; font-size:1.05rem; border-radius:var(--radius-xl); border:none; cursor:pointer; text-decoration:none; transition:transform .15s ease, box-shadow .2s ease, background .2s ease; letter-spacing:.01em; }
.btn-icon{ font-size:1.2em; line-height:1; }
.btn-cta-primary{ background:linear-gradient(135deg, var(--cognac) 0%, var(--vermeil) 100%); color:#FFFFFF; box-shadow:var(--glow-cognac), inset 0 1px 0 rgba(255,255,255,.25); font-size:1.15rem; padding:1.1rem 2rem; }
.btn-cta-primary:hover{ transform:translateY(-2px); box-shadow:0 0 32px rgba(107,58,31,.8), inset 0 1px 0 rgba(255,255,255,.25); color:#FFFFFF; }
.btn-cta-secondary{ background:transparent; color:var(--bronze); border:2px solid var(--bronze); box-shadow:var(--glow-bronze); }
.btn-cta-secondary:hover{ background:var(--bronze); color:var(--chocolat); transform:translateY(-2px); }
.btn-cta-final{ background:linear-gradient(135deg, var(--cognac) 0%, var(--whisky) 100%); color:var(--creme); font-size:1.2rem; padding:1.2rem 2.4rem; box-shadow:var(--glow-cognac), 0 8px 28px rgba(0,0,0,.6); }
.btn-cta-final:hover{ transform:translateY(-2px); box-shadow:0 0 38px rgba(107,58,31,.85), 0 8px 28px rgba(0,0,0,.6); color:var(--creme); }

.trust-bar{ background:var(--chocolat-deep); border-top:1px solid var(--cognac); border-bottom:1px solid var(--cognac); padding:2rem 0; position:relative; }
.trust-bar::before, .trust-bar::after{ content:''; position:absolute; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent, var(--cognac), var(--bronze), var(--whisky), transparent); }
.trust-bar::before{ top:-1px; } .trust-bar::after{ bottom:-1px; }
.trust-grid{ display:grid; grid-template-columns:1fr; gap:1.5rem; text-align:center; }
@media(min-width:720px){ .trust-grid{ grid-template-columns:repeat(3,1fr); } }
.trust-item{ padding:0 .5rem; }
.trust-icon{ display:inline-block; font-size:2rem; margin-bottom:.5rem; filter:drop-shadow(0 0 12px rgba(184,146,114,.5)); }
.trust-title{ font-size:1.15rem; font-family:var(--serif); color:var(--bronze); margin:0 0 .3rem; font-weight:700; }
.trust-item p{ font-size:.92rem; color:var(--creme-warm); margin:0; line-height:1.45; }

.section{ padding:var(--section-y) 0; background:var(--chocolat); }
.section-alt{ background:var(--chocolat-deep); }
.section h2{ position:relative; padding-bottom:.6rem; margin-bottom:1.6rem; color:#FFFFFF; }
.section h2::after{ content:''; position:absolute; left:0; bottom:0; width:80px; height:3px; background:linear-gradient(90deg, var(--cognac) 0%, var(--bronze) 100%); }
.section p{ color:var(--creme-warm); font-size:1.05rem; line-height:1.75; }
.section p strong{ color:#FFFFFF; }
@media(min-width:900px){ .section p{ font-size:1.12rem; line-height:1.78; } .section h2{ font-size:2.1rem; } }
@media(min-width:1280px){ .section p{ font-size:1.15rem; } .section h2{ font-size:2.3rem; } }

.figure-mood{ margin:0; width:100%; overflow:hidden; }
.figure-mood img{ width:100%; height:auto; max-height:520px; object-fit:cover; display:block; filter:saturate(1.05) contrast(1.05); }

.specialty{ margin:2rem 0; padding:1.6rem 1.8rem; background:var(--cognac-card); border-left:4px solid var(--bronze); border-radius:0 var(--radius-lg) var(--radius-lg) 0; box-shadow:var(--shadow-sm); }
.section-alt .specialty{ background:var(--cognac-deep); }
.specialty h3{ font-style:italic; margin-bottom:.6rem; color:var(--bronze); }
.specialty p{ color:var(--creme-warm); } .specialty p:last-child{ margin-bottom:0; } .specialty strong{ color:#FFFFFF; }

.inline-num{ font-family:var(--serif); font-weight:700; color:var(--bronze); white-space:nowrap; border-bottom:2px solid var(--cognac); }

.cta-mid{ background:linear-gradient(135deg, var(--cognac-deep) 0%, var(--chocolat) 50%, var(--cognac) 100%); padding:2.5rem 0; text-align:center; color:#FFFFFF; position:relative; }
.cta-mid::before{ content:''; position:absolute; inset:0; background:radial-gradient(ellipse at center, rgba(184,146,114,.22) 0%, transparent 70%); pointer-events:none; }
.cta-mid-text{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:#FFFFFF; margin:0 0 1.2rem; position:relative; text-shadow:0 0 18px rgba(184,146,114,.45); }

.testimonials{ display:grid; grid-template-columns:1fr; gap:1.5rem; margin-top:2rem; }
@media(min-width:760px){ .testimonials{ grid-template-columns:repeat(3,1fr); } }
.testimonial{ margin:0; padding:1.8rem 1.5rem; background:var(--cognac-card); border-radius:var(--radius-xl); box-shadow:var(--shadow-md); text-align:center; position:relative; border:1px solid var(--line); }
.testimonial img, .avatar-fallback{ width:90px; height:90px; border-radius:50%; margin:0 auto 1rem; border:3px solid var(--bronze); box-shadow:var(--glow-bronze); object-fit:cover; }
.avatar-fallback{ background:linear-gradient(135deg, var(--cognac) 0%, var(--bronze) 100%); color:#FFFFFF; font-family:var(--serif); font-size:2.4rem; font-weight:700; display:flex; align-items:center; justify-content:center; }
.testimonial blockquote{ margin:0 0 1rem; padding:0; }
.testimonial blockquote p{ font-family:var(--serif); font-style:italic; font-size:1.05rem; line-height:1.55; color:var(--creme); margin:0; }
.testimonial figcaption{ font-size:.9rem; color:var(--bronze); font-weight:500; letter-spacing:.02em; }
.testimonial figcaption strong{ color:#FFFFFF; }

.rating{ font-size:1.05rem; color:var(--whisky); letter-spacing:.15em; margin:.3rem 0 .6rem; text-shadow:0 0 12px rgba(177,113,50,.45); }

.faq-item{ margin:.5rem 0; background:var(--cognac-card); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.section-alt .faq-item{ background:var(--cognac-deep); }
.faq-item[open]{ box-shadow:var(--shadow-sm); border-color:var(--line-strong); }
.faq-item summary{ cursor:pointer; list-style:none; padding:1.1rem 3rem 1.1rem 1.4rem; position:relative; background:transparent; transition:background .2s ease; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; position:absolute; right:1.2rem; top:50%; transform:translateY(-50%); font-family:var(--serif); font-size:1.8rem; font-weight:300; color:var(--bronze); transition:transform .25s ease; line-height:1; }
.faq-item[open] summary::after{ transform:translateY(-50%) rotate(45deg); color:var(--whisky); }
.faq-item summary:hover{ background:rgba(184,146,114,.07); }
.faq-item summary h3{ display:inline; font-family:var(--sans); font-size:1rem; font-weight:600; color:#FFFFFF; margin:0; font-style:normal; }
.faq-item > p{ padding:0 1.4rem 1.2rem; margin:0; color:var(--creme-warm); font-size:.98rem; line-height:1.65; }
.faq-item > p strong{ color:#FFFFFF; }

.cta-final{ background: radial-gradient(ellipse at top, rgba(107,58,31,.5) 0%, transparent 60%), radial-gradient(ellipse at bottom, rgba(184,146,114,.4) 0%, transparent 60%), linear-gradient(180deg, var(--chocolat-deep) 0%, var(--cognac-deep) 100%); color:#FFFFFF; padding:5rem 0 4rem; text-align:center; position:relative; }
.cta-final::before{ content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent 0%, var(--bronze) 50%, transparent 100%); }
.cta-final-title{ font-family:var(--serif); font-style:italic; color:var(--bronze); font-size:clamp(1.8rem, 4.5vw, 2.8rem); font-weight:600; margin-bottom:.8rem; margin-top:0; text-shadow:0 0 22px rgba(184,146,114,.55); }
.cta-final-sub{ color:var(--creme-warm); font-size:1.1rem; margin-bottom:2rem; }
.cta-final-phone{ font-family:var(--serif); font-size:clamp(2rem, 6vw, 3.2rem); font-weight:700; color:#FFFFFF; letter-spacing:.05em; margin:.5rem 0 .3rem; text-shadow:0 0 26px rgba(184,146,114,.5); }
.cta-final-meta{ color:var(--creme-warm); opacity:.85; font-size:.95rem; margin-bottom:2rem; }

.site-footer{ background:var(--chocolat-deep); color:var(--creme-warm); padding:3rem 0 7.5rem; font-size:.88rem; line-height:1.55; border-top:1px solid var(--line); }
.footer-legal{ max-width:760px; margin:0 auto 1rem; text-align:center; opacity:.9; }
.footer-legal strong{ color:var(--bronze); }
.footer-pricing{ text-align:center; color:var(--bronze); margin:0 auto 1.6rem; font-weight:500; }
.footer-nav{ display:flex; flex-wrap:wrap; justify-content:center; gap:1rem 1.8rem; margin:1.5rem 0; padding:1.5rem 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.footer-nav a{ color:var(--bronze); font-size:.9rem; letter-spacing:.02em; }
.footer-nav a:hover{ color:#FFFFFF; }
.footer-copyright{ text-align:center; margin:1rem 0 0; font-size:.82rem; opacity:.7; font-style:italic; font-family:var(--serif); }
@media(min-width:720px){ .site-footer{ padding-bottom:3rem; } }

.sticky-cta{ position:fixed; left:.6rem; right:.6rem; bottom:.6rem; display:flex; align-items:center; justify-content:center; gap:.6rem; padding:.95rem 1rem; background:linear-gradient(135deg, var(--cognac) 0%, var(--vermeil) 100%); color:#FFFFFF; font-weight:700; font-size:.95rem; border-radius:var(--radius-xl); box-shadow:0 -4px 24px rgba(107,58,31,.55), 0 6px 16px rgba(0,0,0,.6); z-index:99; transition:transform .3s ease, opacity .3s ease; text-decoration:none; letter-spacing:.01em; }
.sticky-cta strong{ color:#FFFFFF; font-weight:800; } .sticky-cta:hover{ color:#FFFFFF; } .sticky-icon{ font-size:1.2rem; }
.sticky-cta:not(.is-visible){ transform:translateY(120%); opacity:0; pointer-events:none; }
@media(min-width:1024px){ .sticky-cta{ left:auto; right:1.5rem; bottom:1.5rem; max-width:340px; padding:1rem 1.4rem; } }

.site-header{ background:linear-gradient(135deg, var(--chocolat-deep) 0%, var(--cognac-deep) 100%); border-bottom:1px solid var(--bronze); padding:1rem 0; }
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.site-header__brand{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:#FFFFFF; letter-spacing:.12em; text-transform:uppercase; text-decoration:none; text-shadow:0 0 12px rgba(0,0,0,.3); }
.site-header__brand:hover{ color:var(--bronze); }
.site-header__back{ font-family:var(--sans); font-size:.9rem; color:#FFFFFF; text-decoration:none; border:1px solid var(--bronze); padding:.5rem 1rem; border-radius:var(--radius); background:rgba(255,255,255,.08); }
.site-header__back:hover{ background:var(--bronze); color:var(--chocolat); }

.page-legal{ padding:3rem 0 5rem; background:var(--chocolat); }
.page-legal h1{ font-family:var(--serif); color:#FFFFFF; font-size:clamp(1.8rem, 4.5vw, 2.6rem); margin:0 0 .5rem; font-weight:600; }
.page-legal__lede{ color:var(--creme-warm); font-size:1.05rem; margin:0 0 2.5rem; padding-bottom:1.5rem; border-bottom:1px solid var(--line); font-style:italic; font-family:var(--serif); }
.page-legal h2{ font-family:var(--serif); color:var(--bronze); font-size:1.35rem; margin:2rem 0 .8rem; font-weight:600; font-style:normal; }
.page-legal h2::after{ display:none; }
.page-legal p, .page-legal li{ color:var(--creme-warm); font-size:1rem; line-height:1.7; }
.page-legal ul, .page-legal ol{ padding-left:1.4rem; margin:.5rem 0 1.2rem; }
.page-legal address{ font-style:normal; background:var(--cognac-card); padding:1rem 1.2rem; border-left:3px solid var(--bronze); border-radius:0 var(--radius) var(--radius) 0; margin:1rem 0; color:var(--creme); }
.page-legal a{ color:var(--bronze); text-decoration:underline; text-decoration-color:var(--cognac); text-underline-offset:3px; }
.page-legal a:hover{ color:var(--bronze-light); }
.page-legal strong{ color:#FFFFFF; }
.page-legal .meta-info{ font-size:.85rem; color:var(--creme-warm); opacity:.7; margin-top:3rem; padding-top:1rem; border-top:1px solid var(--line); font-style:italic; }

.age-gate{ position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; padding:1rem; background:rgba(26,14,8,.92); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); animation:gateFade .25s ease-out; }
.age-gate[hidden]{ display:none; }
@keyframes gateFade{ from{opacity:0} to{opacity:1} }
.age-gate__panel{ background:linear-gradient(180deg, var(--cognac-card) 0%, var(--cognac-deep) 100%); border:1px solid var(--bronze); border-radius:var(--radius-xl); padding:2.2rem 1.6rem; max-width:480px; width:100%; text-align:center; box-shadow:0 30px 80px rgba(0,0,0,.7), 0 0 32px rgba(184,146,114,.3), inset 0 1px 0 rgba(255,255,255,.05); animation:gateUp .3s ease-out; }
@keyframes gateUp{ from{transform:translateY(20px); opacity:0} to{transform:translateY(0); opacity:1} }
.age-gate__brand{ font-family:var(--serif); font-style:italic; font-size:1rem; color:var(--bronze); letter-spacing:.18em; text-transform:uppercase; margin:0 0 1rem; }
.age-gate__title{ font-family:var(--serif); font-size:clamp(1.5rem, 4.5vw, 2rem); color:#FFFFFF; margin:0 0 1rem; font-weight:600; font-style:normal; }
.age-gate__text{ color:var(--creme-warm); font-size:.98rem; line-height:1.55; margin:0 0 1.6rem; }
.age-gate__text strong{ color:#FFFFFF; }
.age-gate__actions{ display:flex; flex-direction:column; gap:.7rem; }
.age-gate__btn{ display:inline-flex; align-items:center; justify-content:center; padding:.95rem 1.4rem; font-family:var(--sans); font-size:1rem; font-weight:700; border:none; border-radius:var(--radius-xl); cursor:pointer; text-decoration:none; transition:transform .15s ease, box-shadow .2s ease; }
.age-gate__btn--yes{ background:linear-gradient(135deg, var(--cognac) 0%, var(--vermeil) 100%); color:#FFFFFF; box-shadow:var(--glow-cognac), inset 0 1px 0 rgba(255,255,255,.25); }
.age-gate__btn--yes:hover{ transform:translateY(-2px); box-shadow:0 0 32px rgba(107,58,31,.8), inset 0 1px 0 rgba(255,255,255,.25); }
.age-gate__btn--no{ background:transparent; color:var(--creme-warm); border:1px solid var(--line); font-weight:500; }
.age-gate__btn--no:hover{ background:var(--cognac-deep); color:var(--bronze); }
.age-gate__legal{ margin:1.4rem 0 0; font-size:.78rem; color:var(--creme-warm); opacity:.7; line-height:1.45; }
@media(min-width:520px){ .age-gate__panel{ padding:2.5rem 2.2rem; } .age-gate__actions{ flex-direction:row; justify-content:center; } .age-gate__btn{ flex:1; max-width:200px; } }
body.gate-active{ overflow:hidden; }

.page-404{display:flex;align-items:center;justify-content:center;min-height:70vh;text-align:center;padding:40px 20px}
.page-404 h1{font-size:clamp(3rem,10vw,6rem);color:var(--bronze);margin:0 0 12px;letter-spacing:.05em}
.page-404 h1::after{display:none}
.page-404 h2{margin:0 0 20px;font-size:1.5rem;color:#FFFFFF}
.page-404 p{color:var(--creme-warm);max-width:480px;margin:0 auto 28px}

:focus-visible{ outline:3px solid var(--bronze); outline-offset:3px; border-radius:3px; }
@media(prefers-reduced-motion:reduce){ *,*::before,*::after{ animation-duration:.01ms !important; transition-duration:.01ms !important; scroll-behavior:auto !important; } }
