/* ===== CRAFT STUDIO — Landing Page ===== */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Josefin+Sans:wght@300;400&display=swap');

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

:root{
  --cream   : #efebe7;
  --taupe   : #b9afa7;
  --gold    : #ddb564;
  --black   : #1a1a1a;
  --serif   : 'Cinzel', Georgia, serif;
  --sans    : 'Josefin Sans', sans-serif;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--black);
  background:var(--cream);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---------- background ---------- */
.page-wrapper{
  position:relative;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:1rem 1.5rem;
}

.page-wrapper::before{
  content:'';position:fixed;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(221,181,100,.12) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 80% 90%, rgba(185,175,167,.18) 0%, transparent 55%),
    radial-gradient(ellipse 90% 80% at 50% 50%, rgba(239,235,231,.6) 0%, transparent 70%);
  background-color:var(--cream);
}

.bg-wave{position:fixed;bottom:0;left:0;right:0;z-index:0;pointer-events:none;opacity:.35}
.bg-wave svg{display:block;width:100%;height:auto}
.bg-wave-top{position:fixed;top:0;left:0;right:0;z-index:0;pointer-events:none;opacity:.25;transform:rotate(180deg)}
.bg-wave-top svg{display:block;width:100%;height:auto}

/* ---------- card ---------- */
.card{
  position:relative;z-index:1;
  width:100%;max-width:580px;
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(221,181,100,.25);
  border-radius:28px;
  padding:1.8rem 2.5rem 1.4rem;
  box-shadow:
    0 4px 30px rgba(0,0,0,.06),
    0 1px 3px rgba(0,0,0,.04),
    inset 0 1px 0 rgba(255,255,255,.7);
  text-align:center;
  animation:cardIn .9s cubic-bezier(.22,1,.36,1) both;
}

@keyframes cardIn{
  from{opacity:0;transform:translateY(30px) scale(.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* ---------- logo ---------- */
.logo-wrap{
  margin-bottom:.9rem;
  animation:fadeUp .8s .15s cubic-bezier(.22,1,.36,1) both;
}
.logo-wrap img{
  width:min(340px, 80%);height:auto;
  display:block;margin:0 auto;
  filter:drop-shadow(0 2px 8px rgba(221,181,100,.15));
}

/* ---------- announcement ---------- */
.announcement{
  background: linear-gradient(135deg, #b9a491 0%, #8a7563 45%, #6e5e4f 100%);
  color:var(--cream);
  border-radius:16px;
  padding:1.2rem 2rem;
  margin-bottom:1.2rem;
  position:relative;overflow:hidden;
  animation:fadeUp .8s .3s cubic-bezier(.22,1,.36,1) both;
}

.announcement::before{
  content:'';position:absolute;
  top:-30%;right:-20%;width:200px;height:200px;
  background:radial-gradient(circle, rgba(221,181,100,.1) 0%, transparent 70%);
  border-radius:50%;pointer-events:none;
}

.announcement h2{
  font-family:var(--serif);font-weight:500;
  font-size:1rem;letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:.4rem;
}

.announcement .new-address{
  font-family:var(--serif);font-weight:500;
  font-size:1.65rem;letter-spacing:.04em;
  line-height:1.3;color:#fff;
}

.announcement .new-address span{
  display:block;font-family:var(--sans);
  font-size:.9rem;font-weight:300;
  color:#ece4dd;margin-top:.2rem;letter-spacing:.04em;
}

/* ---------- social links ---------- */
.socials{
  display:flex;justify-content:center;
  gap:1rem;margin-bottom:1.2rem;
  animation:fadeUp .8s .45s cubic-bezier(.22,1,.36,1) both;
}

.social-link{
  display:flex;flex-direction:column;
  align-items:center;gap:.5rem;
  text-decoration:none;color:var(--black);
  padding:.7rem 1.2rem;border-radius:16px;
  border:1px solid rgba(185,175,167,.3);
  background:rgba(255,255,255,.5);
  transition:all .3s ease;
  flex:1;max-width:150px;
}

.social-link:hover{
  border-color:var(--gold);
  background:rgba(221,181,100,.08);
  transform:translateY(-3px);
  box-shadow:0 8px 20px rgba(221,181,100,.12);
}

.social-link .social-icon{
  width:32px;height:32px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.social-link .social-icon svg{width:32px;height:32px}

.social-link .social-name{
  font-family:var(--sans);font-size:.75rem;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;color:var(--taupe);
}

.social-link .social-sub{
  font-family:var(--sans);
  font-size:.8rem;
  font-weight:300;
  letter-spacing:.04em;color:var(--taupe);
  margin-top:-.25rem;opacity:.7;
}

.social-link:hover .social-name{color:var(--gold)}

/* ---------- divider ---------- */
.divider{
  display:flex;align-items:center;gap:.8rem;
  margin-bottom:1rem;
  animation:fadeUp .8s .55s cubic-bezier(.22,1,.36,1) both;
}
.divider::before,.divider::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg, transparent, var(--taupe), transparent);
  opacity:.4;
}
.divider .star{color:var(--gold);font-size:.7rem}

/* ---------- services ---------- */
.services{
  animation:fadeUp .8s .65s cubic-bezier(.22,1,.36,1) both;
  margin-bottom:.8rem;
}

.services h3{
  font-family:var(--serif);font-weight:400;
  font-size:.9rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--taupe);
  margin-bottom:.7rem;
}

.services-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:.35rem .9rem;
}

.service-item{
  display:flex;align-items:center;gap:.55rem;
  padding:.35rem .7rem;border-radius:10px;
  transition:background .25s ease;
  font-family:var(--sans);font-size:.88rem;
  font-weight:300;letter-spacing:.03em;
  color:var(--black);text-align:left;
}
.service-item:hover{background:rgba(221,181,100,.07)}

.service-item .dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}

/* ---------- contact footer ---------- */
.contact-row{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:1.5rem;
  padding-top:.9rem;
  border-top:1px solid rgba(185,175,167,.25);
  animation:fadeUp .8s .75s cubic-bezier(.22,1,.36,1) both;
  margin-top:1.5rem;
}

.contact-item{
  display:flex;
  align-items:center;
  gap:.4rem;
  text-decoration:none;
  color:var(--taupe);
  font-family:var(--sans);
  font-size:.88rem;
  font-weight:300;
  letter-spacing:.02em;
  transition:color .25s ease;
}

.contact-item:hover{
  color:var(--gold);
}

.contact-item svg{
  width:14px;height:14px;
  flex-shrink:0;
  opacity:.7;
}

.contact-item:hover svg{
  opacity:1;
}

/* ---------- animations ---------- */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

/* ---------- sparkles ---------- */
.sparkle{
  position:absolute;width:3px;height:3px;
  background:var(--gold);border-radius:50%;opacity:0;
  animation:sparkle 3s ease-in-out infinite;
}
.sparkle:nth-child(1){top:12%;left:8%;animation-delay:0s}
.sparkle:nth-child(2){top:6%;right:15%;animation-delay:1.2s}
.sparkle:nth-child(3){bottom:18%;left:12%;animation-delay:2.1s}
.sparkle:nth-child(4){bottom:8%;right:10%;animation-delay:.6s}
.sparkle:nth-child(5){top:40%;right:5%;animation-delay:1.8s}

@keyframes sparkle{
  0%,100%{opacity:0;transform:scale(0)}
  50%{opacity:.6;transform:scale(1)}
}

/* ---------- responsive ---------- */
@media(max-width:480px){
  .page-wrapper{padding:.6rem 1rem}
  .card{padding:1.4rem 1.4rem 1.2rem;border-radius:22px}
  .logo-wrap img{width:min(280px,80%)}
  .logo-wrap{margin-bottom:.7rem}
  .announcement{padding:1rem 1.2rem;margin-bottom:1rem}
  .announcement .new-address{font-size:1.35rem}
  .socials{gap:.6rem;margin-bottom:1rem}
  .social-link{padding:.6rem .5rem;border-radius:14px}
  .social-link .social-icon svg{width:26px;height:26px}
  .services-grid{grid-template-columns:1fr;gap:.3rem}
  .service-item{font-size:.85rem;padding:.3rem .6rem}
  .contact-row{gap:1rem;flex-wrap:wrap}
  .contact-item{font-size:.8rem}
}
