/* ===== ECOMMERCE — Angelic Perú ===== */
:root {
  --ec-cream: #faf6ef;
  --ec-cream-2: #f3ecdf;
  --ec-gold: #c8985a;
  --ec-gold-l: #e9c789;
  --ec-gold-d: #a07640;
  --ec-ink: #3d2f2a;
  --ec-ink-2: #6b594f;
  --ec-line: #e9dec8;
  --ec-wa: #25d366;
}

/* Base */
.ec-root {
  font-family: var(--font-body, 'Inter', sans-serif);
  color: var(--ec-ink);
  background: linear-gradient(180deg, #ece0cb 0%, #e8d9c0 100%);
  min-height: 100vh;
}
.ec-root *, .ec-root *::before, .ec-root *::after { box-sizing: border-box; }
.ec-root a { color: inherit; text-decoration: none; }

/* Reveal */
.ec-root [data-reveal] {
  opacity: 0; transform: translateY(32px) scale(0.985);
  transition: opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.ec-root [data-reveal].is-revealed { opacity: 1; transform: translateY(0) scale(1); }

/* Typography */
.ec-h1 {
  font-family: var(--font-display, 'Cormorant Garamond', serif);
  font-weight: 400; font-size: clamp(36px, 5.5vw, 72px);
  line-height: 1.06; letter-spacing: -0.01em;
  color: var(--ec-ink); margin: 0 0 16px; text-wrap: pretty;
}
.ec-h2 {
  font-family: var(--font-display, 'Cormorant Garamond', serif);
  font-weight: 400; font-size: clamp(28px, 3.8vw, 50px);
  line-height: 1.1; letter-spacing: -0.01em;
  color: var(--ec-ink); margin: 0 0 14px;
  position: relative; display: inline-block; padding-bottom: 16px;
}
.ec-h2::after {
  content: ''; position: absolute;
  left: 50%; bottom: 0;
  width: 0; height: 2px; transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, var(--ec-gold), var(--ec-gold-l), var(--ec-gold), transparent);
  transition: width 1.2s cubic-bezier(.2,.7,.2,1) .3s;
}
.is-revealed .ec-h2::after,
.ec-section-head.is-revealed .ec-h2::after { width: 160px; }
.ec-h2--light { color: #fff8e0; }
.ec-eyebrow {
  display: inline-block; font-size: 11px; letter-spacing: 0.3em;
  text-transform: uppercase; color: var(--ec-gold-d); margin-bottom: 14px; font-weight: 500;
}
.ec-eyebrow--light { color: #f4d99b; }
.ec-section-head { text-align: center; max-width: 720px; margin: 0 auto 48px; padding: 0 20px; }
.ec-section-sub { color: var(--ec-ink-2); font-size: 16px; max-width: 580px; margin: 0 auto; line-height: 1.6; }

/* Buttons */
.ec-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 15px 30px; border-radius: 999px;
  font-family: var(--font-body, 'Inter', sans-serif);
  font-size: 14px; font-weight: 500; letter-spacing: 0.02em;
  cursor: pointer; border: 1px solid transparent;
  text-decoration: none;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, background .3s;
  white-space: nowrap;
}
.ec-btn--gold {
  background: linear-gradient(135deg, var(--ec-gold-l), var(--ec-gold) 60%, #9a7238);
  color: #fff;
  box-shadow: 0 6px 24px rgba(200,152,90,.38), inset 0 1px 0 rgba(255,255,255,.45);
}
.ec-btn--gold:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(200,152,90,.52); }
.ec-btn--wa {
  background: linear-gradient(135deg, #2ee06a, #25d366 55%, #1eb858);
  color: #fff;
  box-shadow: 0 6px 22px rgba(37,211,102,.38), inset 0 1px 0 rgba(255,255,255,.3);
}
.ec-btn--wa svg { width: 17px; height: 17px; flex: none; }
.ec-btn--wa:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(37,211,102,.52); }
.ec-btn--ghost-sm {
  background: transparent; color: var(--ec-gold-d); border-color: var(--ec-gold);
  padding: 10px 22px; font-size: 13px;
}
.ec-btn--ghost-sm:hover { background: rgba(200,152,90,.08); }
.ec-pill {
  display: inline-flex; align-items: center; padding: 7px 14px; border-radius: 999px;
  border: 1px solid var(--ec-line); background: transparent;
  font-family: var(--font-body, 'Inter', sans-serif);
  font-size: 11px; letter-spacing: 0.12em; color: var(--ec-ink-2);
  cursor: pointer; transition: border-color .25s, color .25s; white-space: nowrap;
}
.ec-pill:hover { border-color: var(--ec-gold); color: var(--ec-gold-d); }

/* Frames */
.ec-frame {
  margin: 20px clamp(10px, 2.5vw, 36px);
  border-radius: 32px; border: 1px solid rgba(200,152,90,.22);
  overflow: hidden;
  box-shadow: 0 14px 48px rgba(180,130,70,.12), 0 2px 8px rgba(180,130,70,.08);
  background: var(--ec-cream);
}

/* ─── NAV ─── */
.ec-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,246,239,.88); backdrop-filter: blur(14px);
  border-bottom: 1px solid transparent;
  transition: background .4s, border-color .4s, box-shadow .4s;
}
.ec-nav--scrolled {
  background: rgba(250,246,239,.97);
  border-bottom-color: var(--ec-line);
  box-shadow: 0 4px 20px rgba(200,152,90,.1);
}
.ec-nav__inner {
  max-width: 1360px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 32px; gap: 20px;
}
.ec-nav__brand { display: flex; align-items: center; text-decoration: none; }
.ec-nav__logo { height: 78px; width: auto; display: block; }
.ec-nav__links { display: flex; gap: 24px; }
.ec-nav__links a {
  color: var(--ec-ink-2); text-decoration: none;
  font-size: 13px; letter-spacing: 0.04em; transition: color .25s;
}
.ec-nav__links a:hover { color: var(--ec-gold-d); }
.ec-nav__actions { display: flex; align-items: center; gap: 10px; }
.ec-nav__cart {
  position: relative; background: transparent;
  border: 1px solid var(--ec-line); border-radius: 12px; padding: 9px 10px;
  color: var(--ec-ink-2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: border-color .25s, color .25s, background .25s;
}
.ec-nav__cart:hover { border-color: var(--ec-gold); color: var(--ec-gold-d); background: rgba(200,152,90,.07); }
.ec-nav__badge {
  position: absolute; top: -7px; right: -7px;
  min-width: 18px; height: 18px;
  background: var(--ec-gold); color: #fff; border-radius: 999px;
  font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; padding: 0 4px;
  animation: ec-badge-pop .35s cubic-bezier(.2,1.5,.4,1);
}
@keyframes ec-badge-pop { 0% { transform: scale(0); } 100% { transform: scale(1); } }

/* ─── HERO ─── */
.ec-hero {
  position: relative; height: 100vh; min-height: 680px;
  overflow: hidden; display: flex; align-items: center; justify-content: center;
}
.ec-hero__bg-wrap { position: absolute; inset: 0; z-index: 0; will-change: transform; }
.ec-hero__kb { position: absolute; inset: -15%; animation: ec-kb 32s ease-in-out infinite alternate; will-change: transform; }
.ec-hero__img { width: 100%; height: 100%; object-fit: cover; display: block; }
@keyframes ec-kb {
  0%   { transform: scale(1.0) translate(0%, 0%); }
  33%  { transform: scale(1.06) translate(-1.5%, 0.5%); }
  66%  { transform: scale(1.09) translate(1%, -0.5%); }
  100% { transform: scale(1.04) translate(-0.5%, 1.5%); }
}
.ec-hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg,
    rgba(255,245,245,.06) 0%,
    rgba(20,5,15,.12) 38%,
    rgba(20,5,15,.32) 65%,
    rgba(15,4,12,.58) 100%);
}
/* Keep feathers/particles above overlay */
.ec-hero .hp-feathers { z-index: 2; }
.ec-hero .light-particles { z-index: 2 !important; }
.ec-hero__content {
  position: relative; z-index: 4; text-align: center;
  max-width: 1000px; padding: 0 32px 88px;
  will-change: transform, opacity; color: #7B1034;
}
.ec-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-size: 10px; letter-spacing: 0.34em; text-transform: uppercase;
  color: rgba(244,217,155,.88); margin-bottom: 24px;
  opacity: 0; transform: translateY(8px);
  transition: opacity .9s ease 150ms, transform .9s ease 150ms;
}
.ec-hero__eyebrow.is-in { opacity: 1; transform: translateY(0); }
.ec-hero__eline { width: 32px; height: 1px; background: linear-gradient(90deg, transparent, rgba(244,217,155,.65), transparent); }
.ec-hero__headline {
  font-family: var(--font-display, 'Cormorant Garamond', serif);
  font-weight: 400; font-size: clamp(50px, 8vw, 112px);
  line-height: 0.96; letter-spacing: -0.02em;
  margin: 0 0 22px; color: #fff; text-wrap: pretty;
  text-shadow: 0 4px 32px rgba(0,0,0,.28);
}
.ec-hero__gold {
  background: linear-gradient(180deg, #fff8e0 0%, #f0d978 55%, #d4af6b 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; font-style: italic; display: block;
}
.ec-hero__sub {
  font-size: clamp(18px, 1.8vw, 24px); color: rgba(255,248,224,.82);
  margin: 0 auto 40px; max-width: 620px; line-height: 1.6;
  font-weight: 300; letter-spacing: 0.02em;
  opacity: 0; transform: translateY(10px);
  transition: opacity 1s ease 1.4s, transform 1s ease 1.4s;
}
.ec-hero__sub.is-in { opacity: 1; transform: translateY(0); }
.ec-hero__ctas {
  display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center;
  opacity: 0; transform: translateY(10px);
  transition: opacity 1s ease 2s, transform 1s ease 2s;
}
.ec-hero__ctas.is-in { opacity: 1; transform: translateY(0); }
.ec-hero__scroll {
  position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%);
  z-index: 4; display: flex; flex-direction: column; align-items: center;
  opacity: 0; animation: ec-fadein 1s ease 3.2s forwards;
}
@keyframes ec-fadein { to { opacity: .7; } }
.ec-hero__scroll-line {
  width: 1px; height: 46px;
  background: linear-gradient(180deg, rgba(244,217,155,.7), transparent);
  position: relative; overflow: hidden;
}
.ec-hero__scroll-dot {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  width: 4px; height: 10px; border-radius: 2px; background: #f4d99b;
  animation: ec-drop 2.2s ease-in-out infinite;
}
@keyframes ec-drop { 0% { top:-10px; opacity:0; } 25% { opacity:1; } 100% { top:46px; opacity:0; } }

/* ─── CERT BADGE ─── */
.ec-cert {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 18px; margin: 6px 0 12px;
  border: 1px solid var(--ec-line); border-radius: 999px;
  background: rgba(255,252,245,.8);
  font-size: 12px; letter-spacing: 0.08em; color: var(--ec-gold-d); font-weight: 500;
}

/* ─── ABOUT ─── */
.ec-about { padding: 80px 40px; }
.ec-about__inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 72px; align-items: center;
}
.ec-about__collage {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr 1fr;
  gap: 12px; aspect-ratio: 4/5;
}
.ec-about__aura {
  position: absolute; inset: -30%; border-radius: 50%;
  background: radial-gradient(circle, rgba(244,217,155,.5), transparent 60%);
  pointer-events: none; z-index: 0;
  animation: ec-aura 6s ease-in-out infinite;
}
@keyframes ec-aura { 0%,100% { transform: scale(1); opacity:.7; } 50% { transform: scale(1.06); opacity:1; } }
.ec-col-main { grid-column:1/3; grid-row:1/4; border-radius:14px; overflow:hidden; position:relative; z-index:1; box-shadow: 0 16px 40px rgba(180,130,70,.18); }
.ec-col-sm { border-radius:12px; overflow:hidden; position:relative; z-index:1; box-shadow: 0 8px 24px rgba(180,130,70,.14); }
.ec-col-sm--a { grid-column:3/4; grid-row:1/2; }
.ec-col-sm--b { grid-column:3/4; grid-row:2/4; }
.ec-col-sm--c { grid-column:1/4; grid-row:4/5; }
.ec-col-main img, .ec-col-sm img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .6s ease; }
.ec-col-main:hover img, .ec-col-sm:hover img { transform: scale(1.05); }
.ec-about__sp {
  position: absolute; color: var(--ec-gold); font-size: 20px;
  animation: ec-aura 3.5s ease-in-out infinite; z-index:2; pointer-events:none;
}
.ec-about__sp--1 { top:-10px; right:12%; }
.ec-about__sp--2 { bottom:28%; left:-12px; animation-delay:1.8s; font-size:14px; }
.ec-about__text { display:flex; flex-direction:column; gap:4px; }
.ec-about__text p { font-size:16px; color:var(--ec-ink-2); line-height:1.7; margin:0 0 14px; }
.ec-about__stats {
  display: grid; grid-template-columns: repeat(3,1fr); gap:20px;
  margin-top:28px; padding-top:24px; border-top:1px solid var(--ec-line);
}
.ec-about__stats > div { display:flex; flex-direction:column; gap:3px; }
.ec-about__stats strong { font-family:var(--font-display,serif); font-size:26px; color:var(--ec-gold-d); font-weight:400; }
.ec-about__stats span { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ec-ink-2); }

/* ─── SHOP ─── */
.ec-shop { padding: 80px 32px; }
.ec-cats {
  display: flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:48px;
}
.ec-cat {
  display: inline-flex; align-items:center; gap:7px;
  padding: 10px 22px; border-radius:999px; border:1px solid var(--ec-line);
  background: rgba(255,252,245,.75); font-size:13px; font-weight:500; letter-spacing:.05em;
  color: var(--ec-ink-2); cursor:pointer; transition: all .3s;
  font-family: var(--font-body,'Inter',sans-serif);
}
.ec-cat:hover { border-color:var(--ec-gold); color:var(--ec-gold-d); background:rgba(255,252,245,1); }
.ec-cat.is-active {
  background: linear-gradient(135deg, var(--ec-gold-l), var(--ec-gold));
  color:#fff; border-color:transparent;
  box-shadow:0 4px 16px rgba(200,152,90,.35);
}
.ec-grid {
  max-width: 1280px; margin:0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(288px, 1fr));
  gap: 22px;
}

/* ─── CARD ─── */
.ec-card {
  position:relative; background:#fff; border-radius:22px;
  border:1px solid var(--ec-line); overflow:hidden;
  box-shadow:0 4px 20px rgba(180,130,70,.08);
  transition: transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s, border-color .4s;
  display:flex; flex-direction:column;
}
.ec-card:hover { transform:translateY(-7px); box-shadow:0 22px 52px rgba(180,130,70,.2); border-color:var(--ec-gold-l); }
.ec-card__badge {
  position:absolute; top:14px; left:14px; z-index:2;
  background:linear-gradient(135deg, var(--ec-gold-l), var(--ec-gold));
  color:#fff; font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  padding:5px 12px; border-radius:999px; box-shadow:0 3px 10px rgba(200,152,90,.4);
}
.ec-card__media {
  position:relative; aspect-ratio:1;
  background: linear-gradient(135deg, #fdf0dc, #f0e0c4); overflow:hidden; flex-shrink:0;
}
.ec-card__img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s ease; }
.ec-card:hover .ec-card__img { transform:scale(1.07); }
.ec-card__icon-bg {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 50% 40%, rgba(244,217,155,.55), rgba(240,212,180,.2));
}
.ec-card__icon-bg svg { width:72px; height:72px; }
.ec-card__chip {
  position:absolute; bottom:12px; right:12px;
  background:rgba(255,255,255,.88); backdrop-filter:blur(6px);
  border:1px solid rgba(200,152,90,.3); border-radius:999px;
  padding:4px 11px; font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ec-gold-d); font-weight:600;
}
.ec-card__body { padding:20px 22px 22px; display:flex; flex-direction:column; gap:6px; flex:1; }
.ec-card__dur { font-size:11px; color:var(--ec-gold-d); letter-spacing:.1em; font-weight:500; }
.ec-card__name { font-family:var(--font-display,serif); font-size:19px; font-weight:400; color:var(--ec-ink); line-height:1.2; margin:0; }
.ec-card__desc { font-size:14px; color:var(--ec-ink-2); line-height:1.55; flex:1; margin:0; }
.ec-card__foot {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-top:10px; padding-top:14px; border-top:1px solid var(--ec-line);
}
.ec-card__prices { display:flex; flex-direction:column; gap:2px; }
.ec-card__price-main { font-family:var(--font-display,serif); font-size:24px; color:var(--ec-gold-d); font-weight:400; line-height:1; }
.ec-card__price-alt { font-size:11px; color:var(--ec-ink-2); letter-spacing:.06em; }
.ec-card__add {
  width:38px; height:38px; border-radius:50%;
  background:linear-gradient(135deg, var(--ec-gold-l), var(--ec-gold));
  border:none; color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:14px; flex-shrink:0;
  box-shadow:0 4px 12px rgba(200,152,90,.35);
  transition: transform .3s, box-shadow .3s, background .3s;
}
.ec-card__add:hover { transform:scale(1.14); box-shadow:0 6px 20px rgba(200,152,90,.5); }
.ec-card__add.is-done { background:linear-gradient(135deg,#2ee06a,#25d366); font-size:15px; }

/* ─── CART DRAWER ─── */
.ec-backdrop {
  position:fixed; inset:0; z-index:90;
  background:rgba(20,8,18,.45); backdrop-filter:blur(3px);
  opacity:0; pointer-events:none; transition:opacity .35s;
}
.ec-backdrop.is-open { opacity:1; pointer-events:all; }
.ec-drawer {
  position:fixed; top:0; right:0; bottom:0; z-index:91;
  width:min(420px, 100vw);
  background:var(--ec-cream);
  box-shadow:-10px 0 60px rgba(20,8,18,.25);
  display:flex; flex-direction:column;
  transform:translateX(105%); transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.ec-drawer.is-open { transform:translateX(0); }
.ec-drawer__head {
  display:flex; justify-content:space-between; align-items:flex-start;
  padding:22px 24px 16px; border-bottom:1px solid var(--ec-line);
  background:rgba(255,252,245,.95); backdrop-filter:blur(8px); flex-shrink:0;
}
.ec-drawer__head h3 { font-family:var(--font-display,serif); font-size:24px; font-weight:400; margin:0; color:var(--ec-ink); }
.ec-drawer__count { font-size:12px; color:var(--ec-ink-2); letter-spacing:.08em; }
.ec-drawer__close {
  background:rgba(200,152,90,.12); border:none; border-radius:50%;
  width:34px; height:34px; color:var(--ec-ink-2); cursor:pointer;
  font-size:14px; display:flex; align-items:center; justify-content:center;
  transition:background .25s; flex-shrink:0;
}
.ec-drawer__close:hover { background:rgba(200,152,90,.25); }
.ec-drawer__empty {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:18px;
  padding:40px; color:var(--ec-ink-2); text-align:center;
}
.ec-drawer__empty p { font-family:var(--font-display,serif); font-style:italic; font-size:20px; }
.ec-drawer__items { flex:1; overflow-y:auto; padding:16px 24px; display:flex; flex-direction:column; gap:10px; }
.ec-ditem {
  display:flex; align-items:center; gap:12px;
  padding:14px 16px; border-radius:14px;
  background:rgba(255,252,245,.9); border:1px solid var(--ec-line);
}
.ec-ditem__info { flex:1; display:flex; flex-direction:column; gap:3px; min-width:0; }
.ec-ditem__type { font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ec-gold-d); }
.ec-ditem__name { font-size:14px; font-weight:500; color:var(--ec-ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ec-ditem__unit { font-size:12px; color:var(--ec-ink-2); }
.ec-ditem__qty { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.ec-ditem__qty button {
  width:26px; height:26px; border-radius:50%; border:1px solid var(--ec-line);
  background:#fff; color:var(--ec-ink); cursor:pointer; font-size:16px;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
}
.ec-ditem__qty button:hover { background:var(--ec-gold-l); border-color:var(--ec-gold); color:#fff; }
.ec-ditem__qty span { font-size:14px; font-weight:600; min-width:18px; text-align:center; }
.ec-ditem__sub { font-family:var(--font-display,serif); font-size:18px; color:var(--ec-gold-d); flex-shrink:0; }
.ec-drawer__footer { padding:18px 24px 28px; border-top:1px solid var(--ec-line); display:flex; flex-direction:column; gap:14px; flex-shrink:0; background:rgba(255,252,245,.95); }
.ec-drawer__total { display:flex; justify-content:space-between; align-items:center; }
.ec-drawer__total > span { font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--ec-ink-2); }
.ec-drawer__total-usd { font-family:var(--font-display,serif); font-size:30px; color:var(--ec-gold-d); }
.ec-drawer__total-pen { font-size:13px; color:var(--ec-ink-2); display:block; text-align:right; }
.ec-drawer__order { width:100%; justify-content:center; padding:16px; font-size:15px; }
.ec-drawer__keep { background:transparent; border:none; color:var(--ec-ink-2); font-size:13px; cursor:pointer; text-decoration:underline; text-align:center; font-family:var(--font-body,'Inter',sans-serif); }

/* ─── MACHU ─── */
.ec-machu {
  position:relative; padding:130px 32px 190px; overflow:hidden;
  background:linear-gradient(180deg, #1d1224 0%, #2a1a30 40%, #4a2c44 80%, #6b3a52 100%);
  color:#fff8ec;
}
.ec-machu__bg { position:absolute; inset:0; z-index:1; }
.ec-machu .andes-svg { position:absolute; bottom:0; left:0; right:0; width:100%; height:60%; z-index:2; }
.ec-machu__content { position:relative; z-index:3; max-width:800px; margin:0 auto; text-align:center; display:flex; flex-direction:column; align-items:center; gap:14px; }
.ec-machu__photo { position:relative; width:180px; height:180px; margin-bottom:20px; }
.ec-machu__photo img { width:100%; height:100%; object-fit:cover; object-position:center 25%; border-radius:50%; border:3px solid rgba(244,217,155,.72); box-shadow:0 20px 60px rgba(0,0,0,.4), 0 0 50px rgba(244,217,155,.25); display:block; }
.ec-machu__ring { position:absolute; inset:-14px; border-radius:50%; border:1px dashed rgba(244,217,155,.45); animation:ec-spin 60s linear infinite; pointer-events:none; }
@keyframes ec-spin { to { transform:rotate(360deg); } }
.ec-machu__text { font-size:clamp(16px,1.5vw,20px); color:rgba(255,248,236,.88); line-height:1.65; max-width:680px; }

/* ─── TESTIMONIALS ─── */
.ec-testi { padding:80px 32px; background:var(--ec-cream-2,#f3ecdf); }
.ec-tgrid { max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px; }
.ec-tcard { background:rgba(255,252,245,.9); border:1px solid var(--ec-line); border-radius:18px; padding:36px 26px 24px; margin:0; position:relative; }
.ec-tcard__star { position:absolute; top:14px; right:18px; color:var(--ec-gold-l); font-size:16px; opacity:.8; }
.ec-tcard blockquote { font-family:var(--font-display,serif); font-style:italic; font-size:17px; line-height:1.55; color:var(--ec-ink); margin:0 0 16px; }
.ec-tcard figcaption { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ec-gold-d); font-weight:600; }

/* ─── FINAL CTA ─── */
.ec-final {
  position:relative; padding:120px 32px; overflow:hidden; text-align:center;
  background:radial-gradient(ellipse at 50% 30%, rgba(255,240,200,.65), transparent 60%), linear-gradient(180deg,#f3ecdf 0%,#ece0cb 100%);
}
.ec-final__bg { position:absolute; inset:0; pointer-events:none; }
.ec-final__content { position:relative; z-index:2; max-width:720px; margin:0 auto; display:flex; flex-direction:column; align-items:center; gap:10px; }
.ec-final__content p { font-size:18px; color:var(--ec-ink-2); }
.ec-final__ctas { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:28px; }

/* ─── FOOTER ─── */
.ec-footer { background:#2a1d28; color:rgba(255,248,236,.72); padding:56px 32px 32px; }
.ec-footer__inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:40px; }
.ec-footer__brand { display:flex; flex-direction:column; gap:12px; }
.ec-footer__logo { height:50px; width:auto; max-width:200px; display:block; filter:brightness(0) invert(1); opacity:.88; }
.ec-footer__brand p { font-size:13px; line-height:1.5; margin:0; }
.ec-footer__wa { display:inline-flex; align-items:center; gap:8px; color:#4ee887; font-size:14px; font-weight:500; }
.ec-footer__wa svg { width:16px; height:16px; }
.ec-footer__links { display:flex; flex-direction:column; gap:10px; }
.ec-footer__links h4 { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ec-gold-l,#e9c789); margin:0 0 8px; }
.ec-footer__links a { font-size:14px; color:rgba(255,248,236,.6); transition:color .25s; }
.ec-footer__links a:hover { color:var(--ec-gold-l,#e9c789); }
.ec-footer__right { display:flex; flex-direction:column; gap:10px; align-items:flex-start; }
.ec-footer__right p { font-size:12px; color:rgba(255,248,236,.42); margin:0; }
.ec-footer__right .ec-pill { color:rgba(255,248,236,.68); border-color:rgba(255,248,236,.22); }
.ec-footer__right .ec-pill:hover { border-color:var(--ec-gold-l,#e9c789); color:var(--ec-gold-l,#e9c789); }

/* ─── RESPONSIVE ─── */
@media (max-width:1100px) { .ec-footer__inner { grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width:900px) {
  .ec-nav__links { display:none; }
  .ec-nav__logo { height:58px; }
  .ec-about__inner { grid-template-columns:1fr; gap:40px; }
  .ec-about__collage { max-width:420px; margin:0 auto; width:100%; }
  .ec-about__stats { grid-template-columns:1fr 1fr; }
  .ec-hero__headline { font-size:clamp(42px,12vw,68px); }
}
@media (max-width:640px) {
  .ec-frame { margin:12px 8px; border-radius:20px; }
  .ec-about { padding:50px 20px; }
  .ec-shop { padding:50px 16px; }
  .ec-testi { padding:50px 16px; }
  .ec-final { padding:80px 20px; }
  .ec-footer__inner { grid-template-columns:1fr; gap:24px; }
  .ec-hero__content { padding:0 20px 70px; }
  .ec-hero__ctas { flex-direction:column; align-items:center; }
  .ec-nav__inner { padding:10px 16px; }
  .ec-nav__logo { height:48px; }
  .ec-grid { grid-template-columns:1fr 1fr; gap:12px; }
  .ec-card__body { padding:14px 14px 16px; }
  .ec-card__name { font-size:16px; }
  .ec-card__price-main { font-size:20px; }
}
@media (max-width:420px) { .ec-grid { grid-template-columns:1fr; } }

/* ═══════════════════════════════════════════
   ADDITIONS v3 — portrait, grid, logo, checkout
   ═══════════════════════════════════════════ */

/* Hero: dos columnas (texto izquierda, retrato derecha) */
.ec-hero__content {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 48px;
  max-width: 1100px;
  width: calc(100% - 80px);
  text-align: left;
  padding: 0;
}
.ec-hero__text-col { flex: 1 1 0; min-width: 0; }
.ec-hero__text-col .ec-hero__sub  { max-width: 100%; margin: 0 0 36px; }
.ec-hero__text-col .ec-hero__ctas { justify-content: flex-start; }

.ec-hero__headline--new {
  font-size: clamp(40px, 6vw, 88px);
  line-height: 1.08;
  color: #7B1034;
  margin: 0 0 20px;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.9s 0.3s ease, transform 0.9s 0.3s ease;
}
.ec-hero__headline--new.is-in { opacity: 1; transform: translateY(0); }

.ec-hero__portrait-col {
  flex: 0 0 252px;
  align-self: center;
  opacity: 0;
  transform: translateX(18px);
  transition: opacity 0.9s 0.5s ease, transform 0.9s 0.5s ease;
}
.ec-hero__portrait-col.is-in { opacity: 1; transform: translateX(0); }
.ec-hero__portrait-col img {
  display: block;
  width: 252px;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.45);
}

@media (max-width: 780px) {
  .ec-hero { height: auto; min-height: 100svh; min-height: 100vh; }
  .ec-hero__content {
    flex-direction: column;
    text-align: center;
    align-items: center;
    width: calc(100% - 32px);
    padding: 100px 0 60px;
    gap: 24px;
  }
  .ec-hero__text-col { order: 2; }
  .ec-hero__portrait-col { order: 1; flex: 0 0 auto; }
  .ec-hero__portrait-col img { width: 150px; height: auto; border-radius: 14px; }
  .ec-hero__text-col .ec-hero__ctas { justify-content: center; }
  .ec-hero__headline--new { font-size: clamp(28px, 8vw, 52px); color: #7B1034; }
  .ec-hero__sub { font-size: clamp(15px, 4vw, 20px); }
}


/* ─── EMPTY STATE GRID ─── */
.ec-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 48px 20px;
  color: var(--ec-ink-2);
  font-family: var(--font-display, 'Cormorant Garamond', serif);
  font-style: italic;
  font-size: 18px;
  opacity: 0.65;
}
/* ─── CHECKOUT MODAL ─── */
.ck-overlay {
  position:fixed; inset:0;
  background:rgba(30,15,8,.72); backdrop-filter:blur(6px);
  z-index:9000; display:flex; align-items:center; justify-content:center;
  padding:16px; overflow-y:auto;
}
.ck-modal {
  background:#fdf8f2; border-radius:24px;
  width:100%; max-width:540px;
  box-shadow:0 32px 80px rgba(0,0,0,.35);
  overflow:hidden; position:relative;
  max-height:92vh; overflow-y:auto; scrollbar-width:thin;
}
.ck-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px 14px; border-bottom:1px solid #e8dcc8; background:#fff;
}
.ck-steps { display:flex; align-items:center; gap:6px; }
.ck-step {
  display:flex; align-items:center; gap:6px;
  font-size:0.78rem; color:#b0957a; font-weight:500;
}
.ck-step span {
  width:22px; height:22px; border-radius:50%; background:#e8dcc8;
  color:#8a6a4a; font-size:0.72rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.ck-step.is-active span { background:#c8985a; color:#fff; }
.ck-step.is-done span { background:#4caf50; color:#fff; }
.ck-step.is-active { color:#3d2f2a; }
.ck-step-line { width:24px; height:1px; background:#ddd; flex-shrink:0; }
.ck-close { background:none; border:none; font-size:1.1rem; cursor:pointer; color:#8a6a4a; padding:4px 8px; line-height:1; }
.ck-body { padding:24px; display:flex; flex-direction:column; gap:14px; }
.ck-title { font-family:var(--font-display,'Cormorant Garamond',serif); font-size:1.4rem; font-weight:500; color:#3d2f2a; margin:0; }
.ck-summary { background:#fff; border-radius:12px; border:1px solid #e8dcc8; padding:12px 16px; display:flex; flex-direction:column; gap:6px; }
.ck-sitem { display:flex; justify-content:space-between; font-size:0.84rem; color:#5a4535; }
.ck-stotal { display:flex; justify-content:space-between; padding-top:8px; margin-top:4px; border-top:1px solid #e8dcc8; font-size:0.9rem; color:#3d2f2a; }
.ck-stotal small { font-size:0.75rem; color:#8a6a4a; margin-left:4px; }
.ck-form { display:flex; flex-direction:column; gap:12px; }
.ck-field { display:flex; flex-direction:column; gap:5px; }
.ck-field label { font-size:0.78rem; font-weight:600; color:#6b4f3a; letter-spacing:.03em; text-transform:uppercase; }
.ck-field input, .ck-field select {
  padding:11px 14px; border:1.5px solid #ddd0be; border-radius:10px;
  font-size:0.92rem; color:#3d2f2a; background:#fff; outline:none;
  transition:border-color .2s; font-family:inherit;
}
.ck-field input:focus, .ck-field select:focus { border-color:#c8985a; }
.ck-err { font-size:0.74rem; color:#c0392b; }
.ck-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.ck-btn-main { width:100%; justify-content:center; padding:15px !important; font-size:1rem !important; margin-top:4px; border-radius:12px !important; }
.ck-back { background:none; border:none; color:#8a6a4a; font-size:0.85rem; cursor:pointer; padding:0; text-align:center; }
.ck-back:hover { color:#3d2f2a; }
.ck-secure-badge {
  display:flex; align-items:center; gap:8px; font-size:0.8rem;
  color:#4a7c59; background:#f0faf3; border:1px solid #c3e6cb; border-radius:8px; padding:8px 12px;
}
.ck-card-preview {
  background:linear-gradient(135deg,#3d2f2a 0%,#6b4522 60%,#c8985a 100%);
  border-radius:16px; padding:24px; color:#fff; font-family:'Courier New',monospace;
  min-height:160px; display:flex; flex-direction:column; justify-content:space-between;
  box-shadow:0 12px 32px rgba(100,60,20,.35);
}
.ck-card-chip { margin-bottom:16px; }
.ck-card-num { font-size:1.15rem; letter-spacing:.18em; color:rgba(255,255,255,.9); }
.ck-card-bottom { display:flex; justify-content:space-between; font-size:0.8rem; color:rgba(255,255,255,.75); text-transform:uppercase; letter-spacing:.06em; }
.ck-total-row {
  display:flex; justify-content:space-between; align-items:baseline;
  background:#fff; border-radius:10px; padding:12px 16px;
  border:1px solid #e8dcc8; font-size:0.9rem; color:#3d2f2a;
}
.ck-total-row small { font-size:0.75rem; color:#8a6a4a; }
.ck-processing { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:60px 32px; gap:16px; text-align:center; }
.ck-spinner { position:relative; width:80px; height:80px; display:flex; align-items:center; justify-content:center; }
.ck-spin-ring { position:absolute; inset:0; border:3px solid #e8dcc8; border-top-color:#c8985a; border-radius:50%; animation:ck-spin 1s linear infinite; }
@keyframes ck-spin { to { transform:rotate(360deg); } }
.ck-processing p { font-size:1rem; color:#3d2f2a; margin:0; }
.ck-processing small { font-size:0.78rem; color:#8a6a4a; }
.ck-success { display:flex; flex-direction:column; align-items:center; padding:40px 28px; gap:14px; text-align:center; }
.ck-success-icon svg { animation:ck-pop .5s cubic-bezier(.2,1.6,.5,1) forwards; }
@keyframes ck-pop { from{transform:scale(0.5);opacity:0;} to{transform:scale(1);opacity:1;} }
.ck-success h3 { font-family:var(--font-display,'Cormorant Garamond',serif); font-size:1.6rem; color:#3d2f2a; margin:0; }
.ck-order-num { font-size:1rem; color:#c8985a; font-weight:700; letter-spacing:.08em; margin:0; }
.ck-success-items { width:100%; background:#fff; border-radius:12px; border:1px solid #e8dcc8; padding:12px 16px; display:flex; flex-direction:column; gap:6px; text-align:left; }
.ck-success-msg { font-size:0.85rem; color:#6b4f3a; margin:0; line-height:1.5; }
