/* ═══════════════════════════════════════════════════════════════════════════
   DIADELAMADRE 2026 — Editorial brutal. Crema · Dorado · Tinta. Cormorant + Jost.
   ═══════════════════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Jost',system-ui,sans-serif;font-weight:300;color:#1C1712;background:#FDFAF6;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

:root{
  --cream:#F7F2EA;--cream-d:#F0E8DA;--cream-dd:#E8DDC8;
  --gold:#B8976A;--gold-d:#8C6E45;--gold-l:#D4B98C;
  --ink:#1C1712;--muted:#7A6E62;--stone:#2B2522;--white:#FDFAF6;
  --rose:#C68A8A;--rose-soft:#F0DCDC;
  --success:#10B981;--danger:#a23a2a;
}

/* ═══ Top promo bar ═══ */
.promo-bar{background:var(--ink);color:#fff;padding:11px 20px;text-align:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;position:relative;overflow:hidden}
.promo-bar::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold-l) 50%,var(--gold) 70%,transparent)}
.promo-bar strong{color:var(--gold-l);font-weight:500;letter-spacing:.18em}
.promo-bar .dot{margin:0 10px;color:rgba(255,255,255,.4)}

/* ═══ Brand ═══ */
.brand{padding:22px 44px;background:var(--white);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(184,151,106,.14);position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(10px);background:rgba(253,250,246,.92)}
.brand-logo{height:48px;width:auto;display:block}
.brand-nav{display:flex;gap:28px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:500}
.brand-nav a{position:relative;padding:6px 0}
.brand-nav a::after{content:'';position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--ink);transition:width .3s}
.brand-nav a:hover::after{width:100%}
@media(max-width:760px){.brand{padding:16px 24px}.brand-logo{height:38px}.brand-nav{display:none}}

/* ═══ Hero ═══ */
.hero{position:relative;padding:90px 44px 110px;background:linear-gradient(180deg,var(--white) 0%,var(--cream) 100%);overflow:hidden;min-height:80vh;display:flex;align-items:center}
.hero-inner{max-width:760px;position:relative;z-index:2}
.hero-kicker{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:34px;font-weight:500;display:inline-flex;align-items:center;gap:14px}
.hero-kicker::before{content:'';width:30px;height:1px;background:var(--gold)}
.hero-title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:400;font-size:clamp(46px,7vw,96px);line-height:.98;letter-spacing:-1.5px;color:var(--ink);margin:0 0 28px}
.hero-title em{font-style:italic;color:var(--gold-d)}
.hero-sub{font-size:clamp(16px,1.4vw,18px);color:var(--muted);max-width:560px;line-height:1.65;margin:0 0 38px}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:54px}
.btn-primary{display:inline-block;background:var(--ink);color:var(--white);padding:18px 36px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;border:0;border-radius:0;transition:transform .25s,background .25s,box-shadow .25s;box-shadow:0 8px 24px rgba(28,23,18,.18)}
.btn-primary:hover{background:var(--stone);transform:translateY(-2px);box-shadow:0 12px 32px rgba(28,23,18,.25)}
.btn-primary:disabled{background:#bdb5a8;cursor:not-allowed;box-shadow:none;transform:none}
.btn-ghost{display:inline-block;padding:18px 4px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink);transition:gap .25s,color .25s}
.btn-ghost:hover{color:var(--gold-d);border-bottom-color:var(--gold-d)}

.countdown{display:inline-block;padding:22px 30px;background:var(--white);border:1px solid var(--cream-dd);border-radius:4px;box-shadow:0 6px 24px rgba(28,23,18,.06)}
.cd-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:14px;font-weight:500}
.cd-grid{display:flex;gap:22px}
.cd-grid > div{text-align:center}
.cd-num{display:block;font-family:'Cormorant Garamond',serif;font-size:34px;line-height:1;color:var(--ink);font-weight:400;letter-spacing:-1px}
.cd-u{display:block;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:4px}

.hero-art{position:absolute;right:-160px;top:50%;transform:translateY(-50%);width:560px;height:560px;z-index:1;pointer-events:none}
.hero-circle{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--gold-l) 0%,var(--gold) 35%,transparent 75%);opacity:.42;filter:blur(40px)}
.hero-line{position:absolute;left:-20%;top:60%;width:140%;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);opacity:.45;transform:rotate(-8deg)}
@media(max-width:900px){.hero-art{right:-40%;width:420px;height:420px}}
@media(max-width:560px){.hero{padding:60px 24px 80px;min-height:70vh}.hero-art{display:none}}

/* ═══ Section heads ═══ */
.section-head{text-align:center;max-width:680px;margin:0 auto 56px;padding:0 24px}
.kicker{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:500;display:inline-flex;align-items:center;gap:14px}
.kicker::before,.kicker::after{content:'';width:24px;height:1px;background:var(--gold)}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(36px,4.5vw,56px);line-height:1.05;letter-spacing:-.8px;color:var(--ink);margin:0 0 16px}
.section-title em{font-style:italic;color:var(--gold-d)}
.section-sub{color:var(--muted);font-size:16px;line-height:1.65;margin:0;max-width:520px;margin-left:auto;margin-right:auto}

/* ═══ Packs ═══ */
.packs-section{padding:100px 44px;background:var(--white)}
.packs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px;max-width:1180px;margin:0 auto}
.pack-card{background:var(--white);border:1px solid var(--cream-dd);border-radius:4px;padding:34px 30px 30px;position:relative;transition:transform .35s,box-shadow .35s,border-color .35s;display:flex;flex-direction:column}
.pack-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(28,23,18,.1);border-color:var(--gold)}
.pack-card.featured{background:linear-gradient(180deg,var(--cream) 0%,var(--white) 100%);border-color:var(--gold);transform:scale(1.02)}
.pack-card.featured:hover{transform:scale(1.02) translateY(-6px)}
.pack-badge{position:absolute;top:-12px;left:30px;background:var(--gold-d);color:var(--white);padding:6px 14px;font-size:9px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;border-radius:2px;box-shadow:0 4px 14px rgba(140,110,69,.35)}
.pack-name{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:32px;line-height:1.05;color:var(--ink);margin:0 0 4px;letter-spacing:-.5px}
.pack-sub{color:var(--muted);font-size:14px;font-style:italic;font-family:'Cormorant Garamond',serif;margin:0 0 22px}
.pack-features{list-style:none;padding:0;margin:0 0 22px;border-top:1px solid var(--cream-dd);padding-top:18px}
.pack-features li{padding:8px 0;font-size:14px;color:#3a2f25;display:flex;align-items:flex-start;gap:10px;line-height:1.55}
.ftr-tag{flex-shrink:0;display:inline-block;background:var(--cream);color:var(--gold-d);padding:3px 9px;font-size:9px;letter-spacing:.16em;text-transform:uppercase;border-radius:2px;font-weight:500;line-height:1.4}
.ftr-tag.alt{background:var(--ink);color:var(--gold-l)}
.ftr-tag.warm{background:#F4EAD8;color:var(--gold-d);border:1px solid #D4B98C}
.ftr-tag.soft{background:transparent;color:var(--muted);border:1px solid var(--cream-dd)}
.pack-desc{color:var(--muted);font-size:13.5px;line-height:1.6;margin:0 0 22px}
.pack-price{margin-top:auto;padding-top:18px;border-top:1px solid var(--cream-dd);margin-bottom:20px}
.pack-price .orig{text-decoration:line-through;color:#bdb5a8;font-size:15px;margin-right:10px}
.pack-price .now{font-family:'Cormorant Garamond',serif;font-size:46px;color:var(--ink);font-weight:400;letter-spacing:-1px;line-height:1}
.pack-price .save{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-d);margin-top:8px;font-weight:500}
.pack-cta{width:100%;margin-top:auto}

.empty-note{text-align:center;color:var(--muted);font-style:italic;padding:32px;font-family:'Cormorant Garamond',serif;font-size:18px}

/* ═══ Builder ═══ */
.builder-section{padding:100px 44px;background:var(--cream)}
.builder{max-width:1100px;margin:0 auto;background:var(--white);border:1px solid var(--cream-dd);border-radius:6px;padding:50px 50px 40px;position:relative}
.builder-step{padding:28px 0;border-bottom:1px solid var(--cream-dd);position:relative}
.builder-step:first-child{padding-top:0}
.builder-step:last-child{border-bottom:0}
.step-num{position:absolute;left:-72px;top:32px;font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--gold);font-weight:400;font-style:italic}
.step-num{display:none}
.step-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:24px;color:var(--ink);margin:0 0 16px;letter-spacing:-.3px}
.step-title em{font-style:italic;color:var(--gold-d);font-weight:300}
.step-note{color:var(--muted);font-size:13px;margin:0 0 14px}
.step-note.small{font-size:12px;font-style:italic}

.massage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.massage-card{position:relative;border:1px solid var(--cream-dd);border-radius:4px;padding:16px 16px 14px;cursor:pointer;transition:border-color .2s,background .2s,transform .2s;background:var(--white);display:flex;flex-direction:column;gap:4px}
.massage-card:hover{border-color:var(--gold);transform:translateY(-1px)}
.massage-card input{position:absolute;opacity:0;pointer-events:none}
.massage-card.selected{border-color:var(--ink);background:var(--cream-d);box-shadow:0 0 0 3px var(--cream-d) inset}
.m-cat{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:500}
.m-name{font-size:14.5px;line-height:1.35;color:var(--ink);font-weight:400;margin-top:2px}
.m-dur{font-size:12px;color:var(--muted);margin-top:2px}
.m-price{margin-top:auto;padding-top:8px;display:flex;align-items:baseline;gap:8px}
.m-orig{text-decoration:line-through;color:#bdb5a8;font-size:11px}
.m-now{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--ink);letter-spacing:-.5px;line-height:1}
.m-addon-hint{font-size:10px;color:var(--gold-d);letter-spacing:.08em;margin-top:4px}

.qty-pills{display:flex;gap:8px;flex-wrap:wrap}
.qty-pill{position:relative;border:1px solid var(--cream-dd);border-radius:99px;width:60px;height:60px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--ink);transition:all .2s;background:var(--white)}
.qty-pill:hover{border-color:var(--gold)}
.qty-pill input{position:absolute;opacity:0;pointer-events:none}
.qty-pill.selected{background:var(--ink);color:var(--white);border-color:var(--ink)}

.qty-breakdown{margin-top:18px;padding:14px 18px;background:#FDF8EE;border:1px dashed var(--gold);border-radius:4px}
.bd-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;font-size:13.5px;color:#5A4830;border-bottom:1px solid rgba(184,151,106,.18)}
.bd-row:last-child{border-bottom:0}
.bd-row strong{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);font-weight:400}
.bd-row.total{margin-top:4px;padding-top:10px;border-top:1px solid var(--gold);border-bottom:0;color:var(--ink)}
.bd-row.total strong{font-size:24px;color:var(--ink)}

.gift-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.gift-card{position:relative;border:1px solid var(--cream-dd);border-radius:4px;padding:14px 16px;cursor:pointer;transition:border-color .2s,background .2s;background:var(--white)}
.gift-card:hover:not(.sold-out){border-color:var(--gold)}
.gift-card input{position:absolute;opacity:0;pointer-events:none}
.gift-card.selected{border-color:var(--ink);background:var(--cream-d);box-shadow:0 0 0 3px var(--cream-d) inset}
.g-name{font-size:14px;color:var(--ink);font-weight:400;line-height:1.35}
.g-desc{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.5}
.gift-card.sold-out{opacity:.55;cursor:not-allowed;background:repeating-linear-gradient(135deg,#FBF5EA,#FBF5EA 6px,#F2EADC 6px,#F2EADC 12px)}
.gift-card.sold-out .g-name{text-decoration:line-through}
.g-soldout{display:inline-block;margin-top:6px;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--danger);background:#f4d4cf;padding:3px 9px;border-radius:99px;font-weight:600}

.builder-step--cta{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:38px}
.btn-build{padding:20px 44px;font-size:12px;letter-spacing:.22em}

@media(max-width:760px){.builder-section{padding:60px 18px}.builder{padding:30px 22px}}

/* ═══ Cómo funciona ═══ */
.how-section{padding:100px 44px;background:var(--white)}
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;max-width:980px;margin:0 auto}
.how-card{padding:32px 28px;border:1px solid var(--cream-dd);border-radius:4px;background:var(--white)}
.how-num{font-family:'Cormorant Garamond',serif;font-size:60px;color:var(--gold-l);font-weight:400;line-height:1;margin-bottom:14px;font-style:italic}
.how-card h4{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:24px;margin:0 0 8px;color:var(--ink)}
.how-card p{color:var(--muted);font-size:14px;line-height:1.65;margin:0}

/* ═══ Footer ═══ */
.ddm-foot{background:var(--ink);color:var(--cream);padding:60px 44px 36px;border-top:1px solid var(--gold)}
.foot-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;max-width:1180px;margin:0 auto 36px}
.ddm-foot .kicker{color:var(--gold-l);margin-bottom:10px}
.ddm-foot p{color:#c8b9a3;font-size:13px;line-height:1.7;margin:0}
.foot-meta{text-align:center;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(212,185,140,.45);max-width:1180px;margin:0 auto;padding-top:24px;border-top:1px solid rgba(212,185,140,.15)}
@media(max-width:660px){.foot-grid{grid-template-columns:1fr}}

/* ═══ Closed banner ═══ */
.closed-banner{background:var(--cream);padding:80px 44px;text-align:center}
.closed-banner p{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--ink);font-style:italic;line-height:1.5}
.closed-banner a{color:var(--gold-d);border-bottom:1px solid var(--gold-d)}

/* ═══ Modal Checkout ═══ */
.modal[hidden]{display:none !important}
[hidden]{display:none !important}
.modal{position:fixed;inset:0;z-index:1000;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;animation:modalFade .25s ease}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal-bg{position:fixed;inset:0;background:rgba(28,23,18,.7);backdrop-filter:blur(6px);z-index:0}
.modal-wrap{position:relative;background:var(--white);width:100%;max-width:980px;margin:0 auto;min-height:100vh;animation:modalSlide .35s cubic-bezier(.22,.61,.36,1);z-index:1}
@keyframes modalSlide{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
.modal-close{position:fixed;top:18px;right:18px;width:42px;height:42px;border-radius:50%;background:var(--cream);border:0;font-size:22px;color:var(--ink);z-index:10;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.modal-close:hover{background:var(--cream-dd)}
.modal-grid{display:grid;grid-template-columns:340px 1fr;align-items:start}
@media(max-width:860px){.modal-grid{grid-template-columns:1fr}}

.modal-summary{background:var(--ink);color:var(--cream);padding:56px 36px 32px;position:sticky;top:0;align-self:start}
@media(max-width:860px){.modal-summary{position:static}}
.modal-summary .kicker{color:var(--gold-l);margin-bottom:16px}
.modal-summary .kicker::before,.modal-summary .kicker::after{background:var(--gold-l)}
.modal-summary h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:34px;line-height:1.1;letter-spacing:-.5px;margin:0 0 24px;color:var(--cream)}
.sum-list{list-style:none;padding:0;margin:0 0 24px;border-top:1px solid rgba(212,185,140,.18);padding-top:18px}
.sum-list li{padding:9px 0;display:flex;justify-content:space-between;gap:12px;font-size:13px;color:#d8c9b3;border-bottom:1px solid rgba(212,185,140,.1)}
.sum-list li:last-child{border-bottom:0}
.sum-list .it-name{color:var(--cream)}
.sum-list .it-tag{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-l);margin-right:6px}
.sum-total{padding-top:18px;border-top:1px solid rgba(212,185,140,.3)}
.sum-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;font-size:13px;color:#d8c9b3}
.sum-row strong{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--cream);font-weight:400;letter-spacing:-.5px}
.sum-row.save strong{color:var(--gold-l);font-size:18px}
.sum-meta{margin-top:30px;padding-top:18px;border-top:1px solid rgba(212,185,140,.15)}
.sum-meta div{font-size:11px;color:#a89880;letter-spacing:.04em;padding:4px 0}

.modal-form{padding:56px 50px 50px}
.modal-form .kicker{margin-bottom:14px}
.form-block{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--cream-dd)}
.form-block:last-of-type{border-bottom:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.form-row{grid-template-columns:1fr}.modal-form{padding:36px 24px 30px}.modal-summary{padding:36px 24px 24px}}
.modal-form label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:500}
.modal-form label .opt{text-transform:none;letter-spacing:0;font-size:11px;color:#bdb5a8;font-style:italic;margin-left:6px}
.modal-form input[type=text],.modal-form input[type=email],.modal-form input[type=tel],.modal-form input[type=datetime-local],.modal-form textarea{width:100%;padding:12px 14px;border:1px solid var(--cream-dd);border-radius:3px;background:var(--white);font-family:inherit;font-size:14.5px;color:var(--ink);font-weight:400;text-transform:none;letter-spacing:0;margin-top:6px}
.modal-form input:focus,.modal-form textarea:focus{outline:none;border-color:var(--gold-d);box-shadow:0 0 0 3px rgba(184,151,106,.15)}
.modal-form textarea{resize:vertical;font-family:'Cormorant Garamond',serif;font-size:16px;line-height:1.5}
.note-muted{font-size:12.5px;color:var(--muted);margin:-4px 0 14px;line-height:1.6}
.note-muted strong{color:var(--ink);font-weight:500}
.check-row{display:flex !important;align-items:flex-start;gap:12px;font-size:13.5px !important;color:var(--ink) !important;text-transform:none !important;letter-spacing:0 !important;font-weight:300 !important;cursor:pointer;line-height:1.5;padding:10px 0;border-radius:3px}
.check-row input{margin-top:4px;width:auto;accent-color:var(--ink)}
.check-row span{flex:1}
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pay-card{position:relative;border:1px solid var(--cream-dd);border-radius:4px;padding:18px 20px;cursor:pointer;transition:all .2s;background:var(--white);text-transform:none !important;letter-spacing:0 !important;color:var(--ink) !important;font-weight:400 !important;font-size:14px !important;margin-bottom:0 !important}
.pay-card input{position:absolute;opacity:0;pointer-events:none}
.pay-card:hover{border-color:var(--gold)}
.pay-card.selected{border-color:var(--ink);background:var(--cream-d);box-shadow:0 0 0 2px var(--cream-d) inset}
.pay-name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--ink);font-weight:400;line-height:1}
.pay-icon{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px;font-weight:500}
.btn-pay{width:100%;padding:20px;font-size:12px;letter-spacing:.22em;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:14px}
.btn-pay span{font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:0;text-transform:none;color:var(--gold-l)}
.form-error{background:#f4d4cf;color:#8b3322;padding:12px 16px;border-radius:3px;font-size:13px;margin-top:14px}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
}
