
:root{
  --cream:#fbf5ef;
  --ivory:#fffdf8;
  --mist:#f6ece5;
  --sand:#ead6ca;
  --blush:#e6bfae;
  --rose:#c99582;
  --clay:#a86f5c;
  --cocoa:#3e2f29;
  --taupe:#8a6e61;
  --champagne:#fff1da;
  --line:rgba(146,108,91,.22);
  --shadow:0 28px 70px rgba(105,71,56,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Manrope,system-ui,sans-serif;
  background:
    linear-gradient(180deg,var(--cream),#fffaf6 52%,var(--cream));
  color:var(--cocoa);
  overflow-x:hidden;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background-image:
    radial-gradient(1px 1px at 12% 18%, rgba(255,238,210,.48) 50%, transparent 51%),
    radial-gradient(1px 1px at 28% 72%, rgba(255,238,210,.36) 50%, transparent 51%),
    radial-gradient(1px 1px at 52% 34%, rgba(255,238,210,.42) 50%, transparent 51%),
    radial-gradient(1px 1px at 76% 24%, rgba(255,238,210,.44) 50%, transparent 51%),
    radial-gradient(1px 1px at 88% 68%, rgba(255,238,210,.34) 50%, transparent 51%),
    radial-gradient(1px 1px at 42% 88%, rgba(255,238,210,.32) 50%, transparent 51%);
  opacity:.36;
  animation:sparkleDrift 18s ease-in-out infinite alternate;
}
body:after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-2;
  opacity:.34;
  background-image:
    linear-gradient(90deg, rgba(124,91,75,.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(124,91,75,.035) 1px, transparent 1px),
    radial-gradient(circle at 24% 18%, rgba(234,214,202,.18), transparent 28%),
    radial-gradient(circle at 78% 72%, rgba(230,191,174,.12), transparent 30%);
  background-size: 42px 42px, 42px 42px, 100% 100%, 100% 100%;
  mix-blend-mode:multiply;
}
@keyframes sparkleDrift{
  0%{transform:translateY(0);opacity:.22}
  50%{transform:translateY(-2px);opacity:.42}
  100%{transform:translateY(2px);opacity:.3}
}
  50%{transform:translateY(-3px);opacity:.46}
  100%{transform:translateY(2px);opacity:.34}
}50%{opacity:.48}}
h1,h2,h3{font-family:"DM Serif Display",serif;font-weight:400;margin:0;letter-spacing:-.035em}
p{color:#6c554b;line-height:1.75}
a{text-decoration:none;color:inherit}
.container{width:min(1180px,calc(100% - 44px));margin:auto}
.eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--taupe);font-weight:800}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:15px 27px;
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;
  transition:.25s ease;
}
.primary{background:var(--cocoa);color:white;box-shadow:0 18px 36px rgba(62,47,41,.17)}
.primary:hover{transform:translateY(-2px);background:#251c18}
.outline{border:1px solid var(--line);background:rgba(255,253,248,.55);color:var(--cocoa)}
.outline:hover{background:white;transform:translateY(-2px)}
header{padding:24px 0;position:relative;z-index:5}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand small{
  display:block;
  font-family:"DM Serif Display",serif;
  font-size:36px;
  line-height:.88;
  letter-spacing:.045em;
  text-transform:uppercase;
  color:var(--cocoa);
  font-weight:400;
  margin-bottom:6px;
}
.brand strong{
  display:block;
  font-family:Manrope,system-ui,sans-serif;
  font-size:11px;
  line-height:1;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:800;
  text-align:center;
}
nav{display:flex;gap:28px;font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:#6c554b;font-weight:800}
.hero{padding:50px 0 96px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:62px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);background:rgba(255,253,248,.62);border-radius:999px;padding:10px 15px;margin-bottom:26px;box-shadow:0 14px 28px rgba(105,71,56,.06)}
.dot{width:9px;height:9px;border-radius:50%;background:var(--rose)}
.hero h1,.page-hero h1{font-size:clamp(54px,8vw,98px);line-height:.88;max-width:900px}
.hero p{font-size:18px;max-width:635px;margin:28px 0 34px}
.actions{display:flex;gap:14px;flex-wrap:wrap}
.meta{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px}
.meta span{border:1px solid var(--line);background:rgba(255,253,248,.45);border-radius:999px;padding:10px 14px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe);font-weight:800}
.visual{position:relative}
.art-card{
  min-height:620px;border-radius:58px;padding:23px;position:relative;overflow:hidden;
  background:linear-gradient(145deg,#fffaf5,#efdbd0);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:var(--shadow);
}
.balloon-art{
  min-height:574px;
  border-radius:46px;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(145deg, rgba(255,253,248,.68), rgba(234,214,202,.72)),
    linear-gradient(135deg,#f8eee8,#e2c1b2);
}
.balloon-art:before{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  bottom:18%;
  height:34%;
  background:
    linear-gradient(180deg, rgba(231,203,184,.55), rgba(218,182,157,.32));
  border-radius: 70% 30% 18% 18% / 55% 55% 22% 22%;
  transform:rotate(-1deg);
  box-shadow:
    -120px -18px 0 rgba(231,203,184,.24),
    120px -10px 0 rgba(231,203,184,.22);
}
.balloon-art:after{
  content:"Replace with your hero photo";
  position:absolute;left:26px;right:26px;bottom:26px;
  background:rgba(255,253,248,.78);border:1px solid rgba(255,255,255,.75);
  backdrop-filter:blur(12px);border-radius:33px;padding:24px;
  font-family:"DM Serif Display",serif;font-size:33px;line-height:1.05;color:var(--cocoa)
}
.seal{
  position:absolute;right:-28px;top:52px;width:156px;height:156px;border-radius:50%;
  background:var(--cocoa);color:white;display:grid;place-items:center;text-align:center;
  padding:22px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;transform:rotate(9deg);z-index:2
}
.float{
  position:absolute;left:-30px;bottom:45px;width:220px;padding:22px;border-radius:32px;
  background:rgba(255,253,248,.82);border:1px solid rgba(255,255,255,.8);
  box-shadow:0 22px 48px rgba(105,71,56,.13);backdrop-filter:blur(12px)
}
.float strong{font-family:"DM Serif Display",serif;font-size:27px;font-weight:400;display:block;line-height:1}
.float p{font-size:12px;margin:8px 0 0;line-height:1.45}
section{padding:88px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:32px;margin-bottom:38px}
.section-head h2{font-size:clamp(40px,5.5vw,66px);line-height:.95;max-width:780px}
.section-head p{max-width:390px;margin:0}
.grid{display:grid;gap:22px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}
.card,.panel,.step{
  background:rgba(255,253,248,.72);border:1px solid rgba(234,214,202,.88);
  border-radius:38px;padding:34px;box-shadow:0 20px 46px rgba(105,71,56,.07);position:relative;overflow:hidden
}

.card h3,.panel h3{font-size:31px;margin-bottom:12px;position:relative}
.card p,.panel p,.panel ul{position:relative}
.number{display:block;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--taupe);font-weight:800;margin-bottom:25px;position:relative}
.featured{background:linear-gradient(145deg,#ead6ca,#fff4ec)}
.statement-box{
  border-radius:52px;background:var(--cocoa);color:white;padding:60px;position:relative;overflow:hidden;
  display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:center
}


.statement-box h2{font-size:clamp(40px,5.2vw,64px);line-height:.95;color:white;position:relative}
.statement-box p{color:#ead6ca;font-size:18px;margin:0;position:relative}
.page-hero{text-align:center;padding:62px 0 42px;display:flex;justify-content:center;align-items:center}
.page-hero p{max-width:730px;margin:26px auto 0;font-size:18px}
.price{font-family:"DM Serif Display",serif;color:var(--cocoa);font-size:31px;margin:8px 0 10px}
.list{padding-left:18px;color:#6c554b;line-height:1.9}
.banner{
  border-radius:48px;background:#f3e8df;border:1px solid #ead6ca;padding:44px;
  display:flex;align-items:center;justify-content:space-between;gap:30px;position:relative;overflow:hidden
}

.banner h2{font-size:46px;margin-top:8px;position:relative}
.banner p,.banner a,.banner .eyebrow{position:relative}
.gallery{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:156px;gap:16px}
.tile{border-radius:36px;padding:24px;display:flex;align-items:end;font-family:"DM Serif Display",serif;font-size:29px;background:#fff;border:1px solid #ead6ca;position:relative;overflow:hidden}

.t1{grid-column:span 2;grid-row:span 2;background:#dfb8a6}.t2{grid-column:span 2;background:#fff8f4}.t3{grid-column:span 2;grid-row:span 2;background:#ead6ca}.t4{grid-column:span 2;background:#c99582;color:white}.t5{grid-column:span 2;background:#f5e9e1}.t6{grid-column:span 2;background:#fff}
.about-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:42px;align-items:center;background:rgba(255,255,255,.58);border:1px solid #ead6ca;border-radius:50px;padding:34px}
.portrait{min-height:475px;border-radius:40px;background:linear-gradient(145deg,#ead6ca,#d5a693);position:relative;overflow:hidden}
.portrait:before{
  content:"";
  position:absolute;
  inset:28px;
  border:1px solid rgba(255,255,255,.55);
  border-radius:30px;
}
.portrait:after{
  content:"";
  position:absolute;
  width:72%;
  height:42%;
  right:-8%;
  top:12%;
  background:rgba(255,255,255,.18);
  transform:rotate(-8deg);
  border-radius:28px;
}
.portrait-note{position:absolute;left:26px;right:26px;bottom:26px;background:rgba(255,253,248,.76);border:1px solid rgba(255,255,255,.75);backdrop-filter:blur(10px);border-radius:32px;padding:24px;font-family:"DM Serif Display",serif;font-size:31px;line-height:1.05}
.about-text{padding:20px 22px}.about-text h2{font-size:clamp(44px,5.5vw,70px);line-height:.95;margin:10px 0 22px}.about-text p{font-size:17px}
.form{display:grid;gap:16px}.field{display:grid;gap:8px}.field label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:800;color:var(--taupe)}
input,textarea,select{width:100%;border:1px solid #ead6ca;background:rgba(255,255,255,.75);border-radius:18px;padding:15px 16px;font-family:Manrope;color:var(--cocoa)}textarea{min-height:145px;resize:vertical}
.cta{text-align:center;padding:104px 0}.cta h2{font-size:clamp(52px,7vw,84px);line-height:.93}.cta p{max-width:650px;margin:24px auto 34px;font-size:18px}
.service-line{margin-top:28px;font-size:14px;color:#80675c;font-weight:700}
footer{border-top:1px solid #ead6ca;padding:30px 0;text-align:center;color:#80675c;font-size:13px;letter-spacing:.05em}
@media(max-width:900px){
  nav{display:none}.hero-grid,.statement-box,.about-wrap{grid-template-columns:1fr}.art-card{min-height:470px}.balloon-art{min-height:430px}
  .section-head{display:block}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}.tile{grid-column:span 1!important;grid-row:span 1!important}.banner{display:block}
  .container{width:min(100% - 34px,1180px)}section{padding:64px 0}.float{left:18px}.statement-box{padding:38px}.hero h1,.page-hero h1{font-size:52px}
}


/* Center page hero headlines intentionally */
.page-hero .container{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.page-hero h1,
.page-hero p,
.page-hero .eyebrow{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}


/* Refined brand lockup and texture details */
.brand{
  min-width:190px;
}
.card,.panel,.step,.banner,.about-wrap,.art-card{
  background-image:
    linear-gradient(90deg, rgba(124,91,75,.025) 1px, transparent 1px),
    linear-gradient(0deg, rgba(124,91,75,.02) 1px, transparent 1px);
  background-size:26px 26px;
}


/* Modern + softly animated Domilú logo */
.brand{
  min-width:210px;
  text-align:center;
  position:relative;
}

.brand small{
  display:block;
  font-family:"DM Serif Display",serif;
  font-size:42px;
  line-height:.88;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--cocoa);
  font-weight:400;
  margin-bottom:8px;
  position:relative;
  animation:logoBreath 7s ease-in-out infinite;
}

.brand small::after{
  content:"";
  position:absolute;
  right:-7px;
  top:5px;
  width:6px;
  height:6px;
  border-radius:50%;
  background:#e8caa7;
  opacity:.45;
  box-shadow:0 0 12px rgba(232,202,167,.65);
  animation:sparklePulse 4.8s ease-in-out infinite;
}

.brand strong{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-family:Manrope,system-ui,sans-serif;
  font-size:10px;
  line-height:1;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:800;
  text-align:center;
}

.brand strong::before,
.brand strong::after{
  content:"";
  display:block;
  width:28px;
  height:1px;
  background:linear-gradient(90deg, transparent, #d6b28a, transparent);
  opacity:.78;
  animation:lineShimmer 6s ease-in-out infinite;
}

@keyframes logoBreath{
  0%,100%{letter-spacing:.08em; opacity:1}
  50%{letter-spacing:.092em; opacity:.96}
}

@keyframes sparklePulse{
  0%,100%{transform:scale(.8); opacity:.28}
  45%{transform:scale(1.15); opacity:.72}
  60%{transform:scale(.95); opacity:.46}
}

@keyframes lineShimmer{
  0%,100%{opacity:.45; transform:scaleX(.86)}
  50%{opacity:.9; transform:scaleX(1)}
}
