/* Flowstate Therapeutic Services — sunset pastel theme */
:root{
  /* Base */
  --bg: #120b1a;                  /* deep plum night */
  --surface: rgba(255, 255, 255, 0.07);
  --surface-2: rgba(255, 255, 255, 0.10);
  --text: rgba(255, 255, 255, 0.92);
  --muted: rgba(255, 255, 255, 0.72);
  --line: rgba(255, 255, 255, 0.14);

  /* Sunset pastels */
  --sun-peach: #ffd2b8;
  --sun-coral: #ff9aa2;
  --sun-lavender: #cdb4ff;
  --sun-rose: #ffb3d1;
  --sun-butter: #ffe29a;
  --sun-sky: #a8e6ff;

  /* Use these as “brand” accents throughout */
  --brand: var(--sun-peach);
  --brand-2: var(--sun-lavender);
  --accent: var(--sun-butter);

  --shadow: 0 12px 30px rgba(0,0,0,.35);
  --radius: 18px;

  --container: 1100px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }

body{
  margin: 0;
  font-family: var(--font);
  color: var(--text);

  /* Sunset pastel backdrop */
  background:
    radial-gradient(900px 600px at 12% 10%, rgba(255, 210, 184, 0.22), transparent 55%), /* peach */
    radial-gradient(850px 560px at 88% 14%, rgba(205, 180, 255, 0.20), transparent 52%), /* lavender */
    radial-gradient(900px 650px at 60% 85%, rgba(255, 226, 154, 0.16), transparent 55%), /* butter */
    radial-gradient(900px 650px at 25% 80%, rgba(255, 154, 162, 0.14), transparent 55%), /* coral */
    linear-gradient(180deg, #0a0711, var(--bg));
}

a{ color: inherit; text-decoration: none; }
a:hover{ text-decoration: underline; text-underline-offset: 3px; }

.container{
  width: min(var(--container), calc(100% - 2rem));
  margin-inline: auto;
}

.skip-link{
  position: absolute;
  left: -999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.skip-link:focus{
  left: 1rem;
  top: 1rem;
  width: auto;
  height: auto;
  padding: .75rem 1rem;
  background: rgba(10, 7, 17, 0.95);
  border: 1px solid var(--line);
  border-radius: 10px;
  z-index: 1000;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(10px);
  background: rgba(10, 7, 17, 0.74);
  border-bottom: 1px solid var(--line);
}
.header-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .9rem 0;
  gap: 1rem;
}

.brand{
  display: flex;
  gap: .75rem;
  align-items: center;
  min-width: 220px;
}
.brand-mark{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 28% 32%, rgba(255, 210, 184, 0.95), transparent 58%), /* peach */
    radial-gradient(circle at 78% 72%, rgba(205, 180, 255, 0.80), transparent 60%), /* lavender */
    radial-gradient(circle at 65% 30%, rgba(255, 226, 154, 0.55), transparent 55%), /* butter */
    rgba(255, 255, 255, 0.06);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.brand-text{ display: grid; line-height: 1.1; }
.brand-name{ font-weight: 740; letter-spacing: 0.2px; }
.brand-sub{ color: var(--muted); font-size: .9rem; }

.nav{
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.nav a{
  padding: .5rem .6rem;
  border-radius: 12px;
}
.nav a:not(.btn):hover{
  background: rgba(255,255,255,.06);
  text-decoration: none;
}

/* Sections */
.section{ padding: 4.2rem 0; }
.section-alt{
  background: linear-gradient(
    180deg,
    rgba(255, 210, 184, 0.05),
    rgba(205, 180, 255, 0.03),
    transparent
  );
  border-block: 1px solid var(--line);
}

.section-header{ margin-bottom: 1.75rem; }
.section-header h2{
  margin: 0 0 .4rem 0;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
}
.section-header p{
  margin: 0;
  color: var(--muted);
  max-width: 70ch;
}

/* Hero */
.hero{ padding: 4.6rem 0 3.5rem; }
.hero-grid{
  display: grid;
  gap: 1.6rem;
  grid-template-columns: 1.35fr .9fr;
  align-items: start;
}
.hero h1{
  margin: 0 0 1rem 0;
  font-size: clamp(2rem, 4.1vw, 3.2rem);
  line-height: 1.05;
  letter-spacing: -0.4px;
}
.lead{
  margin: 0 0 1.3rem 0;
  color: var(--muted);
  font-size: 1.06rem;
  max-width: 65ch;
}
.hero-actions{
  display: flex;
  gap: .8rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.hero-highlights{
  margin: 0;
  padding-left: 1.1rem;
  color: var(--muted);
}
.hero-highlights li{ margin: .35rem 0; }

/* Grid & cards */
.grid{ display: grid; gap: 1rem; }
.cards-3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
.split{ grid-template-columns: repeat(2, minmax(0, 1fr)); }

.card, .panel, details.card{
  background: linear-gradient(
    180deg,
    rgba(255, 210, 184, 0.08),
    rgba(205, 180, 255, 0.05)
  );
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.2rem;
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
}

.card-title{
  margin: 0 0 .5rem 0;
  font-size: 1.2rem;
}
.card-text{ margin: 0 0 .9rem 0; color: var(--muted); }

.card-list{
  margin: 1rem 0 1.1rem;
  display: grid;
  gap: .75rem;
}
.card-list dt{ color: var(--muted); font-size: .88rem; }
.card-list dd{ margin: 0; font-weight: 600; }

.bullets{
  margin: .75rem 0 0;
  padding-left: 1.1rem;
  color: var(--muted);
}
.bullets li{ margin: .35rem 0; }

.muted{ color: var(--muted); }
.fine-print{
  margin-top: .9rem;
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.35;
}

/* Buttons */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .85rem 1.05rem;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);

  /* Sunset pastel button glow */
  background:
    radial-gradient(120% 120% at 12% 18%, rgba(255, 210, 184, 0.55), transparent 56%),
    radial-gradient(120% 120% at 88% 62%, rgba(205, 180, 255, 0.40), transparent 58%),
    radial-gradient(120% 120% at 55% 30%, rgba(255, 226, 154, 0.30), transparent 55%),
    rgba(255,255,255,.06);

  box-shadow: var(--shadow);
  text-decoration: none;
  font-weight: 650;
}
.btn:hover{
  filter: brightness(1.05);
  text-decoration: none;
}
.btn:active{ transform: translateY(1px); }

.btn-ghost{ background: rgba(255,255,255,.04); }
.btn-small{ padding: .6rem .85rem; border-radius: 12px; }
.btn-wide{ width: 100%; }

/* Callout */
.callout{
  margin-top: 1.25rem;
  padding: 1.2rem;
  border-radius: var(--radius);
  border: 1px dashed rgba(255,255,255,.22);
  background:
    linear-gradient(180deg, rgba(255, 154, 162, 0.06), rgba(255, 226, 154, 0.04));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.callout h3{ margin: 0 0 .25rem 0; }
.callout p{ margin: 0; color: var(--muted); }

/* Tags */
.tags{
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .8rem;
}
.tag{
  display: inline-flex;
  align-items: center;
  padding: .45rem .65rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.86);
  font-size: .92rem;
}

/* Profiles */
.profile h3{ margin-bottom: .25rem; }
.avatar{
  width: 56px;
  height: 56px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 210, 184, 0.70), transparent 60%),
    radial-gradient(circle at 75% 70%, rgba(205, 180, 255, 0.55), transparent 58%),
    radial-gradient(circle at 60% 35%, rgba(255, 226, 154, 0.40), transparent 55%),
    rgba(255,255,255,.05);
  margin-bottom: .8rem;
}

/* Quotes */
.quote blockquote{
  margin: 0;
  color: rgba(255,255,255,.9);
  font-size: 1.02rem;
  line-height: 1.5;
}
.quote figcaption{
  margin-top: .8rem;
  color: var(--muted);
}

/* Details */
details summary{
  cursor: pointer;
  font-weight: 700;
  list-style: none;
}
details summary::-webkit-details-marker{ display: none; }
details summary::after{
  content: "▾";
  float: right;
  opacity: .8;
}
details[open] summary::after{ content: "▴"; }
details p{
  margin: .75rem 0 0;
  color: var(--muted);
}

/* Forms */
.form .field{ margin-bottom: .9rem; }
label{
  display: block;
  font-weight: 650;
  margin-bottom: .35rem;
}
input, textarea{
  width: 100%;
  padding: .75rem .8rem;
  color: var(--text);
  background: rgba(0,0,0,.20);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 14px;
  outline: none;
}
input:focus, textarea:focus{
  border-color: rgba(255, 210, 184, 0.75);
  box-shadow: 0 0 0 4px rgba(255, 210, 184, 0.16);
}

/* Contact aside */
.mini-note{
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}
.mini-note h4{ margin: 0 0 .25rem 0; }

/* Footer */
.site-footer{
  padding: 2.5rem 0;
  border-top: 1px solid var(--line);
  background: rgba(0,0,0,.18);
}
.footer-inner{ display: grid; gap: .4rem; }
.footer-inner p{ margin: 0; }

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .cards-3{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .callout{ flex-direction: column; align-items: flex-start; }
  .nav{ gap: .3rem; }
}