:root{
  --bg:#f6efe5;
  --bg2:#efe3d4;
  --ink:#2d2924;
  --soft:#756b60;
  --gold:#b99045;
  --gold2:#d6b772;
  --white:#fffaf3;
}

*{box-sizing:border-box;margin:0;padding:0}

html,body{min-height:100%}

body{
  font-family:"Montserrat",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(ellipse at 50% -5%, rgba(255,255,255,.95), rgba(255,255,255,.38) 30%, transparent 56%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  overflow-x:hidden;
}

.landing{
  min-height:100svh;
  position:relative;
  display:flex;
  justify-content:center;
  padding:18px 18px 24px;
  overflow:hidden;
}

.content{
  width:min(100%,430px);
  min-height:calc(100svh - 42px);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  position:relative;
  z-index:2;
  padding-top:10px;
}

.light{
  position:absolute;
  top:-115px;
  left:50%;
  width:170px;
  height:260px;
  transform:translateX(-50%);
  background:radial-gradient(ellipse at top, rgba(255,255,255,.98), rgba(255,255,255,.42) 42%, transparent 72%);
  filter:blur(2px);
  z-index:0;
}

.line{
  position:absolute;
  width:260px;
  height:720px;
  border:1.4px solid rgba(185,144,69,.55);
  border-radius:50%;
  pointer-events:none;
  z-index:1;
}

.line-left{left:-236px;top:-75px;transform:rotate(7deg)}
.line-right{right:-250px;top:260px;transform:rotate(-9deg)}

.social{
  width:100%;
  display:flex;
  justify-content:flex-end;
  gap:12px;
  margin-bottom:10px;
}

.social a{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  border-radius:16px;
  color:var(--gold);
  background:rgba(255,255,255,.47);
  border:1px solid rgba(185,144,69,.23);
  box-shadow:0 8px 22px rgba(67,49,23,.06), inset 0 1px 0 rgba(255,255,255,.7);
  text-decoration:none;
}

.social svg{width:24px;height:24px;fill:currentColor}

.brand{
  width:100%;
  display:flex;
  justify-content:center;
  margin:0 0 12px;
}

.logo{
  width:min(292px,72vw);
  height:auto;
  display:block;
  object-fit:contain;
  filter:drop-shadow(0 10px 18px rgba(55,42,24,.08));
}

h1{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:clamp(3.15rem,14vw,4.45rem);
  line-height:.91;
  font-weight:700;
  letter-spacing:-.052em;
  margin:4px 0 18px;
}

h1 em{
  display:block;
  color:var(--gold);
  font-style:italic;
  font-weight:600;
  margin-top:8px;
}

.divider{
  width:170px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(185,144,69,.52),transparent);
  margin:0 auto 25px;
  position:relative;
}

.divider:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:15px;
  height:15px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:#ead2a0;
  border:2px solid rgba(185,144,69,.32);
  box-shadow:0 0 16px rgba(185,144,69,.45);
}

.location{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:13px;
  margin-bottom:25px;
  transform:translateX(-6px);
}

.pin{
  width:37px;
  height:37px;
  fill:var(--gold);
  flex:none;
}

.location strong{
  display:block;
  font-size:clamp(1.35rem,5.9vw,1.75rem);
  letter-spacing:.27em;
  font-weight:700;
  transform:translateX(.12em);
}

.location span{
  display:block;
  margin-top:3px;
  font-size:clamp(.94rem,4vw,1.06rem);
  letter-spacing:.16em;
  color:var(--soft);
  font-weight:500;
  transform:translateX(.08em);
}

.buttons{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-bottom:26px;
}

.button{
  width:100%;
  min-height:78px;
  display:grid;
  grid-template-columns:62px 1fr;
  align-items:center;
  text-align:left;
  gap:2px;
  border-radius:28px;
  padding:14px 20px;
  text-decoration:none;
  color:var(--ink);
  background:rgba(255,255,255,.66);
  border:1px solid rgba(185,144,69,.22);
  box-shadow:0 14px 26px rgba(60,42,20,.065), inset 0 1px 0 rgba(255,255,255,.75);
}

.button-main{
  color:white;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  border-color:rgba(139,98,36,.16);
  box-shadow:0 14px 28px rgba(150,106,36,.22), inset 0 1px 0 rgba(255,255,255,.35);
}

.button svg{
  width:48px;
  height:48px;
  padding:10px;
  border-radius:50%;
  fill:currentColor;
  color:var(--gold);
  border:2px solid rgba(185,144,69,.42);
}

.button-main svg{
  color:white;
  border-color:rgba(255,255,255,.75);
}

.button b{
  display:block;
  font-size:clamp(1rem,4.55vw,1.2rem);
  letter-spacing:.09em;
  line-height:1.18;
}

.button small{
  display:block;
  margin-top:6px;
  color:inherit;
  opacity:.82;
  font-size:clamp(.82rem,3.55vw,.94rem);
  line-height:1.28;
}

.care{
  margin:2px 0 22px;
}

.care svg{
  width:30px;
  height:30px;
  fill:none;
  stroke:var(--gold);
  stroke-width:1.7;
  margin-bottom:9px;
}

.care p{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:clamp(1.72rem,8vw,2.35rem);
  line-height:1;
  font-weight:500;
  letter-spacing:-.035em;
}

.care em{
  display:block;
  margin-top:9px;
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:clamp(1.86rem,8.8vw,2.55rem);
  color:var(--gold);
  font-style:italic;
}

.address{
  width:100%;
  font-style:normal;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(185,144,69,.24);
  border-radius:24px;
  padding:20px 16px;
  box-shadow:0 14px 30px rgba(60,42,20,.055), inset 0 1px 0 rgba(255,255,255,.75);
}

.address span{
  display:block;
  font-size:clamp(.86rem,3.75vw,1rem);
  line-height:1.55;
  color:#514a42;
  letter-spacing:.03em;
  font-weight:500;
}

@media(max-width:360px){
  .landing{padding-left:14px;padding-right:14px}
  .logo{width:min(250px,68vw)}
  .button{min-height:72px;grid-template-columns:56px 1fr;padding:13px 17px}
  .button svg{width:43px;height:43px}
}
