:root{
  --ink:#252228;
  --ink-soft:#544d59;
  --paper:#fcfbfe;
  --lilac:#e8ddff;
  --blush:#ffdbe6;
  --mint:#dff7ea;
  --peach:#ffe8d6;
  --butter:#fff6c9;
  --accent:#b389ff;
  --ring:0 0 0 6px rgba(179,137,255,.15);
  --shadow:0 10px 30px rgba(46,42,50,.1), 0 2px 8px rgba(46,42,50,.07);
  --radius:20px;
  --radius-sm:14px;
  --gap:18px;
}

.atkinson-hyperlegible-bold {
  font-family: "Atkinson Hyperlegible", sans-serif;
  font-weight: 700;
  font-style: normal;
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:Inter, Segoe UI, Roboto, Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";
  color:var(--ink);
  background:
    radial-gradient(1200px 1200px at 10% -10%, var(--lilac), transparent 60%),
    radial-gradient(1200px 1200px at 110% 20%, var(--blush), transparent 60%),
    radial-gradient(1200px 1200px at 50% 120%, var(--mint), transparent 60%),
    var(--paper);
  line-height:1.6;
}

/* Layout */
.wrap {
  width:min(1100px, 92vw);
  margin-inline:auto
}

header {
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(10px);
  background:color-mix(in oklab, white 70%, transparent);
  border-bottom:1px solid color-mix(in oklab, var(--ink) 10%, transparent);
}
.nav {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:14px;
  width:min(1100px, 92vw);
  margin-inline:auto;
}
.brand {
  display:flex; gap:12px; align-items:center;
  text-decoration:none; color:inherit;
}
.brand-badge {
  width:60px; height:60px; border-radius:12px;
  display:grid; place-items:center;
  font-weight:800;
}

.brand-name {
  font-weight:800;
  letter-spacing:.2px;
  margin:0;
  line-height:1;
  font-size: 20px;
}

.nav nav{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.nav a{
  color:inherit; text-decoration:none;
  font-weight:600;
  padding:8px 12px;
  border-radius:10px;
}

.nav a:hover{
  background:color-mix(in oklab, var(--butter) 50%, transparent);
}

.nav .cta{
  background:var(--ink); color:white;
  padding:9px 14px; border-radius:12px;
  box-shadow:var(--shadow);
}

.nav .cta:hover{
  transform:translateY(-1px);
}

/* Banner */
.site-title-banner {
  padding:50px 0;
  text-align:center;
}

.site-title-banner h1 {
  font-family:"Playfair Display", serif;
  font-weight:800;
  line-height:1;
  font-size:clamp(48px, 8vw, 90px);
  margin:0;
  letter-spacing:.5px;
  color:var(--ink);
}

/* Hero */
.hero {padding:50px 0 10px}
.hero-grid {display:grid; grid-template-columns:1.2fr .8fr; gap:32px; align-items:center}
@media (max-width:900px) {
  .hero-grid {
    display: block;
    text-align: center;
  }
  .hero-card {
    margin: 10%;
  }
}

.hero-proof h3{
  font-family:"Playfair Display", serif;
  font-size:22px;
  margin:0 0 12px 0;
}

.hero-points{
  list-style:none;
  padding:0;
  margin:0 0 16px 0;
}

.hero-points li{
  margin-bottom:8px;
  font-weight:600;
  color:var(--ink-soft);
}

.hero-example{
  background:white;
  border-radius:var(--radius-sm);
  padding:14px;
  box-shadow:var(--shadow);
}

.hero-example span{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--ink-soft);
}

.hero-example strong{
  display:block;
  font-size:16px;
  margin-top:4px;
}

.hero-example p{
  margin:4px 0 0;
  font-size:14px;
  color:var(--ink-soft);
}


.kicker{
  display:inline-block;
  background:var(--butter);
  padding:6px 12px;
  border-radius:999px;
  font-weight:600;
  letter-spacing:.2px;
}

h2{
  font-family:"Playfair Display", serif;
  font-weight:700;
  line-height:1.1;
  font-size:clamp(34px, 5vw, 56px);
  margin:12px 0 10px;
  letter-spacing:.2px;
}

.lead{
  font-size:clamp(16px, 2.2vw, 20px);
  color:var(--ink-soft);
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:16px;
}
@media (max-width:900px){ .hero-actions{justify-content:center} }

.hero-card{
  background:linear-gradient(145deg, var(--lilac), var(--blush));
  border-radius:var(--radius);
  padding:20px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  display:grid;
  place-items:center;
}

.hero-card .bubble{
  position:absolute;
  inset:auto -30px -30px auto;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, white, rgba(255,255,255,.1));
  filter:blur(.5px);
  opacity:.7;
}

.trust-strip{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}

.trust-pill{
  background:white;
  border-radius:14px;
  padding:10px 14px;
  box-shadow:var(--shadow);
  font-weight:700;
  font-size:14px;
}

/* Sections */
.section{padding:50px 0}

.section h2{
  font-family:"Playfair Display", serif;
  font-size:clamp(26px, 3.6vw, 36px);
  margin:0 0 8px 0;
  color:var(--ink);
}

.sub{color:var(--ink-soft); margin:0 0 20px 0}

/* Popular package */
/* Highlight the most popular package */
.card.popular{
  position: relative;
  overflow: visible;
  background: var(--mint)
}

/* Subtle badge */
.popular-badge{
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink);
  color: white;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 999px;
  letter-spacing: .3px;
  box-shadow: var(--shadow);
  pointer-events: none;
}

.card.popular .card-body{
  border: 2px solid color-mix(in oklab, var(--ink) 15%, transparent);
  border-radius: var(--radius);
}


/* Generic grid cards */
.grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:var(--gap);
}

.card{
  background:white;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex;
  flex-direction:column;
}

.card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 40px rgba(46,42,50,.15);
}

.card-body{padding:16px 16px 18px}

.card h3{margin:0 0 6px 0; font-size:20px}
.desc{color:var(--ink-soft); margin:0 0 12px 0}

/* Process responsive grid */
.process-grid > .card{grid-column:span 12}
@media (min-width:641px){ .process-grid > .card{grid-column:span 6} }
@media (min-width:1001px){ .process-grid > .card{grid-column:span 4} }

.step-number{
  width:50px;
  height:50px;
  background:var(--lilac);
  border-radius:var(--radius-sm);
  display:grid;
  place-items:center;
  font-size:20px;
  font-weight:800;
  margin-bottom:12px;
}

/* Buttons */
.btn{
  display:inline-block;
  text-decoration:none;
  font-weight:800;
  font-size:14px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);
  background:linear-gradient(180deg, white, #f7f6fb);
}

.btn.primary{
  background:var(--ink);
  color:white;
  border-color:var(--ink);
}

.btn:focus-visible{
  outline:none;
  box-shadow:var(--ring);
}

/* Portfoliio notes */
.work-notes{
  margin-top:12px;
  padding:14px 16px;
  background:color-mix(in oklab, white 70%, transparent);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.work-notes ul{
  margin:0;
  padding-left:18px;
  color:var(--ink-soft);
  font-weight:600;
}

.detailed-about {
  font-size: 14px;
  font-weight: 400;
  list-style: none;
}

.work-cta{
  margin-top:20px;
  display:flex;
  justify-content:flex-start;
}
@media (max-width:900px){ .work-cta{justify-content:center} }

/* About */
.about{
  background:
    radial-gradient(800px 800px at -10% 20%, var(--mint), transparent 60%),
    radial-gradient(800px 800px at 110% 80%, var(--peach), transparent 60%);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow);
}

.about-note {
  margin-top:18px;
  background:white;
  border-radius:var(--radius);
  padding:16px 18px;
  box-shadow:var(--shadow);
  color:var(--ink-soft);
  font-weight:600;
}


/* Expertise */
.expertise-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:10px;
  text-align:center;
}
@media (max-width:768px){ .expertise-grid{grid-template-columns:1fr} }

.expertise-icon{
  font-size:28px;
  color:var(--accent);
  margin-bottom:12px;
}
.expertise-item h4{
  font-family:"Playfair Display", serif;
  font-size:20px;
  margin-bottom:8px;
}
.expertise-item p{
  color:var(--ink-soft);
  font-size:15px;
  margin:0;
  font-weight:600;
}

/* Packages */
.features-list{
  list-style:none;
  padding:0;
  margin:16px 0;
  text-align:left;
  color:var(--ink-soft);
  font-weight:600;
}
.features-list li{
  margin-bottom:8px;
  font-size:15px;
}

.price{
  font-size:18px;
  font-weight:800;
  margin:16px 0 10px;
}

.card .btn.primary{
  width:100%;
  text-align:center;
}

.package-fine{
  margin:10px 0 0;
  color:var(--ink-soft);
  font-weight:600;
  font-size:13px;
}

/* Pricing note */
.pricing-note{
  margin-top:18px;
  padding:14px 16px;
  background:white;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  color:var(--ink-soft);
  font-weight:600;
}

/* Testimonials */
.testimonial-card{
  background:white;
  padding:24px;
  box-shadow:var(--shadow);
  border-radius:var(--radius);
}
.testimonial-card blockquote{
  margin:0 0 16px 0;
  padding:0;
  font-size:17px;
  font-style:italic;
  color:var(--ink-soft);
  border-left:3px solid var(--lilac);
  padding-left:18px;
}
.testimonial-card cite{
  font-weight:400;
  font-style:normal;
}
.testimonial-card cite strong{
  font-weight:800;
  display:block;
}

/* Contact */
.contact-form-wrapper{
  background:white;
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow);
  max-width:650px;
  margin-inline:auto;
}

.form-group{margin-bottom:16px}

.form-group label{
  display:block;
  font-weight:700;
  margin-bottom:6px;
  font-size:14px;
}

input[type="text"],
input[type="email"],
select,
textarea{
  width:100%;
  padding:12px;
  font-size:16px;
  border:1px solid color-mix(in oklab, var(--ink) 15%, transparent);
  background:#fcfbfe;
  border-radius:12px;
  font-family:inherit;
  transition:border-color .2s ease, box-shadow .2s ease;
}

input[type="text"]:focus,
input[type="email"]:focus,
select:focus,
textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:var(--ring);
}

textarea{resize:vertical}

.email {
  text-align: center;
  align-items: center;
  margin: 20px auto;
  color: #544d59;
  font-size: small;
}

select{
  -webkit-appearance:none;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%232e2a32' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
}

form button.btn{
  width:100%;
  padding:14px;
  font-size:16px;
}

.form-fine{
  margin:12px 0 0;
  color:var(--ink-soft);
  font-weight:600;
  font-size:13px;
}

/* Portfolio */
.portfolio-item{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  display:block;
  height: 450px;
}

.portfolio-item .img-fluid{
  transition:transform .4s ease;
  width:100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

.portfolio-item:hover .img-fluid{
  transform:scale(1.05);
}

.portfolio-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(37,34,40,.8), transparent 60%);
  display:flex;
  align-items:flex-end;
  padding:24px;
  opacity:0;
  transition:opacity .4s ease;
}

.portfolio-item:hover .portfolio-overlay{
  opacity:1;
}

.portfolio-title{
  color:white;
  transform:translateY(10px);
  transition:transform .4s ease;
}

.portfolio-item:hover .portfolio-title{
  transform:translateY(0);
}

.portfolio-title h3{
  margin:0 0 4px 0;
  font-family:"Playfair Display", serif;
  font-size:20px;
}

.portfolio-title p{
  margin:0;
  font-size:14px;
  opacity:.9;
  font-weight:300;
}

/* Footer */
footer{
  padding:40px 0 50px;
  text-align:center;
  color:var(--ink-soft);
  font-size:14px;
}

/* Small screen nav spacing */
@media (max-width:520px){
  .brand-name{display:none}
  .nav nav{gap:4px}
}
