:root {
  --font-family: "Libre Baskerville", sans-serif;
  --font-size-base: 16.2px;
  --line-height-base: 1.79;

  --max-w: 960px;
  --space-x: 1.45rem;
  --space-y: 1.5rem;
  --gap: 0.95rem;
  --space-section-y: calc(var(--space-y) * 2.4);
  --space-section-x: var(--space-x);
  --space-block: calc(var(--gap) * 1.5);
  --space-card: calc(var(--space-y) * .75);
  --font-size-sm: calc(var(--font-size-base) * .875);
  --font-size-md: var(--font-size-base);
  --font-size-lg: calc(var(--font-size-base) * 1.125);
  --font-size-h3: calc(var(--font-size-base) * 1.35);
  --font-size-h2: calc(var(--font-size-base) * 2);
  --font-size-h1: calc(var(--font-size-base) * 2.65);
  --motion-distance: calc(var(--gap) * var(--random-number));

  --radius-xl: 0.82rem;
  --radius-lg: 0.45rem;
  --radius-md: 0.35rem;
  --radius-sm: 0.25rem;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.08);
  --shadow-md: 0 2px 16px rgba(0,0,0,0.1);
  --shadow-lg: 0 6px 30px rgba(0,0,0,0.12);

  --overlay: rgba(255,255,255,0.7);
  --anim-duration: 430ms;
  --anim-ease: cubic-bezier(0.2,0.8,0.2,1);
  --random-number: 1;

  --brand: #b388ff;
  --brand-contrast: #ffffff;
  --accent: #ff80ab;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f5f5f5;
  --neutral-300: #e0e0e0;
  --neutral-600: #757575;
  --neutral-800: #424242;
  --neutral-900: #212121;

  --page-bg: #ffffff;
  --page-fg: #212121;
  --muted-bg: #f5f5f5;
  --muted-fg: #424242;
  --card-bg: #ffffff;
  --card-fg: #212121;
  --card-border: #e0e0e0;
  --inverse-bg: #212121;
  --inverse-fg: #ffffff;
  --primary-bg: #b388ff;
  --primary-fg: #ffffff;
  --primary-hover: #9c64e0;
  --accent-bg: #ff80ab;
  --accent-fg: #ffffff;
  --accent-hover: #f06292;
  --gradient-hero-bg: linear-gradient(135deg, #fce4ec 0%, #f3e5f5 50%, #e8eaf6 100%);
  --gradient-hero-fg: #212121;
  --gradient-accent-bg: linear-gradient(135deg, #b388ff 0%, #ff80ab 100%);
  --gradient-accent-fg: #ffffff;

  --ring: #b388ff;

  --link: #b388ff;
  --link-hover: #ff80ab;

  --btn-ghost-bg: transparent;
  --btn-ghost-bg-hover: color-mix(in srgb, currentColor 10%, transparent);
  --input-placeholder: rgba(255,255,255,0.55);
}
body{margin:0;padding:0;font-family:var(--font-family);box-sizing: border-box;}
*{box-sizing:border-box;}
a{color:inherit;}
.btn-primary,.btn.btn-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;border-color:var(--primary-bg)!important;}
.btn-primary:hover,.btn.btn-primary:hover{background:var(--primary-hover)!important;color:var(--primary-fg)!important;border-color:var(--primary-hover)!important;}
.btn-outline-primary{color:var(--primary-bg)!important;border-color:var(--primary-bg)!important;}
.btn-outline-primary:hover{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.bg-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.text-primary{color:var(--primary-bg)!important;}
.border-primary{border-color:var(--primary-bg)!important;}
.bg-light{background:var(--page-bg)!important;color:var(--page-fg)!important;}
.bg-dark{background:var(--inverse-bg)!important;color:var(--inverse-fg)!important;}

.site-header {
  background-color: var(--page-bg);
  border-bottom: 1px solid var(--muted-bg);
  width: 100%;
}

.header-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-y) var(--space-x);
}

.logo {
  font-size: var(--font-size-h2);
  font-weight: 700;
  color: var(--page-fg);
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: -0.02em;
}

.logo:hover {
  color: var(--link-hover);
}

.nav-menu {
  display: flex;
  align-items: center;
}

.nav-list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--gap);
}

.nav-link {
  font-size: var(--font-size-md);
  color: var(--page-fg);
  text-decoration: none;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  transition: background-color var(--anim-duration) var(--anim-ease), color var(--anim-duration) var(--anim-ease);
}

.nav-link:hover {
  background-color: var(--muted-bg);
  color: var(--link-hover);
}

.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: var(--radius-sm);
  transition: background-color var(--anim-duration) var(--anim-ease);
}

.burger:hover {
  background-color: var(--muted-bg);
}

.burger-line {
  display: block;
  width: 1.5rem;
  height: 2px;
  background-color: var(--page-fg);
  border-radius: 1px;
  transition: transform var(--anim-duration) var(--anim-ease), opacity var(--anim-duration) var(--anim-ease);
}

.burger-line + .burger-line {
  margin-top: 5px;
}

.burger.active .burger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.burger.active .burger-line:nth-child(2) {
  opacity: 0;
}

.burger.active .burger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 767px) {
  .burger {
    display: flex;
  }

  .nav-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--page-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--anim-duration) var(--anim-ease), visibility var(--anim-duration) var(--anim-ease);
    z-index: 100;
  }

  .nav-menu.open {
    opacity: 1;
    visibility: visible;
  }

  .nav-list {
    flex-direction: column;
    align-items: center;
    gap: var(--space-y);
  }

  .nav-link {
    font-size: var(--font-size-h3);
    padding: 0.5rem 1rem;
  }
}

.site-footer {
    background-color: #f9f4f0;
    color: #3a2e2a;
    font-family: 'Georgia', 'Times New Roman', serif;
    padding: 2.5rem 1.5rem 1.5rem;
    border-top: 2px solid #e0d3c8;
  }

  .footer-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }

  .footer-brand {
    text-align: center;
  }

  .footer-logo {
    font-size: 1.8rem;
    font-weight: 700;
    color: #b85c3a;
    text-decoration: none;
    letter-spacing: 0.02em;
  }

  .footer-logo:hover {
    color: #8f4428;
  }

  .footer-tagline {
    font-size: 0.95rem;
    color: #6b5a50;
    margin-top: 0.4rem;
    font-style: italic;
  }

  .footer-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1.2rem 2rem;
  }

  .footer-nav a {
    color: #3a2e2a;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 500;
    transition: color 0.2s;
  }

  .footer-nav a:hover {
    color: #b85c3a;
    text-decoration: underline;
  }

  .footer-contact {
    text-align: center;
  }

  .contact-info {
    font-style: normal;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    font-size: 0.95rem;
    line-height: 1.5;
  }

  .contact-item a {
    color: #3a2e2a;
    text-decoration: none;
  }

  .contact-item a:hover {
    color: #b85c3a;
    text-decoration: underline;
  }

  .footer-legal ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1rem 2rem;
  }

  .footer-legal a {
    color: #6b5a50;
    text-decoration: none;
    font-size: 0.9rem;
    border-bottom: 1px dotted transparent;
    transition: border-color 0.2s;
  }

  .footer-legal a:hover {
    border-bottom-color: #b85c3a;
    color: #b85c3a;
  }

  .footer-disclaimer {
    text-align: center;
    font-size: 0.85rem;
    color: #7a6a5e;
    line-height: 1.5;
    max-width: 800px;
    margin: 0 auto;
    padding: 0.5rem 0;
    border-top: 1px solid #e0d3c8;
  }

  .footer-disclaimer p {
    margin: 0;
  }

  .footer-copy {
    text-align: center;
    font-size: 0.85rem;
    color: #8a7a6e;
    margin-top: 0.5rem;
  }

  .footer-copy p {
    margin: 0;
  }

  @media (min-width: 768px) {
    .footer-container {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2rem 3rem;
    }

    .footer-brand {
      grid-column: 1 / 2;
      text-align: left;
    }

    .footer-nav {
      grid-column: 2 / 3;
      text-align: right;
    }

    .footer-nav ul {
      justify-content: flex-end;
    }

    .footer-contact {
      grid-column: 1 / 2;
      text-align: left;
    }

    .contact-info {
      align-items: flex-start;
    }

    .footer-legal {
      grid-column: 2 / 3;
      text-align: right;
    }

    .footer-legal ul {
      justify-content: flex-end;
    }

    .footer-disclaimer {
      grid-column: 1 / -1;
    }

    .footer-copy {
      grid-column: 1 / -1;
    }
  }

  @media (min-width: 1024px) {
    .footer-container {
      grid-template-columns: 2fr 1fr 1fr;
      gap: 2rem;
    }

    .footer-brand {
      grid-column: 1 / 2;
    }

    .footer-nav {
      grid-column: 2 / 3;
      text-align: left;
    }

    .footer-nav ul {
      flex-direction: column;
      gap: 0.6rem;
    }

    .footer-contact {
      grid-column: 3 / 4;
    }

    .footer-legal {
      grid-column: 1 / 2;
      text-align: left;
    }

    .footer-legal ul {
      justify-content: flex-start;
      gap: 1.5rem;
    }

    .footer-disclaimer {
      grid-column: 1 / -1;
    }

    .footer-copy {
      grid-column: 1 / -1;
    }
  }

.cookies{position:fixed;left:var(--space-x);right:var(--space-x);bottom:var(--space-y);z-index:1200;}

    .cookies .stack{max-width:860px;margin:0 auto;background:linear-gradient(145deg,var(--primary-bg),var(--inverse-bg));color:var(--primary-fg);border-radius:var(--radius-lg);padding:var(--space-y) var(--space-x);box-shadow:var(--shadow-lg);}

    .cookies .stack strong{display:block;margin-bottom:6px;}
    .cookies .stack p{margin:0;opacity:.9;}

    .cookies .actions{margin-top:12px;display:flex;flex-wrap:wrap;gap:10px;}

    .cookies .actions button{border:1px solid color-mix(in srgb, currentColor 40%, transparent);background:transparent;border-radius:999px;padding:7px 12px;cursor:pointer;}

    .cookies .actions button[data-choice='accept']{background:var(--accent-bg);border-color:transparent;color:var(--accent-fg);font-weight:700;}

.lead {
    padding: clamp(3.8rem, 8vw, 6.8rem) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
}

.lead .wrap {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    grid-template-columns:1.15fr .85fr;
    gap: 1rem;
}

.lead .copy, .lead .meta {
    padding: 1.1rem;
    border-radius: var(--radius-xl);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.lead .copy p {
    margin: 0;
    color: color-mix(in srgb, currentColor 76%, transparent);
    text-transform: uppercase;
    letter-spacing: .1em;
    font-size: .82rem;
}

.lead .copy h1 {
    margin: .65rem 0 0;
    font-size: clamp(2.5rem, 5vw, 4.8rem);
    line-height: 1.02;
}

.lead .copy span {
    display: block;
    margin-top: .95rem;
    max-width: 38rem;
}

.lead .actions {
    margin-top: 1.1rem;
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}

.lead .actions a {
    display: inline-flex;
    min-height: 2.8rem;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
    border-radius: var(--radius-md);
    text-decoration: none;
    border: 1px solid color-mix(in srgb, currentColor 22%, transparent);
    background: color-mix(in srgb, currentColor 12%, transparent);
}

.lead .actions a:first-child {
    background: var(--accent-bg);
    color: var(--accent-fg);
    border-color: var(--accent-hover);
}

.lead .meta {
    display: grid;
    align-content: center;
    gap: .7rem;
}

.lead .meta p, .lead .meta div {
    margin: 0;
    color: color-mix(in srgb, currentColor 88%, transparent);
}

@media (max-width: 860px) {
    .lead .wrap {
        grid-template-columns:1fr;
    }
}

.legal-quietpage{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.legal-quietpage .quietpage-wrap{max-width:var(--max-w);margin:0 auto;background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:1.2rem;box-shadow:var(--shadow-sm)}
.legal-quietpage h1{margin:0;color:var(--card-fg);font-size:clamp(2rem,4.4vw,3.6rem);line-height:1.04}
.legal-quietpage .quietpage-date{color:var(--link);font-weight:700}
.legal-quietpage h2{margin:1.3rem 0 0;color:var(--card-fg);font-size:clamp(1.25rem,2.5vw,1.8rem);line-height:1.15}
.legal-quietpage p{margin:.75rem 0 0;color:var(--card-fg);opacity:.84;line-height:1.58}
.legal-quietpage ul{margin:.75rem 0 0;padding-left:1.2rem;color:var(--card-fg)}
.legal-quietpage li{margin:.35rem 0;line-height:1.5}

.our-story-chaptergrid{background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);padding:var(--space-section-y) var(--space-section-x)}
.our-story-chaptergrid .chapters{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap)}
.our-story-chaptergrid .chapter{background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-card);min-height:calc(var(--space-block)*3.4);display:grid;align-content:space-between;gap:var(--space-card);animation:our-story-chaptergrid-drift calc(var(--anim-duration)*7) var(--anim-ease) infinite}
.our-story-chaptergrid .chapter:nth-child(2){animation-delay:calc(var(--anim-duration)*-2)}.our-story-chaptergrid span{color:var(--primary-bg);font-size:var(--font-size-h3)}.our-story-chaptergrid h3,.our-story-chaptergrid p{margin:0}.our-story-chaptergrid h3{font-size:var(--font-size-h3);line-height:1.1}
@keyframes our-story-chaptergrid-drift{0%,100%{transform:translateY(0)}50%{transform:translateY(calc(var(--motion-distance)*-.08))}}
@media(max-width:760px){.our-story-chaptergrid .chapters{grid-template-columns:1fr}.our-story-chaptergrid .chapter{animation:none}}

.recommendations{padding:calc(var(--space-y)*2.65) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.recommendations .grid{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:.6rem;}
.recommendations .main{grid-column:span 12;padding:1rem;border-radius:var(--radius-xl);border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.recommendations .main h2{margin:0;font-size:clamp(1.75rem,3.1vw,2.45rem);}
.recommendations .main p{margin:.38rem 0 0;}
.recommendations .item{grid-column:span 4;padding:.9rem;border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--muted-bg);color:var(--muted-fg);}
.recommendations .item:nth-child(odd){background:var(--card-bg);color:var(--card-fg);}
.recommendations h3{margin:0 0 .22rem;font-size:1rem;}
.recommendations .item p{margin:0 0 .55rem;}
.recommendations a{text-decoration:none;font-weight:700;}
@media (max-width:920px){.recommendations .item{grid-column:span 6;}}@media (max-width:620px){.recommendations .item{grid-column:1/-1;}}

.people-behind-columnvoices{background:var(--muted-bg);color:var(--muted-fg);padding:var(--space-section-y) var(--space-section-x)}
.people-behind-columnvoices .voices{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:minmax(0,.6fr) minmax(0,1.4fr);gap:var(--space-block)}
.people-behind-columnvoices h2,.people-behind-columnvoices p{margin:0}.people-behind-columnvoices h2{font-size:var(--font-size-h2);line-height:1.05;margin-bottom:var(--space-card)}
.people-behind-columnvoices .columns{columns:2;column-gap:var(--gap)}.people-behind-columnvoices .columns p{break-inside:avoid;margin:0 0 var(--gap);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-md);padding:var(--space-card)}
@media(max-width:760px){.people-behind-columnvoices .voices{grid-template-columns:1fr}.people-behind-columnvoices .columns{columns:1}}

.timeline{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}
.timeline .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}
.timeline h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;}
.timeline .sub{margin:.35rem 0 0;opacity:.9;}
.timeline article,.timeline li{padding:.85rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);list-style:none;color:var(--accent-fg);}
.timeline p{margin:0;}
.timeline a{text-decoration:none;color:inherit;font-weight:700;}
.timeline .acc{display:grid;gap:.5rem;}
.timeline details{padding:.82rem .9rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}
.timeline summary{cursor:pointer;font-weight:700;}
.timeline details p{margin:.35rem 0 0;}
.timeline article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);}
.timeline article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
@media (max-width:860px){.timeline .split,.timeline .media,.timeline .grid,.timeline .cards,.timeline .bento,.timeline .foot{grid-template-columns:1fr;}}

.about-brand{padding:clamp(50px,7vw,90px) clamp(16px,4vw,36px);background:var(--muted-bg);color:var(--muted-fg);}

    .about-brand .wrap{max-width:920px;margin:0 auto;}

    .about-brand .head{margin-bottom:15px;}

    .about-brand .head p{margin:0;}

    .about-brand .head h2{margin:7px 0;font-size:clamp(28px,4vw,42px);}

    .about-brand .head span{}

    .about-brand .stack{display:grid;gap:10px;}

    .about-brand .stack article{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--muted-bg);padding:12px;color:var(--muted-fg);}

    .about-brand .line{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;}

    .about-brand .line i{font-style:normal;}

    .about-brand .line h3{margin:0;}

    .about-brand .stack p{margin:7px 0 6px;}

    .about-brand .stack small{font-weight:600;}

.aim {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
  }
  .aim .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
  }
  .aim h2 {
    margin: 0;
    font-size: clamp(1.85rem, 3.6vw, 2.8rem);
    line-height: 1.1;
  }
  .aim .sub {
    margin: .35rem 0 0;
    opacity: .9;
  }
  .aim article,
  .aim li {
    padding: .85rem;
    border-radius: var(--radius-sm);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    list-style: none;
    color: var(--accent-fg);
  }
  .aim p {
    margin: 0;
  }
  .aim a {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
  }
  .aim .rail {
    display: flex;
    gap: .55rem;
    overflow: auto;
  }
  .aim .rail article {
    min-width: 240px;
  }
  .aim article {
    transition: transform var(--anim-duration) var(--anim-ease), box-shadow var(--anim-duration) var(--anim-ease);
  }
  .aim article:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
  }
  @media (max-width: 860px) {
    .aim .split,
    .aim .media,
    .aim .grid,
    .aim .cards,
    .aim .bento,
    .aim .foot {
      grid-template-columns: 1fr;
    }
  }

.contacts-harbor{padding:calc(var(--space-y)*3) var(--space-x);background:var(--neutral-800);color:var(--neutral-0);}
.contacts-harbor .harbor-wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:minmax(0,.75fr) minmax(280px,1.25fr);gap:var(--gap);align-items:start;}
.contacts-harbor .harbor-copy{padding-top:.35rem;border-top:3px solid var(--accent-bg);}
.contacts-harbor h2{margin:0;font-size:clamp(2rem,4vw,3.25rem);line-height:1.02;}
.contacts-harbor p{margin:.85rem 0 0;max-width:31rem;}
.contacts-harbor .harbor-board{display:grid;grid-template-columns:1.08fr .92fr;gap:.8rem;}
.contacts-harbor .address,.contacts-harbor .harbor-hours,.contacts-harbor .harbor-line{font-style:normal;border-radius:var(--radius-lg);background:var(--card-bg);color:var(--card-fg);padding:1rem;border:1px solid var(--card-border);}
.contacts-harbor .harbor-address{grid-row:span 2;display:flex;flex-direction:column;justify-content:space-between;min-height:11rem;}
.contacts-harbor span{display:block;font-size:.82rem;color:var(--neutral-600);}
.contacts-harbor strong,.contacts-harbor a{display:block;margin-top:.42rem;font-size:1.05rem;line-height:1.25;text-decoration:none;}
.contacts-harbor .harbor-links{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:.6rem;}
.contacts-harbor .harbor-links a{padding:.65rem .8rem;border-radius:999px;background:var(--accent-bg);color:var(--accent-fg);text-decoration:none;display:inline-flex;gap:.45rem;align-items:center;}
.contacts-harbor .harbor-links b{font-weight:700;}
@media (max-width:780px){.contacts-harbor .harbor-wrap,.contacts-harbor .harbor-board{grid-template-columns:1fr;}.contacts-harbor .harbor-address{min-height:auto;}.contacts-harbor .harbor-links{display:grid;}}

.form{padding:calc(var(--space-y)*2.9) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.form .shell{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);}
.form .form-intro{padding:1rem;border-radius:var(--radius-lg);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}
.form h2{margin:0;font-size:clamp(1.85rem,3.5vw,2.65rem);}
.form .form-intro p{margin:.45rem 0 0;}
.form .panel{padding:1.1rem;border:1px solid var(--card-border);border-radius:var(--radius-xl);background:var(--card-bg);box-shadow:var(--shadow-md);display:grid;gap:.75rem;color:var(--card-fg);}
.form .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem;}
.form label{display:grid;gap:.28rem;}
.form span{font-size:.84rem;font-weight:700;}
.form input,.form textarea{width:100%;padding:.78rem .82rem;border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);font:inherit;outline:none;transition:border-color var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);}
.form input:focus,.form textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 20%,transparent);}
.form textarea{min-height:128px;resize:vertical;}
.form button{justify-self:start;padding:.82rem 1.1rem;border:0;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);font-weight:700;cursor:pointer;}
.form button:hover{background:var(--primary-hover);color:var(--primary-fg);}
@media (max-width:920px){.form .shell,.form .grid{grid-template-columns:1fr;}}

.privacy{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .privacy .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .privacy h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .privacy .sub{margin:.35rem 0 0;opacity:.9;} .privacy article,.privacy li{padding:.85rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);list-style:none;color:var(--accent-fg);} .privacy p{margin:0;} .privacy a{text-decoration:none;color:inherit;font-weight:700;} .privacy .table{display:grid;gap:.5rem;} .privacy .foot{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.65rem;} .privacy .foot p{padding:.65rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);} @media (max-width:860px){.privacy .split,.privacy .media,.privacy .grid,.privacy .cards,.privacy .bento,.privacy .foot{grid-template-columns:1fr;}}

.rules{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:linear-gradient(180deg,var(--accent-bg),var(--card-bg));color:var(--accent-fg);}

    .rules .wrap{max-width:900px;margin:0 auto;}

    .rules .section-head{margin-bottom:14px;}

    .rules h2{margin:0;font-size:clamp(28px,4vw,40px);}

    .rules .section-head p{margin:10px 0 0;}

    .rules details{border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);padding:10px 12px;margin-bottom:10px;color:var(--card-fg);}

    .rules summary{cursor:pointer;font-weight:700;}

    .rules h4{margin:10px 0 6px;}

    .rules p,.rules li{}

.success{padding:calc(var(--space-y)*2.7) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.success .wrap{max-width:820px;margin:0 auto;display:grid;gap:.58rem;}
.success .note{padding:1rem;border-radius:var(--radius-xl);background:linear-gradient(180deg,var(--card-bg),var(--muted-bg));border:1px solid var(--card-border);text-align:center;color:var(--card-fg);}
.success h2{margin:0;font-size:clamp(1.72rem,3vw,2.4rem);}
.success .note p{margin:.38rem 0 0;}
.success .inline{margin:0;padding:.72rem .8rem;border-radius:var(--radius-md);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}

.unavailable{padding:clamp(56px,10vw,112px) 20px;background:var(--muted-bg);color:var(--muted-fg);}

    .unavailable .box{max-width:760px;margin:0 auto;text-align:center;border-top:6px solid var(--accent-bg);border-radius:var(--radius-lg);background:var(--card-bg);border-left:1px solid var(--card-border);border-right:1px solid var(--card-border);border-bottom:1px solid var(--card-border);padding:clamp(28px,4vw,46px);color:var(--card-fg);}

    .unavailable h1{margin:0;font-size:clamp(32px,6vw,56px);}

    .unavailable p{margin:10px 0 0;}

    .unavailable a{display:inline-block;margin-top:16px;padding:9px 14px;border-radius:999px;text-decoration:none;border:1px solid var(--card-border);}