
:root{
  --bg:#f7f2eb;
  --surface:#fffaf4;
  --surface-2:#fbf5ee;
  --ink:#2b211a;
  --muted:#6f655d;
  --line:rgba(43,33,26,.10);
  --line-strong:rgba(43,33,26,.16);
  --shadow:0 14px 36px rgba(43,33,26,.07);
  --radius:24px;
  --radius-s:16px;
  --shell:1180px;
  --content:860px;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}
:focus-visible{outline:2px solid #8d7665;outline-offset:2px}
.skip-link{
  position:absolute;left:12px;top:12px;transform:translateY(-160%);
  z-index:100;padding:.8rem 1rem;border-radius:999px;background:var(--ink);color:#fff
}
.skip-link:focus{transform:none}
.shell{width:min(calc(100% - 24px),var(--shell));margin:0 auto}
.narrow{width:min(100%,var(--content));margin:0 auto}
section{padding:60px 0}
.stack > * + *{margin-top:1rem}

h1,h2,h3{
  margin:0;
  font-family:var(--serif);
  letter-spacing:-.02em;
  line-height:.98;
  font-weight:600;
}
h1{font-size:clamp(2rem,5.5vw,4rem)}
h2{font-size:clamp(1.8rem,4.6vw,3.3rem)}
h3{font-size:clamp(1.2rem,3vw,1.65rem)}
p{margin:0}
.lead{font-size:1.02rem;color:var(--muted);max-width:34rem}
.eyebrow{
  display:inline-block;
  margin-bottom:.4rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.78rem;
}
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.button-row{display:grid;gap:.75rem}
.button{
  min-height:50px;
  padding:.95rem 1.15rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:600;
  transition:transform .14s ease;
}
.button:hover{transform:translateY(-1px)}
.button-primary{background:var(--ink);color:#fff}
.button-secondary{background:var(--surface);border-color:var(--line-strong);color:var(--ink)}
.button-soft{background:var(--surface-2);border-color:var(--line);color:var(--ink)}
.button.is-disabled{opacity:.45;pointer-events:none}

.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(247,242,235,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(43,33,26,.06);
}
.header-row{
  min-height:86px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:.9rem;
}
.brand{width:min(11rem,42vw);min-width:8.6rem}
.brand img{width:100%;height:auto}
.header-nav,.desktop-cart,.desktop-cta{display:none}
.header-tools{display:flex;align-items:center;gap:.55rem}
.lang-switch{
  display:inline-flex;align-items:center;gap:.16rem;padding:.22rem;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.66)
}
.lang-switch a,.lang-switch span{
  min-width:2.05rem;min-height:2rem;padding:0 .62rem;border-radius:999px;display:inline-flex;
  align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--muted)
}
.lang-switch a[aria-current="page"]{background:var(--ink);color:#fff}
.menu-toggle{
  min-width:2.95rem;min-height:2.95rem;border-radius:999px;border:1px solid var(--line);
  background:var(--surface);color:var(--ink);cursor:pointer;padding:0 .95rem
}
.mobile-panel{display:none;padding-bottom:1rem}
.mobile-panel.is-open{display:block}
.mobile-nav,.mobile-actions{display:grid;gap:.7rem}
.mobile-nav a,.mobile-cart{
  display:flex;align-items:center;justify-content:space-between;padding:.95rem 1rem;border-radius:var(--radius-s);
  background:var(--surface);border:1px solid var(--line)
}
.cart-link{
  display:inline-flex;align-items:center;gap:.55rem;border-radius:999px;border:1px solid var(--line);
  background:var(--surface);padding:0 .95rem;min-height:44px
}
.cart-badge{
  min-width:1.55rem;height:1.55rem;padding:0 .35rem;border-radius:999px;background:var(--ink);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700
}

.hero{
  padding:54px 0 34px;
}
.hero-box{
  display:grid;
  gap:1rem;
  justify-items:start;
}
.hero-box .lead{max-width:30rem}
.safe-pill{
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.66);
  padding:.62rem .95rem;font-size:.9rem;color:var(--ink)
}

.section-head{margin-bottom:1rem}
.panel{padding:1.2rem}
.callout{
  padding:1.05rem 1rem;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:20px;
}
.callout p{max-width:38rem;line-height:1.64}

.format-grid,.contact-grid,.footer-grid,.info-grid,.order-layout{display:grid;gap:1rem}
.format-card,.contact-card,.form-card,.note-card,.delivery-card,.summary-card,.option-card,.cart-item{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
}
.format-card,.note-card,.delivery-card,.summary-card,.contact-card,.form-card,.cart-item{padding:1rem}
.product-photo{
  aspect-ratio:4/5;
  overflow:hidden;
  border-radius:18px;
  margin-bottom:.85rem;
  border:1px solid var(--line);
}
.product-photo img{width:100%;height:100%;object-fit:cover}
.price{font-size:1.02rem;color:var(--muted)}

.process-copy{
  display:grid;
  gap:.95rem;
  max-width:42rem;
}
.process-copy p{line-height:1.72}

.info-grid{
  align-items:start;
}
.note-card{
  position:relative;
  background:linear-gradient(180deg,#fffdf8,#faf4ec);
}
.note-card::before{
  content:"";
  position:absolute;
  left:18px;top:18px;bottom:18px;width:2px;background:rgba(210,150,150,.26)
}
.note-card::after{
  content:"";
  position:absolute;
  top:12px;right:16px;width:42px;height:12px;border-radius:999px;
  background:rgba(212,198,180,.72);transform:rotate(-8deg)
}
.note-title{
  font-family:var(--serif);
  font-size:1.3rem;
  margin:0 0 .55rem .72rem;
}
.note-list{
  margin:.2rem 0 0 .72rem;
  padding-left:1.05rem;
}
.note-list li + li{margin-top:.32rem}
.note-foot{
  display:block;margin:.6rem 0 0 .72rem;color:var(--muted);font-size:.82rem
}

.delivery-card{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#fff,#f8f4ee);
}
.delivery-card::before{
  content:"";
  position:absolute;left:0;right:0;top:0;height:68px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,239,231,.88));
  clip-path:polygon(0 0,100% 0,50% 62%);
}
.delivery-card::after{
  content:"✉";
  position:absolute;top:12px;right:14px;font-size:.96rem;color:var(--muted)
}
.delivery-card h3,.delivery-card p{position:relative;z-index:1}
.delivery-card h3{font-family:var(--sans);font-size:1.08rem;margin:0 0 .55rem;padding-top:1.8rem}
.delivery-card p{line-height:1.62}
.delivery-card p + p{margin-top:.7rem}

.painting-gallery{
  display:grid;
  gap:1rem;
  align-items:start;
}
.painting-main,.painting-detail{
  overflow:hidden;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow);background:#fffdfa
}
.painting-main{aspect-ratio:4/5}
.painting-detail{aspect-ratio:4/5}
.painting-main img,.painting-detail img{width:100%;height:100%;object-fit:cover;display:block}

.about-grid{
  display:grid;
  gap:1rem;
}
.about-portrait{
  width:7.2rem;aspect-ratio:1/1;border-radius:999px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:transparent;margin:0 auto
}
.about-portrait img{width:100%;height:100%;object-fit:contain;background:transparent}
.about-copy{display:grid;gap:.85rem}

.contact-intro{display:grid;gap:.3rem}
.contact-links{display:grid;gap:.75rem;margin-top:1rem}
.contact-link{
  display:flex;align-items:center;gap:.8rem;padding:.92rem 1rem;border-radius:18px;border:1px solid var(--line);
  background:rgba(255,255,255,.72)
}
.contact-icon{
  width:2.5rem;height:2.5rem;border-radius:14px;display:grid;place-items:center;font-weight:700;flex:0 0 auto
}
.contact-icon.email{background:#f3ebe0;color:var(--ink)}
.contact-icon.instagram{background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);color:#fff}
.contact-icon.tiktok{background:#111;color:#fff}
.contact-icon.whatsapp{background:#25D366;color:#fff}
.contact-copy{display:grid;gap:.08rem;min-width:0}
.contact-copy span{color:var(--muted);overflow-wrap:anywhere}

.field{display:grid;gap:.45rem}
.field span{font-size:.92rem;font-weight:600}
.input{
  width:100%;min-height:3rem;padding:.84rem 1rem;border-radius:16px;border:1px solid var(--line-strong);
  background:#fffdfa;color:var(--ink)
}
textarea.input{min-height:7rem;resize:vertical}

.page-hero{padding:38px 0 20px}
.option-grid{display:grid;gap:1rem}
.option-card{position:relative;padding:1rem}
.option-card input{position:absolute;inset:0;opacity:0;cursor:pointer}
.option-title{display:flex;align-items:center;gap:.75rem}
.radio{width:1.05rem;height:1.05rem;border-radius:999px;border:1.5px solid rgba(43,33,26,.22);background:#fff;flex:0 0 auto}
.option-card:has(input:checked){border-color:rgba(43,33,26,.22);box-shadow:0 0 0 2px rgba(43,33,26,.05)}
.option-card:has(input:checked) .radio{border-color:var(--ink);box-shadow:inset 0 0 0 5px var(--ink)}
.summary-card{padding:1.1rem}
.summary-line{display:flex;justify-content:space-between;gap:1rem}
.helper{color:var(--muted);font-size:.92rem}
.cart-list{display:grid;gap:1rem}

.footer{
  margin-top:54px;
  padding:30px 0 34px;
  border-top:1px solid rgba(43,33,26,.08);
}
.footer-grid{gap:.9rem}
.footer-brand{display:grid;gap:.35rem}
.footer-brand img{width:min(4.2rem,24vw)}
.footer-links,.footer-contact,.footer-meta{display:grid;gap:.2rem}
.footer-title{font-size:.83rem;font-weight:600;margin:0}
.footer small,.footer a,.footer p,.footer span{font-size:.82rem;color:var(--muted)}
.inline-links{display:flex;gap:.5rem 1rem;flex-wrap:wrap}
.footer-note{max-width:13rem;line-height:1.45}

@media (min-width:760px){
  .button-row{grid-template-columns:repeat(2,max-content);justify-content:start}
  .button{width:auto;min-width:12rem}
  .format-grid,.info-grid,.contact-grid,.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .about-grid{grid-template-columns:8rem minmax(0,1fr);align-items:center}
  .painting-gallery{grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr)}
  .painting-side{display:grid;gap:1rem}
}
@media (min-width:1000px){
  .header-row{
    grid-template-columns:auto minmax(0,1fr) auto;
    gap:1rem;min-height:94px
  }
  .brand{width:clamp(9rem,9vw,10rem);min-width:9rem}
  .header-nav{
    display:flex;align-items:center;justify-content:center;gap:1.15rem;min-width:0
  }
  .header-nav a{
    white-space:nowrap;color:var(--muted);font-weight:500;font-size:.97rem
  }
  .header-nav a:hover{color:var(--ink)}
  .desktop-cart{display:inline-flex}
  .desktop-cta{display:inline-flex;white-space:nowrap}
  .menu-toggle,.mobile-panel{display:none !important}
  .order-layout{grid-template-columns:1.06fr .94fr;align-items:start}
  .summary-card{position:sticky;top:108px}
  .footer-grid{grid-template-columns:1fr .9fr .95fr .85fr}
}
@media (max-width:1279px) and (min-width:1000px){
  .desktop-cta{display:none}
}


/* V20 clickable birth chart cards + cleaner delivery card */
.format-card.is-clickable{
  cursor:pointer;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.format-card.is-clickable:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 38px rgba(43,33,26,.10);
  border-color:rgba(43,33,26,.18);
}
.format-card.is-clickable:focus-within{
  box-shadow:0 0 0 2px rgba(43,33,26,.08), 0 18px 38px rgba(43,33,26,.10);
}
.card-add-hint{
  margin-top:.65rem;
  font-size:.84rem;
  color:var(--muted);
}
.inline-feedback{
  min-height:1.2rem;
  font-size:.88rem;
  color:var(--muted);
}
.delivery-card{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#fff,#f8f4ee) !important;
  padding:1rem !important;
}
.delivery-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:72px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,239,231,.88));
  clip-path:polygon(0 0,100% 0,50% 62%);
}
.delivery-head{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding-top:.2rem;
  margin-bottom:.6rem;
}
.delivery-head h3{
  font-family:var(--sans) !important;
  font-size:1.08rem !important;
  margin:0;
  padding-top:0 !important;
}
.delivery-icon{
  width:3rem;
  height:3rem;
  object-fit:contain;
  opacity:.95;
  flex:0 0 auto;
}
.delivery-copy{
  position:relative;
  z-index:1;
  padding-top:.2rem;
}
.delivery-copy p{
  line-height:1.62;
}
.delivery-copy p + p{
  margin-top:.72rem;
}
