:root {
  --font-family: "Source Serif 4", sans-serif;
  --font-size-base: 15.4px;
  --line-height-base: 1.87;

  --max-w: 1020px;
  --space-x: 1.37rem;
  --space-y: 1.5rem;
  --gap: 0.98rem;
  --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.74rem;
  --radius-lg: 0.61rem;
  --radius-md: 0.43rem;
  --radius-sm: 0.27rem;

  --shadow-sm: 0 0px 2px rgba(0,0,0,0.07);
  --shadow-md: 0 5px 12px rgba(0,0,0,0.09);
  --shadow-lg: 0 6px 28px rgba(0,0,0,0.11);

  --overlay: rgba(15, 15, 25, 0.65);
  --anim-duration: 350ms;
  --anim-ease: cubic-bezier(0.2,0.8,0.2,1);
  --random-number: 1;

  --brand: #3A2E4A;
  --brand-contrast: #F5F0EB;
  --accent: #B85C3A;
  --accent-contrast: #F5F0EB;

  --neutral-0: #F5F0EB;
  --neutral-100: #E6DFD6;
  --neutral-300: #B8AFA3;
  --neutral-600: #6B6258;
  --neutral-800: #3A342E;
  --neutral-900: #1E1A16;

  --page-bg: #F5F0EB;
  --page-fg: #2C2824;
  --muted-bg: #E6DFD6;
  --muted-fg: #2C2824;
  --card-bg: #FFFFFF;
  --card-fg: #2C2824;
  --card-border: #D6CEC4;
  --inverse-bg: #2C223A;
  --inverse-fg: #F5F0EB;
  --primary-bg: #3A2E4A;
  --primary-fg: #F5F0EB;
  --primary-hover: #2C223A;
  --accent-bg: #B85C3A;
  --accent-fg: #F5F0EB;
  --accent-hover: #9E4A2E;
  --gradient-hero-bg: linear-gradient(135deg, #2C223A 0%, #4A3E5C 50%, #3A2E4A 100%);
  --gradient-hero-fg: #F5F0EB;
  --gradient-accent-bg: linear-gradient(135deg, #B85C3A 0%, #9E4A2E 100%);
  --gradient-accent-fg: #F5F0EB;

  --ring: #B85C3A;

  --link: #3A2E4A;
  --link-hover: #B85C3A;

  --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;}

/* ---------- HEADER STYLES (full‑width background, border) ---------- */
.site-header {
  background-color: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--card-border, #e0e0e0);
  width: 100%;
  /* ensure no fixed/sticky positioning */
  position: relative;
  top: auto;
  left: auto;
  z-index: 100;
  box-sizing: border-box;
}

/* inner wrapper: max‑width + horizontal padding */
.header-wrapper {
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding: 0 var(--space-x, 1.5rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 64px;  /* medium density */
  box-sizing: border-box;
}

/* ----- LOGO (left) ----- */
.logo-link {
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 700;
  color: var(--page-fg, #1a1a1a);
  text-decoration: none;
  letter-spacing: -0.02em;
  line-height: 1.2;
  white-space: nowrap;
  flex-shrink: 0;
}
.logo-link:hover {
  color: var(--link-hover, #0056b3);
}

/* ----- DESKTOP NAV (center) ----- */
.primary-nav {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  justify-content: center;
  margin: 0 1rem;
}
.nav-list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--gap, 2rem);
}
.nav-list a {
  font-size: var(--font-size-md, 1rem);
  color: var(--page-fg, #1a1a1a);
  text-decoration: none;
  padding: 0.25rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  font-weight: 500;
}
.nav-list a:hover {
  border-bottom-color: var(--primary-bg, #1a73e8);
  color: var(--page-fg, #1a1a1a);
}

/* ----- CTA (right) ----- */
.cta-wrapper {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.cta-button {
  display: inline-block;
  background-color: var(--primary-bg, #1a73e8);
  color: var(--primary-fg, #ffffff);
  font-size: var(--font-size-sm, 0.9rem);
  font-weight: 600;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-md, 6px);
  text-decoration: none;
  transition: background-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  white-space: nowrap;
  line-height: 1.4;
}
.cta-button:hover {
  background-color: var(--primary-hover, #1557b0);
  color: var(--primary-fg, #ffffff);
}

/* ----- BURGER (hidden on desktop) ----- */
.burger-button {
  display: none;        /* hidden by default */
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  margin: 0;
  width: 40px;
  height: 40px;
  box-sizing: border-box;
  flex-shrink: 0;
}
.burger-bar {
  display: block;
  width: 22px;
  height: 2.5px;
  background-color: var(--page-fg, #1a1a1a);
  border-radius: 2px;
  transition: transform var(--anim-duration, 0.25s) var(--anim-ease, ease),
              opacity var(--anim-duration, 0.25s) var(--anim-ease, ease);
}

/* ---------- MOBILE STYLES (max-width: 767px) ---------- */
@media (max-width: 767px) {
  .header-wrapper {
    flex-wrap: wrap;
    justify-content: space-between;
    min-height: 56px;
    padding: 0 var(--space-x, 1rem);
  }

  /* show burger */
  .burger-button {
    display: flex;
    order: 3;
  }

  /* hide desktop nav by default, make it full‑width dropdown */
  .primary-nav {
    display: none;
    width: 100%;
    flex: 0 0 100%;
    order: 4;
    margin: 0.5rem 0 0.75rem 0;
    justify-content: center;
    background-color: var(--page-bg, #ffffff);
    border-top: 1px solid var(--card-border, #e0e0e0);
    padding: 0.75rem 0 0.25rem 0;
  }

  .primary-nav.is-open {
    display: flex;
  }

  .nav-list {
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
  }

  .nav-list a {
    font-size: var(--font-size-md, 1rem);
    padding: 0.4rem 0;
    border-bottom: none;
    font-weight: 500;
  }

  .nav-list a:hover {
    border-bottom: none;
    opacity: 0.8;
  }

  /* CTA stays on right, but we can adjust */
  .cta-wrapper {
    order: 2;
    margin-left: auto;
    margin-right: 0.5rem;
  }

  .cta-button {
    font-size: var(--font-size-sm, 0.85rem);
    padding: 0.4rem 1rem;
  }

  .logo-link {
    font-size: var(--font-size-h3, 1.35rem);
    order: 1;
  }
}

/* optional tiny extra: active burger animation (not required but nice) */
.burger-button.active .burger-bar:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
.burger-button.active .burger-bar:nth-child(2) {
  opacity: 0;
}
.burger-button.active .burger-bar:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

footer {
    background-color: #1a1a2e;
    color: #e0e0e0;
    padding: 2.5rem 1.5rem 1rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 0.95rem;
    line-height: 1.6;
  }
  .footer-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1200px;
    margin: 0 auto;
    gap: 2rem;
  }
  .footer-column {
    flex: 1 1 250px;
    min-width: 200px;
  }
  .brand {
    font-size: 1.5rem;
    font-weight: 700;
    color: #f5c518;
    margin-bottom: 0.5rem;
    letter-spacing: 1px;
  }
  .offer {
    color: #b0b0b0;
    margin: 0.5rem 0 0;
    font-size: 0.9rem;
  }
  .footer-nav {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  .footer-nav a {
    color: #c0c0c0;
    text-decoration: none;
    transition: color 0.2s;
    font-size: 0.95rem;
  }
  .footer-nav a:hover {
    color: #f5c518;
  }
  .contact-block {
    margin-bottom: 1rem;
  }
  .contact-item {
    margin: 0.3rem 0;
    color: #d0d0d0;
  }
  .contact-label {
    font-weight: 600;
    color: #f0f0f0;
  }
  .contact-item a {
    color: #a0c4ff;
    text-decoration: none;
  }
  .contact-item a:hover {
    text-decoration: underline;
    color: #f5c518;
  }
  .disclaimer {
    font-size: 0.8rem;
    color: #999;
    border-top: 1px solid #333;
    padding-top: 0.8rem;
    margin-top: 0.8rem;
    line-height: 1.4;
  }
  .footer-bottom {
    text-align: center;
    border-top: 1px solid #2a2a3e;
    margin-top: 2rem;
    padding-top: 1rem;
    font-size: 0.85rem;
    color: #888;
  }
  @media (max-width: 768px) {
    .footer-container {
      flex-direction: column;
      align-items: center;
      text-align: center;
    }
    .footer-column {
      flex: 1 1 100%;
      max-width: 400px;
    }
    .footer-nav {
      align-items: center;
    }
    .contact-block {
      text-align: center;
    }
  }

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

    .cookies .shell{max-width:720px;margin:0 auto;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-y) var(--space-x);color:var(--card-fg);}

    .cookies .meta{display:flex;align-items:center;gap:8px;}

    .cookies .shell p{margin:8px 0 0;}

    .cookies .actions{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap;}

    .cookies .actions button{border:1px solid var(--card-border);background:var(--muted-bg);color:var(--muted-fg);border-radius:var(--radius-sm);padding:8px 12px;cursor:pointer;}

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

.lead {
    padding: clamp(3.8rem, 8vw, 6.9rem) var(--space-x);
    background: radial-gradient(circle at 50% 0, color-mix(in srgb, currentColor 16%, transparent), transparent 30%), 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;
    align-items: center;
}

.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: .6rem 0 0;
    font-size: clamp(2.5rem, 5vw, 4.8rem);
    line-height: 1;
}

.lead .copy strong {
    display: block;
    margin-top: .7rem;
}

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

.lead .cards {
    display: grid;
    gap: .75rem;
}

.lead .cards div {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: color-mix(in srgb, currentColor 12%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

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

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

    .overview .wrap{max-width:var(--max-w);margin:0 auto;}

    .overview .head{margin-bottom:16px;}

    .overview .head p{margin:0;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:0.05em;color:var(--accent-bg);}

    .overview .head h2{margin:7px 0;font-size:clamp(28px,4vw,42px);color:var(--muted-fg);}

    .overview .head span{display:block;max-width:680px;line-height:var(--line-height-base);color:var(--muted-fg);}

    .overview .grid{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}

    .overview .grid article{border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--card-bg);padding:var(--space-y) var(--space-x);box-shadow:var(--shadow-sm);color:var(--card-fg);}

    .overview .grid i{display:inline-block;font-style:normal;margin-bottom:6px;}

    .overview .grid h3{margin:0;font-size:var(--font-size-md);color:var(--card-fg);}

    .overview .grid p{margin:7px 0;font-size:var(--font-size-sm);line-height:var(--line-height-base);color:var(--card-fg);}

    .overview .grid small{font-weight:600;color:var(--accent-bg);}

.merits{padding:clamp(3.5rem,8vw,6rem) var(--space-x);background:linear-gradient(135deg,var(--primary-bg),var(--accent-bg));color:var(--primary-fg);}

    .merits .wrap{max-width:62rem;margin:0 auto;}

    .merits .head{text-align:center;margin-bottom:1.1rem;}

    .merits .head p{margin:0;color:color-mix(in srgb, currentColor 76%, transparent);}

    .merits .head h2{margin:.5rem 0 0;font-size:clamp(2rem,4vw,3rem);}

    .merits .cloud{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center;}

    .merits .cloud article{width:min(16rem,100%);padding:1rem;border-radius:1.5rem;background:color-mix(in srgb, currentColor 14%, transparent);border:1px solid color-mix(in srgb, currentColor 18%, transparent);}

    .merits .cloud p{margin:.45rem 0 0;}

    .merits .cloud span{display:block;margin-top:.55rem;color:color-mix(in srgb, currentColor 76%, transparent);}

.faq-minimaltoggle {
  background: var(--muted-bg);
  color: var(--muted-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-minimaltoggle .toggle {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr);
  gap: var(--space-block);
}
.faq-minimaltoggle .top {
  display: grid;
  gap: var(--space-card);
  align-content: start;
}
.faq-minimaltoggle h2,
.faq-minimaltoggle p {
  margin: 0;
}
.faq-minimaltoggle h2 {
  font-size: var(--font-size-h2);
  line-height: 1.05;
}
.faq-minimaltoggle .items {
  display: grid;
  gap: calc(var(--space-card) * .6);
}
.faq-minimaltoggle .item {
  background: var(--page-bg);
  color: var(--page-fg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-md);
}
.faq-minimaltoggle button {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  padding: var(--space-card);
  text-align: left;
  font: inherit;
  font-size: var(--font-size-lg);
  cursor: pointer;
}
.faq-minimaltoggle .item p {
  max-height: 0;
  overflow: hidden;
  padding: 0 var(--space-card);
  transition: max-height calc(var(--anim-duration) * 2) var(--anim-ease), padding var(--anim-duration) var(--anim-ease);
}
.faq-minimaltoggle .item.is-open p {
  max-height: calc(var(--space-block) * 4);
  padding-bottom: var(--space-card);
}
@media (max-width: 760px) {
  .faq-minimaltoggle .toggle {
    grid-template-columns: 1fr;
  }
}

.mission-slatepath{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.mission-slatepath .slatepath-panel{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.25rem;box-shadow:var(--shadow-sm)}
.mission-slatepath h2{margin:0 0 1rem;color:var(--card-fg);font-size:clamp(2rem,4vw,3.25rem);line-height:1.04}
.mission-slatepath p{margin:.8rem 0 0;color:var(--card-fg);opacity:.84;line-height:1.55}

.people-behind-teamgrid{background:var(--inverse-bg);color:var(--inverse-fg);padding:var(--space-section-y) var(--space-section-x)}
.people-behind-teamgrid .team{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--space-block)}.people-behind-teamgrid .intro{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:var(--gap);align-items:end}
.people-behind-teamgrid h2,.people-behind-teamgrid p{margin:0}.people-behind-teamgrid h2{font-size:var(--font-size-h1);line-height:.96}.people-behind-teamgrid .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap)}
.people-behind-teamgrid .person{background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-card);display:grid;gap:var(--space-card);animation:people-behind-teamgrid-in calc(var(--anim-duration)*2) var(--anim-ease) both}
.people-behind-teamgrid .person:nth-child(2){animation-delay:calc(var(--anim-duration)*.25)}.people-behind-teamgrid strong{font-size:var(--font-size-h3)}.people-behind-teamgrid span{color:var(--muted-fg);font-size:var(--font-size-sm)}
@keyframes people-behind-teamgrid-in{from{opacity:0;transform:translateY(calc(var(--motion-distance)*.2))}to{opacity:1;transform:translateY(0)}}
@media(max-width:820px){.people-behind-teamgrid .intro,.people-behind-teamgrid .grid{grid-template-columns:1fr}}

.tpl-variant-identity-light-v6{background-image:linear-gradient(135deg,color-mix(in srgb,currentColor 6%,transparent),transparent 48%);}
.tpl-variant-identity-light-v6 .grid,.tpl-variant-identity-light-v6 .cards,.tpl-variant-identity-light-v6 .list,.tpl-variant-identity-light-v6 .stack{gap:calc(var(--gap,1rem) * 1.08);}
.tpl-variant-identity-light-v6 article:nth-child(even),.tpl-variant-identity-light-v6 .card:nth-child(even),.tpl-variant-identity-light-v6 .item:nth-child(even){transform:translateY(0.35rem);}
.about-brand{padding:clamp(50px,7vw,90px) clamp(16px,4vw,36px);background:var(--muted-bg);color:var(--muted-fg);}

    .about-brand .wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);align-items:start;}

    .about-brand .img img{width:100%;height:auto;border-radius:var(--radius-lg);border:1px solid var(--card-border);}

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

    .about-brand .body h3{margin:0 0 10px;font-size:1rem;}

    .about-brand .body p{margin:0 0 10px;}

    .about-brand .body ul{margin:0;padding-left:18px;display:grid;gap:6px;}

    @media (max-width: 820px){.about-brand .wrap{grid-template-columns:1fr;}
    }

.form-plainharbor{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--card-bg);color:var(--card-fg);}
.form-plainharbor .plainharbor-box{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);border-top:1px solid var(--card-border);padding-top:1rem;}.form-plainharbor h2{margin:0;font-size:clamp(1.9rem,3.4vw,2.8rem);line-height:1.07;}.form-plainharbor p{margin:.8rem 0 0;color:var(--neutral-600);}
.form-plainharbor .plainharbor-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;}.form-plainharbor label{display:grid;gap:.28rem;}.form-plainharbor span{font-size:.82rem;color:var(--neutral-600);}.form-plainharbor input,.form-plainharbor textarea{width:100%;border:1px solid var(--card-border);border-radius:0;padding:.75rem;font:inherit;color:var(--page-fg);background:var(--page-bg);}
.form-plainharbor .plainharbor-message{grid-column:1/-1;}.form-plainharbor textarea{min-height:9rem;resize:vertical;}.form-plainharbor button{grid-column:1/-1;justify-self:stretch;border:0;border-radius:0;background:var(--primary-bg);color:var(--primary-fg);font:inherit;font-weight:700;padding:.9rem;}
@media (max-width:820px){.form-plainharbor .plainharbor-box,.form-plainharbor .plainharbor-fields{grid-template-columns:1fr;}}

.address{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .address .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .address h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .address .sub{margin:.35rem 0 0;opacity:.9;} .address article,.address 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);} .address p{margin:0;} .address a{text-decoration:none;color:inherit;font-weight:700;} .address .pulse{margin-top:.8rem;padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);animation:contacts-u7Pulse 2.8s ease-in-out infinite;color:var(--accent-fg);} @keyframes contacts-u7Pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.01);}} .address article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .address article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.address .split,.address .media,.address .grid,.address .cards,.address .bento,.address .foot{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}

.policy-items{padding:calc(var(--space-y)*2.7) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.policy-items .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:.72rem;}
.policy-items .banner{padding:1rem;border-radius:var(--radius-xl);border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.policy-items h2{margin:0;font-size:clamp(1.74rem,3vw,2.42rem);}
.policy-items .banner p{margin:.38rem 0 0;}
.policy-items .matrix{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;}
.policy-items .matrix .article{padding:.85rem;border:1px solid var(--card-border);border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);}
.policy-items .matrix h3{margin:0 0 .2rem;font-size:1rem;}
.policy-items .matrix p{margin:0;}
.policy-items .end{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;}
.policy-items .end p{margin:0;padding:.75rem;border-radius:var(--radius-md);background:var(--muted-bg);color:var(--muted-fg);}
@media (max-width:760px){.policy-items .matrix,.policy-items .end{grid-template-columns:1fr;}}

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

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

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

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

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

    .terms-items 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);}

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

    .terms-items h4{margin:10px 0 6px;}

    .terms-items p,.terms-items li{}

.done{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .done .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .done h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .done .sub{margin:.35rem 0 0;opacity:.9;} .done article,.done 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);} .done p{margin:0;} .done a{text-decoration:none;color:inherit;font-weight:700;} .done .ranks{counter-reset:r;display:grid;gap:.5rem;} .done .ranks article{position:relative;padding-left:2.2rem;} .done .ranks article::before{counter-increment:r;content:counter(r);position:absolute;left:.7rem;top:.8rem;width:1.2rem;height:1.2rem;border-radius:50%;display:grid;place-items:center;background:var(--primary-bg);color:var(--primary-fg);font-size:.72rem;} .done article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .done article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.done .split,.done .media,.done .grid,.done .cards,.done .bento,.done .foot{grid-template-columns:1fr;}}

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

    .error-page .box{max-width:760px;margin:0 auto;text-align:center;border:1px solid var(--card-border);border-radius:var(--radius-xl);background:var(--card-bg);padding:clamp(28px,4vw,46px);box-shadow:var(--shadow-md);color:var(--card-fg);}

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

    .error-page p{margin:10px 0 0;}

    .error-page a{display:inline-block;margin-top:18px;padding:10px 16px;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-fg);text-decoration:none;}