/* ==========================================================================
   MAGNOLIA LASH & BROW x ANNEAL — Proposal
   Cream + dusty rose + plum + gold. Cormorant Garamond + Manrope.
   Screen + print (PDF).
   ========================================================================== */
:root{
  --plum:#2E1F2B; --plum-soft:#43303d; --charcoal:#3D3535;
  --rose:#C9A49B; --rose-deep:#A8818A; --rose-tint:#EFE0DB;
  --gold:#C4A96A; --gold-deep:#A98F4F;
  --cream:#FAF6F1; --ivory:#F2EBE0; --greige:#D9CFC4; --white:#fff;
  --muted:#897E80;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-ui:'Manrope',system-ui,sans-serif;
  --maxw:1080px; --ease:cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--font-ui);font-size:16px;line-height:1.7;color:var(--charcoal);background:var(--cream);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.08;color:var(--plum)}
::selection{background:var(--rose);color:var(--plum)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 56px}
.eyebrow{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--rose-deep);display:block;margin-bottom:18px}
.section{padding:84px 0;border-bottom:1px solid var(--greige)}
.section--plum{background:var(--plum);color:rgba(255,255,255,.84);border-bottom:none}
.section--plum h2,.section--plum h3,.section--plum h4{color:#fff}
.section--plum .eyebrow{color:var(--rose)}
.section--cream{background:var(--cream)}
.section--ivory{background:var(--ivory)}
.section--white{background:#fff}
.section h2{font-size:clamp(2.1rem,4.4vw,3.3rem);letter-spacing:0;margin-bottom:14px}
.section .lead{font-size:1.16rem;color:var(--muted);max-width:680px;margin-bottom:8px}
.section--plum .lead{color:rgba(255,255,255,.72)}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-ui);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:15px 32px;border:1.5px solid transparent;transition:.35s var(--ease)}
.btn--rose{background:var(--rose);color:var(--plum)}
.btn--rose:hover{background:var(--rose-deep);color:#fff}
.btn--plum{background:var(--plum);color:#fff}
.btn--plum:hover{background:var(--plum-soft)}
.btn--outline{border-color:var(--plum);color:var(--plum)}
.btn--outline:hover{background:var(--plum);color:#fff}
.btn--light{border-color:rgba(255,255,255,.75);color:#fff}
.btn--light:hover{background:#fff;color:var(--plum)}

/* ---- COVER ---- */
.cover{background:var(--plum);color:#fff;min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.cover::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 16%,rgba(201,164,155,.30),transparent 48%);pointer-events:none}
.cover::after{content:"";position:absolute;left:-10%;bottom:-20%;width:55%;height:70%;background:radial-gradient(circle,rgba(196,169,106,.14),transparent 60%);pointer-events:none}
.cover__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 56px;width:100%}
.cover__mark{font-family:var(--font-display);font-size:2.4rem;font-weight:500;color:#fff;letter-spacing:.01em;margin-bottom:6px}
.cover__mark span{color:var(--rose)}
.cover__rule{width:54px;height:1px;background:var(--gold);margin:26px 0 34px}
.cover__kicker{font-family:var(--font-ui);font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--rose);margin-bottom:24px}
.cover h1{color:#fff;font-size:clamp(2.8rem,6.5vw,5.2rem);letter-spacing:0;max-width:15ch;font-weight:500}
.cover h1 em{font-style:italic;color:var(--rose)}
.cover__sub{font-size:1.2rem;color:rgba(255,255,255,.8);margin:26px 0 40px;max-width:48ch}
.cover__meta{display:flex;flex-wrap:wrap;gap:14px 44px;padding-top:32px;border-top:1px solid rgba(255,255,255,.18);font-size:14px;color:rgba(255,255,255,.72)}
.cover__meta b{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--rose);margin-bottom:4px;display:block}
.cover__meta a{color:#fff;border-bottom:1px solid var(--rose)}

/* ---- AUDIT ---- */
.audit{display:grid;gap:2px;background:var(--greige);border:1px solid var(--greige);margin-top:40px}
.audit__row{background:#fff;padding:26px 30px;display:grid;grid-template-columns:30px 1fr;gap:18px;align-items:start}
.audit__row svg{width:22px;height:22px;color:var(--rose-deep);margin-top:3px}
.audit__row h4{font-family:var(--font-ui);font-size:16px;font-weight:700;color:var(--plum);margin-bottom:4px}
.audit__row p{color:var(--muted);font-size:15px}

/* ---- FEATURE GRID (plum) ---- */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.14);margin:40px 0 36px}
.feat__item{background:var(--plum);padding:30px}
.feat__item svg{width:26px;height:26px;color:var(--rose);margin-bottom:14px}
.feat__item h4{color:#fff;font-family:var(--font-ui);font-size:16px;font-weight:700;margin-bottom:6px}
.feat__item p{color:rgba(255,255,255,.7);font-size:14.5px}

/* ---- comparison table ---- */
.cmp{width:100%;border-collapse:collapse;margin-top:36px;background:#fff;border:1px solid var(--greige)}
.cmp th{text-align:left;font-family:var(--font-ui);font-size:12px;letter-spacing:.13em;text-transform:uppercase;padding:18px 22px;background:var(--plum);color:#fff;font-weight:600}
.cmp th:last-child{background:var(--rose-deep)}
.cmp td{padding:15px 22px;border-top:1px solid var(--greige);font-size:14.5px;vertical-align:top;width:50%}
.cmp td:first-child{color:var(--muted)}
.cmp td:last-child{color:var(--plum);background:#fdf8f4}
.cmp tr:nth-child(even) td:first-child{background:#faf6f1}

/* ---- payments / booking ---- */
.pay{display:grid;grid-template-columns:1.3fr 1fr;gap:24px;margin-top:40px}
.pay__card{border:1px solid var(--greige);background:#fff;padding:36px}
.pay__card--rec{border:2px solid var(--rose);position:relative}
.pay__tag{position:absolute;top:-12px;left:36px;background:var(--rose);color:var(--plum);font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;padding:5px 14px}
.pay__card h3{font-size:1.8rem;margin-bottom:4px}
.pay__card .role{font-family:var(--font-ui);font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--rose-deep);margin-bottom:16px;display:block;font-weight:600}
.pay__card p{font-size:15px;color:var(--charcoal);margin-bottom:16px}
.pay__fees{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.pay__fees span{font-size:12px;letter-spacing:.03em;padding:7px 12px;background:var(--cream);border:1px solid var(--greige);color:var(--plum)}

/* ---- flow (plum) ---- */
.flow{margin-top:40px}
.flow__step{display:grid;grid-template-columns:64px 1fr;gap:26px;padding:26px 0;border-bottom:1px solid rgba(255,255,255,.16);align-items:start}
.flow__step:last-child{border-bottom:none}
.flow__num{font-family:var(--font-display);font-size:2.4rem;color:var(--rose);line-height:1}
.flow__step h4{color:#fff;font-family:var(--font-ui);font-size:17px;font-weight:700;margin-bottom:6px}
.flow__step p{color:rgba(255,255,255,.7);font-size:15px}

/* ---- BLOOM REWARDS ---- */
.bloom__band{display:flex;align-items:baseline;gap:16px;margin-top:8px}
.bloom__band .name{font-family:var(--font-display);font-size:2.2rem;color:var(--plum)}
.bloom__band .tag{font-family:var(--font-ui);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--rose-deep)}
.bloom{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:36px}
.bloom__card{background:#fff;border:1px solid var(--greige);padding:30px;position:relative;overflow:hidden}
.bloom__card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--rose),var(--gold))}
.bloom__card .k{font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-deep)}
.bloom__card h4{font-size:1.5rem;margin:6px 0 10px}
.bloom__card p{font-size:14.5px;color:var(--charcoal)}
.bloom__card .big{font-family:var(--font-display);font-size:1.6rem;color:var(--gold-deep);display:block;margin-bottom:6px}
.bloom__impact{grid-column:1/-1;background:var(--plum);color:#fff;padding:34px 36px;display:flex;gap:30px;align-items:center;flex-wrap:wrap}
.bloom__impact .num{font-family:var(--font-display);font-size:3.2rem;color:var(--rose);line-height:1}
.bloom__impact div{flex:1;min-width:240px}
.bloom__impact h4{color:#fff;font-size:1.4rem;margin-bottom:6px}
.bloom__impact p{color:rgba(255,255,255,.74);font-size:14.5px}
.bloom__note{grid-column:1/-1;background:var(--ivory);border-left:3px solid var(--gold);padding:20px 24px;font-size:14px;color:var(--charcoal)}
.bloom__note b{color:var(--plum)}

/* ---- pricing ---- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px;align-items:start}
.tier{background:#fff;border:1px solid var(--greige);padding:34px 28px;position:relative}
.tier--rec{border:2px solid var(--rose);box-shadow:0 24px 60px rgba(46,31,43,.13)}
.tier__ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--rose);color:var(--plum);font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:6px 16px;white-space:nowrap}
.tier__name{font-family:var(--font-ui);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--rose-deep);font-weight:700}
.tier__price{font-family:var(--font-display);font-size:2.6rem;color:var(--plum);margin:14px 0 2px;line-height:1}
.tier__price small{font-size:1rem;color:var(--muted)}
.tier__mo{font-size:14px;color:var(--plum);font-weight:600;margin-bottom:6px}
.tier__promise{font-size:14px;color:var(--muted);min-height:42px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--greige)}
.tier ul li{font-size:13.5px;color:var(--charcoal);padding:7px 0 7px 24px;position:relative}
.tier ul li::before{content:"";position:absolute;left:0;top:12px;width:9px;height:9px;border:1.5px solid var(--rose-deep);border-top:none;border-right:none;transform:rotate(-45deg)}
.feenote{margin-top:34px;background:var(--ivory);border-left:3px solid var(--rose);padding:22px 26px;font-size:14px;color:var(--charcoal)}
.feenote b{color:var(--plum)}

.just td:last-child,.just th:last-child{background:#fdf8f4}
.just .me td{font-weight:700;color:var(--plum);background:#f6ece6}
.just .me td:first-child{color:var(--plum)}

/* ---- timeline ---- */
.tl{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.tl__week{background:#fff;border:1px solid var(--greige);padding:28px 24px;border-top:3px solid var(--rose)}
.tl__week .w{font-family:var(--font-ui);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-deep);font-weight:700}
.tl__week h4{font-size:1.4rem;margin:8px 0 12px}
.tl__week p{font-size:14px;color:var(--muted)}

/* ---- CTA ---- */
.cta{text-align:center}
.cta h2{font-size:clamp(2.2rem,4.6vw,3.4rem);max-width:20ch;margin:0 auto 18px}
.cta h2 em{font-style:italic;color:var(--rose)}
.cta p{color:rgba(255,255,255,.78);font-size:1.12rem;max-width:54ch;margin:0 auto 34px}
.cta__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta__contact{margin-top:40px;padding-top:30px;border-top:1px solid rgba(255,255,255,.18);font-size:14px;color:rgba(255,255,255,.62)}
.cta__contact a{color:var(--rose)}

.foot{background:var(--plum);color:rgba(255,255,255,.5);text-align:center;padding:30px;font-size:12.5px;letter-spacing:.05em;border-top:1px solid rgba(255,255,255,.12)}

/* ---- responsive ---- */
@media(max-width:880px){
  .wrap,.cover__inner{padding:0 28px}
  .section{padding:60px 0}
  .pay,.feat,.bloom{grid-template-columns:1fr}
  .tiers,.tl{grid-template-columns:1fr}
  .cmp td,.cmp th{font-size:13px;padding:12px 14px}
  .bloom__impact{flex-direction:column;align-items:flex-start;gap:14px}
}

/* ==========================================================================
   PRINT / PDF
   ========================================================================== */
@media print{
  @page{size:Letter;margin:0}
  body{background:#fff;font-size:11pt;line-height:1.5}
  .wrap,.cover__inner{padding:0 0.7in;max-width:none}
  .section{padding:0.55in 0;border-bottom:none;break-before:page}
  .cover{min-height:auto;height:11in;break-after:page;padding:0;display:flex}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .audit__row,.feat__item,.tier,.pay__card,.tl__week,.flow__step,.bloom__card,.cmp tr{break-inside:avoid}
  .tiers,.tl,.feat,.pay,.bloom{break-inside:avoid}
  .cover h1{font-size:40pt}
  .section h2{font-size:23pt}
  .tier__price{font-size:25pt}
  .btn{border:1.5px solid var(--plum);color:var(--plum)!important;background:transparent!important}
  .cta .btn--rose,.section--plum .btn{border-color:var(--rose);color:var(--rose)!important}
}
