:root{
  --ink:#2e2a63;
  --muted:#5d5b7c;
  --violet:#6752aa;
  --violet-dark:#463684;
  --blue:#477fc4;
  --lavender:#efe8fb;
  --soft-blue:#e9f2ff;
  --paper:#fffdfb;
  --shadow:0 22px 60px rgba(56,44,120,.16);
  --radius:28px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:var(--muted);
  background:
    radial-gradient(circle at 8% 25%, rgba(135,114,214,.22), transparent 23%),
    radial-gradient(circle at 92% 18%, rgba(80,135,210,.22), transparent 24%),
    radial-gradient(circle at 5% 82%, rgba(83,125,207,.18), transparent 18%),
    linear-gradient(180deg,#fffdfb 0%,#fbf8ff 50%,#fffdfb 100%);
  line-height:1.7;
}

a{color:inherit}

.topbar{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:22px 6vw;
  background:rgba(255,253,251,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(103,82,170,.10);
}

.brand{text-decoration:none;color:var(--ink)}
.brand-name{
  display:block;
  font-family:Georgia, 'Times New Roman', serif;
  font-style:italic;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1;
}
.brand-subtitle{
  display:block;
  margin-top:8px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  color:var(--violet);
}

.nav{display:flex;align-items:center;gap:26px;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink)}
.nav a{text-decoration:none;font-weight:700;white-space:nowrap}
.nav-button{
  color:#fff!important;
  background:linear-gradient(135deg,var(--violet),var(--violet-dark));
  padding:11px 18px;
  border-radius:999px;
  box-shadow:0 10px 24px rgba(70,54,132,.24);
}

.hero{
  position:relative;
  overflow:hidden;
  min-height:680px;
  padding:70px 6vw 40px;
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr .95fr;
  align-items:center;
  gap:40px;
}
.eyebrow,.section-kicker{
  color:var(--violet);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:700;
  font-size:.78rem;
}
h1,h2{
  font-family:Georgia, 'Times New Roman', serif;
  color:var(--ink);
  line-height:1.1;
  font-weight:500;
}
h1{font-size:clamp(3.2rem,7vw,6rem);margin:.2em 0 .25em}
h2{font-size:clamp(2rem,4vw,3rem);margin:.1em 0 .45em}
.lead{max-width:560px;font-size:1.13rem;color:#424064}
.hero-actions{display:flex;gap:18px;align-items:center;margin-top:34px;flex-wrap:wrap}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 28px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--violet-dark));
  box-shadow:0 14px 30px rgba(70,54,132,.20);
}
.button.ghost{background:transparent;color:var(--ink);box-shadow:none}
.button.small{min-height:44px;padding:0 22px;margin-top:14px}
.button.blue{background:linear-gradient(135deg,#5f91d2,#376db0)}
.hero-photo-wrap{position:relative;align-self:end;text-align:center}
.photo-aura{
  position:absolute;
  inset:8% 0 0 0;
  margin:auto;
  width:88%;
  height:82%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(231,224,249,.9), rgba(139,179,229,.35) 58%, transparent 70%);
  filter:blur(4px);
}
.hero-photo{
  position:relative;
  max-width:min(480px,100%);
  width:100%;
  display:block;
  margin:0 auto;
  border-radius:0 0 46% 46%;
  filter:drop-shadow(0 24px 35px rgba(53,43,96,.20));
}
.watercolor{position:absolute;z-index:1;pointer-events:none;filter:blur(.2px)}
.watercolor-left{
  left:-12%;top:16%;width:52%;height:54%;
  background:radial-gradient(circle at 45% 35%, rgba(169,139,220,.46), transparent 58%), radial-gradient(circle at 65% 60%, rgba(210,197,238,.48), transparent 64%);
  border-radius:46% 54% 56% 44% / 47% 50% 50% 53%;
}
.watercolor-right{
  right:-12%;top:9%;width:44%;height:48%;
  background:radial-gradient(circle at 50% 45%, rgba(60,112,193,.43), transparent 58%), radial-gradient(circle at 28% 70%, rgba(180,201,237,.42), transparent 62%);
  border-radius:54% 46% 44% 56% / 45% 56% 44% 55%;
}
.watercolor-bottom-left{
  left:-13%;bottom:0;width:36%;height:45%;
  background:radial-gradient(circle, rgba(70,116,202,.35), transparent 60%);
  border-radius:50%;
}

.values{
  max-width:1120px;
  margin:-10px auto 40px;
  padding:42px 6vw 20px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
}
.values article{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:14px;
  min-width:0;
  padding:8px 16px;
}
.values h2{
  font-family:Arial, Helvetica, sans-serif;
  font-size:1.12rem;
  font-weight:800;
  margin:0;
  color:var(--ink);
  line-height:1.25;
}
.values p{
  margin:0 auto;
  max-width:285px;
  font-size:.98rem;
  line-height:1.65;
  overflow-wrap:normal;
  word-break:normal;
}
.icon{
  width:76px;height:76px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#eee4fb,#dbeafb);
  color:var(--violet);font-size:2.05rem;
}

.section{padding:80px 6vw;position:relative;overflow:hidden}
.section-inner{max-width:1060px;margin:0 auto;text-align:center}.section-inner.narrow{max-width:850px;text-align:left}
.about p{font-size:1.06rem}.about{background:rgba(255,255,255,.45)}

.cards-section{padding:30px 6vw 60px}
.cards-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:26px}
.service-card{
  position:relative;
  overflow:hidden;
  min-height:420px;
  padding:42px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  border:1px solid rgba(103,82,170,.10);
}
.lavender-card{background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(238,229,249,.92))}
.blue-card{background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(229,241,255,.92))}
.service-card ul{padding-left:0;list-style:none;margin:22px 0}
.service-card li{margin:9px 0;padding-left:28px;position:relative}
.service-card li::before{content:'✓';position:absolute;left:0;color:var(--blue);font-weight:900}
.card-copy{position:relative;z-index:2;max-width:440px}
.line-art{position:absolute;right:32px;bottom:24px;font-size:12rem;color:rgba(103,82,170,.15);line-height:1}

.contact{background:rgba(255,253,251,.7)}
.contact-grid{margin-top:36px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.contact-card{
  display:flex;align-items:center;gap:18px;
  text-align:left;text-decoration:none;
  padding:24px;
  border-radius:20px;
  background:rgba(255,255,255,.76);
  border:1px solid rgba(103,82,170,.10);
  box-shadow:0 14px 38px rgba(56,44,120,.08);
}
.contact-icon{
  width:58px;height:58px;flex:0 0 58px;border-radius:50%;
  display:grid;place-items:center;
  color:white;background:linear-gradient(135deg,var(--violet),var(--blue));
  font-size:1.45rem;font-weight:800;
}
.contact-card strong{color:var(--ink)}

.footer{
  display:grid;
  grid-template-columns:1fr 1fr 1.3fr;
  gap:40px;
  padding:54px 6vw;
  color:#fff;
  background:
    radial-gradient(circle at 80% 30%,rgba(160,130,220,.55),transparent 30%),
    linear-gradient(135deg,#302565,#5f4ba2 58%,#477fc4);
}
.footer-name{font-family:Georgia,'Times New Roman',serif;font-style:italic;font-size:2.2rem}.footer p{margin:.7em 0 0}.footer nav{display:flex;flex-direction:column;gap:10px;text-transform:uppercase;font-weight:700;font-size:.9rem}.footer nav a{text-decoration:none}.footer blockquote{margin:0;font-family:Georgia,'Times New Roman',serif;font-size:1.25rem;line-height:1.6}

@media (max-width:900px){
  .topbar{position:relative;align-items:flex-start;flex-direction:column}.nav{width:100%;overflow:auto;gap:18px;padding-bottom:4px}.hero{padding-top:35px}.hero-content{grid-template-columns:1fr;text-align:center}.lead{margin-left:auto;margin-right:auto}.hero-actions{justify-content:center}.values,.cards-grid,.contact-grid,.footer{grid-template-columns:1fr}.values article{padding:6px 0}.service-card{padding:30px}.line-art{font-size:8rem;opacity:.75}.section-inner.narrow{text-align:left}
}
@media (max-width:560px){
  .brand-name{font-size:2.2rem}.brand-subtitle{font-size:.68rem}.nav{font-size:.78rem}.hero{min-height:auto}.hero-photo{max-width:330px}h1{font-size:3.1rem}.contact-card{padding:18px;overflow-wrap:anywhere}.footer{padding-bottom:40px}.service-card{min-height:auto}
}
