:root {
  --font-family: "Fira Sans", sans-serif;
  --font-size-base: 17.9px;
  --line-height-base: 1.78;

  --max-w: 1580px;
  --space-x: 2.58rem;
  --space-y: 1.5rem;
  --gap: 2.32rem;
  --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: 1.23rem;
  --radius-lg: 0.9rem;
  --radius-md: 0.59rem;
  --radius-sm: 0.29rem;

  --shadow-sm: 0 1px 7px rgba(0,0,0,0.14);
  --shadow-md: 0 10px 26px rgba(0,0,0,0.18);
  --shadow-lg: 0 20px 34px rgba(0,0,0,0.22);

  --overlay: rgba(0,0,0,0.5);
  --anim-duration: 380ms;
  --anim-ease: cubic-bezier(0.4,0,0.2,1);
  --random-number: 2;

  --brand: #1a1a2e;
  --brand-contrast: #ffffff;
  --accent: #ff6b35;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f5f5f5;
  --neutral-300: #d1d5db;
  --neutral-600: #6b7280;
  --neutral-800: #1f2937;
  --neutral-900: #111827;

  --c-page-bg: #fafafa;
  --c-page-fg: #1a1a2e;
  --c-muted-bg: #f0f4f8;
  --c-muted-fg: #1a1a2e;
  --c-card-bg: #ffffff;
  --c-card-fg: #1a1a2e;
  --c-card-border: #e5e7eb;
  --c-inverse-bg: #1a1a2e;
  --c-inverse-fg: #ffffff;
  --c-primary-bg: #1a1a2e;
  --c-primary-fg: #ffffff;
  --c-primary-hover: #2d2d4a;
  --c-accent-bg: #ff6b35;
  --c-accent-fg: #ffffff;
  --c-accent-hover: #e55a2b;
  --g-hero-bg: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
  --g-hero-fg: #ffffff;
  --g-accent-bg: linear-gradient(135deg, #ff6b35 0%, #e55a2b 100%);
  --g-accent-fg: #ffffff;

  --section-light-bg: var(--c-page-bg);
  --section-light-fg: var(--c-page-fg);
  --section-muted-bg: var(--c-muted-bg);
  --section-muted-fg: var(--c-muted-fg);
  --section-card-bg: var(--c-card-bg);
  --section-card-fg: var(--c-card-fg);
  --section-colored-bg: var(--c-inverse-bg);
  --section-colored-fg: var(--c-inverse-fg);
  --section-gradient-bg: var(--g-hero-bg);
  --section-gradient-fg: var(--g-hero-fg);

  --bg-page: var(--c-page-bg);
  --fg-on-page: var(--c-page-fg);

  --bg-alt: var(--c-muted-bg);
  --fg-on-alt: var(--c-muted-fg);

  --surface-1: var(--c-inverse-bg);
  --surface-2: var(--c-muted-bg);
  --fg-on-surface: var(--c-inverse-fg);
  --border-on-surface: var(--c-card-border);

  --surface-light: var(--c-card-bg);
  --fg-on-surface-light: var(--c-card-fg);
  --border-on-surface-light: var(--c-card-border);

  --bg-primary: var(--c-primary-bg);
  --fg-on-primary: var(--c-primary-fg);
  --bg-primary-hover: var(--c-primary-hover);
  --ring: #ff6b35;

  --bg-accent: var(--c-accent-bg);
  --fg-on-accent: var(--c-accent-fg);
  --bg-accent-hover: var(--c-accent-hover);

  --link: #1a1a2e;
  --link-hover: #ff6b35;

  --gradient-hero: var(--g-hero-bg);
  --gradient-hero-fg: var(--g-hero-fg);
  --gradient-accent: var(--g-accent-bg);
  --gradient-accent-fg: var(--g-accent-fg);

  --btn-ghost-bg: transparent;
  --chip-bg: color-mix(in srgb, var(--c-primary-bg) 86%, var(--c-card-bg) 14%);
  --chip-fg: var(--c-primary-fg);
  --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(--c-primary-bg)!important;color:var(--c-primary-fg)!important;border-color:var(--c-primary-bg)!important;}
.btn-primary:hover,.btn.btn-primary:hover{background:var(--c-primary-hover)!important;color:var(--c-primary-fg)!important;border-color:var(--c-primary-hover)!important;}
.btn-outline-primary{color:var(--c-primary-bg)!important;border-color:var(--c-primary-bg)!important;}
.btn-outline-primary:hover{background:var(--c-primary-bg)!important;color:var(--c-primary-fg)!important;}
.bg-primary{background:var(--c-primary-bg)!important;color:var(--c-primary-fg)!important;}
.text-primary{color:var(--c-primary-bg)!important;}
.border-primary{border-color:var(--c-primary-bg)!important;}
.bg-light{background:var(--section-light-bg)!important;color:var(--section-light-fg)!important;}
.bg-dark{background:var(--section-colored-bg)!important;color:var(--section-colored-fg)!important;}

.site-header {
  background: var(--section-light-bg, #ffffff);
  border-bottom: 1px solid var(--c-card-border, #e0e0e0);
  width: 100%;
}

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

.logo {
  font-size: var(--font-size-h3, 1.25rem);
  font-weight: 700;
  color: var(--section-light-fg, #1a1a2e);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}

.main-nav {
  flex: 1;
  display: flex;
  justify-content: center;
}

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

.nav-list a {
  text-decoration: none;
  color: var(--section-light-fg, #1a1a2e);
  font-size: var(--font-size-md, 1rem);
  padding: 0.25rem 0;
  transition: color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  position: relative;
}

.nav-list a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--c-accent-bg, #e94560);
  transition: width var(--anim-duration, 0.2s) var(--anim-ease, ease);
}

.nav-list a:hover {
  color: var(--c-accent-bg, #e94560);
}

.nav-list a:hover::after {
  width: 100%;
}

.cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.25rem;
  background: var(--c-accent-bg, #e94560);
  color: var(--c-accent-fg, #ffffff);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 600;
  border-radius: var(--radius-md, 6px);
  text-decoration: none;
  white-space: nowrap;
  transition: background var(--anim-duration, 0.2s) var(--anim-ease, ease);
  flex-shrink: 0;
}

.cta-button:hover {
  background: var(--c-accent-hover, #d63851);
}

.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  width: 36px;
  height: 36px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}

.burger-line {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--section-light-fg, #1a1a2e);
  border-radius: 2px;
  transition: transform var(--anim-duration, 0.2s) var(--anim-ease, ease), opacity var(--anim-duration, 0.2s) var(--anim-ease, ease);
}

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

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

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

@media (max-width: 767px) {
  .header-wrapper {
    padding: var(--space-y, 0.75rem) var(--space-x, 1rem);
  }

  .main-nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--section-light-bg, #ffffff);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--anim-duration, 0.3s) var(--anim-ease, ease), visibility var(--anim-duration, 0.3s) var(--anim-ease, ease);
    z-index: 100;
  }

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

  .nav-list {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }

  .nav-list a {
    font-size: var(--font-size-h3, 1.25rem);
    padding: 0.5rem 0;
  }

  .cta-button {
    display: none;
  }

  .burger {
    display: flex;
    z-index: 101;
  }
}

@media (min-width: 768px) {
  .burger {
    display: none;
  }
}

.footer-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 2rem 1.5rem;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 1.2rem;
      background: #1a1a2e;
      color: #e0e0e0;
      font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
      font-size: 0.95rem;
      line-height: 1.5;
    }
    .logo {
      font-size: 1.5rem;
      font-weight: 700;
      color: #f5a623;
      margin: 0;
      letter-spacing: 0.5px;
    }
    .footer-nav ul {
      list-style: none;
      display: flex;
      gap: 1.8rem;
      padding: 0;
      margin: 0;
      flex-wrap: wrap;
      justify-content: center;
    }
    .footer-nav a {
      color: #b0b0c0;
      text-decoration: none;
      transition: color 0.2s;
      font-weight: 500;
    }
    .footer-nav a:hover {
      color: #f5a623;
    }
    .footer-legal {
      display: flex;
      gap: 1.5rem;
      flex-wrap: wrap;
      justify-content: center;
    }
    .footer-legal a {
      color: #b0b0c0;
      text-decoration: none;
      font-size: 0.9rem;
      transition: color 0.2s;
    }
    .footer-legal a:hover {
      color: #f5a623;
    }
    .footer-contact {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem 2rem;
      justify-content: center;
      font-style: normal;
      color: #c0c0d0;
    }
    .footer-contact a {
      color: #c0c0d0;
      text-decoration: none;
      transition: color 0.2s;
    }
    .footer-contact a:hover {
      color: #f5a623;
    }
    .footer-disclaimer {
      max-width: 800px;
      text-align: center;
      font-size: 0.85rem;
      color: #9090a0;
      margin: 0.5rem 0 0;
      line-height: 1.4;
    }
    .footer-copy {
      margin: 0;
      font-size: 0.85rem;
      color: #707080;
    }
    @media (max-width: 600px) {
      .footer-container {
        padding: 1.5rem 1rem;
        gap: 1rem;
      }
      .footer-nav ul {
        gap: 1rem;
      }
      .footer-contact {
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
      }
    }

.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(--c-card-bg);border:1px solid var(--c-card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-y) var(--space-x);color:var(--c-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(--c-card-border);background:var(--c-muted-bg);color:var(--c-muted-fg);border-radius:var(--radius-sm);padding:8px 12px;cursor:pointer;}

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

.lead{padding:clamp(3.6rem,8vw,6.8rem) var(--space-x);background:var(--c-card-bg);color:var(--c-card-fg);}

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

    .lead .main{padding:1.2rem;border-radius:var(--radius-xl);background:var(--c-muted-bg);color:var(--c-muted-fg);}

    .lead .main p{margin:0;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;}

    .lead .main h1{margin:.6rem 0 0;font-size:clamp(2.3rem,5vw,4rem);line-height:1.03;}

    .lead .main strong{display:block;margin-top:.8rem;}

    .lead .fact{margin-top:1rem;padding:.85rem .95rem;border-left:3px solid var(--c-primary-bg);background:var(--c-card-bg);color:var(--c-card-fg);}

    .lead .side{padding:1.2rem;border-radius:var(--radius-xl);border:1px solid var(--c-card-border);display:grid;align-content:center;}

    .lead .side span{font-weight:700;}

    .lead .side p{margin:.8rem 0 0;}

    .lead .actions{margin-top: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 var(--c-card-border);color:var(--c-card-fg);background:var(--c-card-bg);}

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

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

.proofs{background:var(--section-gradient-bg);color:var(--section-gradient-fg);padding:clamp(40px,6vw,80px) clamp(16px,3vw,40px);position:relative;overflow:hidden;}

    .proofs .c{max-width:var(--max-w);margin:0 auto;position:relative;z-index:1;}

    .proofs .h{text-align:center;margin-bottom:clamp(32px,5vw,64px);}

    .proofs h2{font-size:clamp(32px,5vw,48px);margin:0 0 1rem;}

    .proofs .subtitle{font-size:clamp(16px,2vw,20px);margin:0;opacity:0.9;}

    .proofs .list{display:flex;flex-direction:column;gap:clamp(16px,2vw,24px);}

    .proofs .item{display:flex;gap:clamp(16px,2vw,24px);background:var(--c-card-bg);padding:clamp(20px,3vw,32px);border-radius:var(--radius-lg);border:1px solid var(--c-card-border);align-items:flex-start;position:relative;overflow:hidden;transition:all var(--anim-duration) var(--anim-ease);color:var(--c-card-fg);}

    .proofs .item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--c-accent-bg);opacity:.75;transform:scaleY(.35);transform-origin:top;transition:transform .45s var(--anim-ease),opacity .45s var(--anim-ease);}

    .proofs .item:hover{transform:translateY(-3px);box-shadow:0 12px 28px color-mix(in srgb, currentColor 14%, transparent);}

    .proofs .item:hover::before{transform:scaleY(1);opacity:1;}

    .proofs .number{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--c-accent-bg);color:var(--c-accent-fg);border-radius:var(--radius-md);font-size:clamp(20px,2.5vw,28px);font-weight:700;position:relative;transition:transform var(--anim-duration) var(--anim-ease);}

    .proofs .item:hover .number{transform:translateY(-2px);}

    .proofs .number::after{content:'';position:absolute;inset:8px;border-radius:inherit;border:1px solid color-mix(in srgb, currentColor 38%, transparent);opacity:.45;}

    .proofs .content{flex:1;}

    .proofs .item h3{font-size:clamp(18px,2.2vw,24px);margin:0 0 0.75rem;transition:color var(--anim-duration) var(--anim-ease);}

    .proofs .item:hover h3{}

    .proofs .item p{margin:0;opacity:0.85;line-height:var(--line-height-base);}

.social-proof{padding:clamp(18px,3vw,44px);background:var(--c-muted-bg);color:var(--c-muted-fg);}

    .social-proof .c{max-width:var(--max-w);margin:0 auto;}

    .social-proof .h{margin-bottom:clamp(14px,2.2vw,22px);}

    .social-proof .title{margin:0;font-size:clamp(24px,4.2vw,40px);letter-spacing:-.02em;line-height:1.1;}

    .social-proof .sub{margin:10px 0 0;max-width:72ch;}

    .social-proof .wrap{border-radius:var(--radius-xl);background:var(--c-card-bg);border:1px solid var(--c-card-border);box-shadow:var(--shadow-lg);overflow:hidden;color:var(--c-card-fg);}

    .social-proof .quotebox{padding:18px;border-bottom:1px solid var(--c-card-border);position:relative;}

    .social-proof .quote{display:none;}

    .social-proof .quote.is-on{display:block;}

    .social-proof .q{font-size:clamp(16px,2.2vw,20px);line-height:1.7;letter-spacing:-.01em;}

    .social-proof .m{margin-top:12px;font-weight:800;}

    .social-proof .badges{overflow:hidden;background:var(--c-muted-bg);color:var(--c-muted-fg);}

    .social-proof .badgetrack{display:flex;gap:10px;padding:12px;width:max-content;animation:socialL2Badges 16s linear infinite;}

    @keyframes socialL2Badges{
        0% {transform:translateX(0);}
        100%{transform:translateX(-50%);}
    }

    .social-proof .badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--c-accent-bg);color:var(--c-accent-fg);border:1px solid color-mix(in srgb, currentColor 6%, transparent);font-weight:900;white-space:nowrap;}

    @media (prefers-reduced-motion: reduce){.social-proof .badgetrack{animation:none;}
    }

.action {
    padding: clamp(3.6rem, 8vw, 6.1rem) var(--space-x);
    background: radial-gradient(circle at 50% 0, color-mix(in srgb, currentColor 16%, transparent), transparent 28%), var(--section-gradient-bg);
    text-align: center;
    color: var(--section-gradient-fg);
}

.action .wrap {
    max-width: 54rem;
    margin: 0 auto;
}

.action .wrap p:first-child {
    margin: 0;
    color: color-mix(in srgb, currentColor 76%, transparent);
}

.action .wrap h2 {
    margin: .55rem 0 0;
    font-size: clamp(2.1rem, 4vw, 3.1rem);
}

.action .row {
    margin-top: 1.15rem;
    display: flex;
    gap: .75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.action .row a {
    display: inline-flex;
    padding: .8rem 1rem;
    border-radius: 999px;
    background: color-mix(in srgb, currentColor 12%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    text-decoration: none;
    animation: next_pulse_c3 2.4s ease-in-out infinite;
}

.action .row a:nth-child(2n) {
    animation-delay: .35s;
}

@keyframes next_pulse_c3 {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-3px);
    }
}

.action .copy {
    margin-top: 1rem;
}

.action .cta {
    display: inline-flex;
    margin-top: 1rem;
    min-height: 2.9rem;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
    border-radius: var(--radius-md);
    background: var(--c-accent-bg);
    color: var(--c-accent-fg);
    text-decoration: none;
}

.block-faq{padding:calc(var(--space-y) * 2.8) var(--space-x);background:var(--c-muted-bg);color:var(--c-muted-fg);}

    .block-faq .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:1rem;}

    .block-faq h2{margin:0;font-size:clamp(1.8rem,3.3vw,2.5rem);}

    .block-faq .bands{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap);}

    .block-faq article{padding:1rem;border-radius:var(--radius-lg);background:var(--c-card-bg);box-shadow:var(--shadow-sm);color:var(--c-card-fg);}

    .block-faq h3{margin:0 0 .45rem;font-size:1rem;}

    .block-faq p{margin:0;}

    @media (max-width: 980px){.block-faq .bands{grid-template-columns:repeat(2,minmax(0,1fr));}
    }

    @media (max-width: 680px){.block-faq .bands{grid-template-columns:1fr;}
    }

.block-project-list.colored {
    padding: 60px 20px;
    background: var(--section-colored-bg);
    color: var(--section-colored-fg);
}

.block-project-list .inner {
    max-width: var(--max-w);
    margin: 0 auto;
}

.block-project-list .header {
    text-align: center;
    margin-bottom: 24px;
}

.block-project-list .header h2 {
    margin: 0 0 4px;
    font-size: clamp(24px, 4vw, 30px);
}

.block-project-list .header p {
    margin: 0;
}

.block-project-list .grid {
    display: grid;
    grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}

.block-project-list .card {
    border-radius: var(--radius-xl);
    padding: 12px 14px;
    background: var(--section-colored-fg);
    border: 1px solid rgba(148, 163, 184, 0.7);
    color: var(--section-colored-bg);
}

.block-project-list .mod-active {
    border-color: var(--c-accent-bg);
}

.block-project-list .mod-paused {
    border-color: var(--c-accent-bg);
}

.block-project-list .mod-archived {
    border-color: var(--c-accent-bg);
}

.block-project-list .name {
    margin: 0 0 3px;
    font-size: 0.95rem;
}

.block-project-list .meta {
    margin: 0;
    font-size: 0.85rem;
}

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

.panel-project-item.colored{padding:56px 20px;background:var(--section-colored-bg);color:var(--section-colored-fg);}

.panel-project-item .inner{max-width:720px;margin:0 auto;}

.panel-project-item .card{border-radius:var(--radius-xl);padding:20px 22px;background:rgba(15,23,42,0.98);border:1px solid rgba(148,163,184,0.75);color:var(--neutral-0);}

.panel-project-item .header{display:flex;justify-content:space-between;gap:12px;align-items:baseline;}

.panel-project-item .header h1{margin:0;font-size:clamp(24px,4vw,32px);}

.panel-project-item .tag{padding:4px 10px;border-radius:999px;background:var(--section-gradient-bg);color:var(--section-gradient-fg);font-size:0.8rem;}

.panel-project-item .meta{margin:8px 0 8px;font-size:0.9rem;}

.panel-project-item .desc{margin:0;font-size:0.95rem;line-height:1.7;}

.inquiry{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--section-gradient-bg);color:var(--section-gradient-fg);} .inquiry .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .inquiry h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .inquiry .sub{margin:.35rem 0 0;opacity:.9;} .inquiry .panel,.inquiry .box{padding:1.1rem;border-radius:var(--radius-xl);background:var(--chip-bg);border:1px solid var(--btn-ghost-bg-hover);box-shadow:var(--shadow-md);color:var(--chip-fg);} .inquiry form{display:grid;gap:.75rem;} .inquiry .field{display:grid;gap:.28rem;} .inquiry .field span{font-size:.82rem;font-weight:700;} .inquiry input,.inquiry textarea{width:100%;padding:.8rem .85rem;border-radius:var(--radius-md);border:1px solid var(--c-card-border);background:var(--c-card-bg);color:var(--c-card-fg);font:inherit;outline:none;transition:border-color var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .inquiry input:focus,.inquiry textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 22%,transparent);} .inquiry textarea{min-height:120px;resize:vertical;} .inquiry button{padding:.82rem 1rem;border:0;border-radius:var(--radius-md);background:var(--c-primary-bg);color:var(--c-primary-fg);font-weight:700;cursor:pointer;transition:transform var(--anim-duration) var(--anim-ease),background var(--anim-duration) var(--anim-ease);} .inquiry button:hover{transform:translateY(-1px);background:var(--c-primary-hover);color:var(--c-primary-fg);} .inquiry .split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);} .inquiry .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;} .inquiry .line{padding:1rem;border-radius:var(--radius-lg);background:var(--chip-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--chip-fg);} .inquiry .bar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;padding:1rem;border-radius:var(--radius-lg);background:var(--chip-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--chip-fg);} .inquiry .stack{padding:1rem;border-radius:var(--radius-lg);background:var(--chip-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--chip-fg);} .inquiry .steps{display:flex;gap:.45rem;flex-wrap:wrap;} .inquiry .steps span{padding:.33rem .55rem;border-radius:var(--radius-sm);background:var(--chip-bg);border:1px solid var(--btn-ghost-bg-hover);font-size:.8rem;color:var(--chip-fg);} .inquiry .agree{display:flex;align-items:center;gap:.45rem;font-size:.86rem;} .inquiry .media{display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);} .inquiry .media img,.inquiry .frame img{width:100%;height:100%;min-height:320px;object-fit:cover;border-radius:var(--radius-xl);} .inquiry .frame{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--gap);} .inquiry .full{grid-column:1/-1;} .inquiry .panel{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .inquiry .panel:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);} @media (max-width:860px){.inquiry .split,.inquiry .media,.inquiry .frame{grid-template-columns:1fr;} .inquiry .grid,.inquiry .bar{grid-template-columns:1fr;}}

.contacts-foldmark{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--c-card-bg);color:var(--c-card-fg);}
.contacts-foldmark .foldmark-shell{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:var(--gap);align-items:start;}
.contacts-foldmark .foldmark-title{position:relative;padding-left:1rem;}
.contacts-foldmark .foldmark-title:before{content:"";position:absolute;left:0;top:.25rem;bottom:.25rem;width:4px;background:var(--c-accent-bg);border-radius:99px;color:var(--c-accent-fg);}
.contacts-foldmark h2{margin:0;font-size:clamp(1.9rem,3.9vw,3.1rem);line-height:1.04;}
.contacts-foldmark .foldmark-title p{margin:.9rem 0 0;color:var(--neutral-600);}
.contacts-foldmark .foldmark-directory{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;}
.contacts-foldmark .foldmark-block{background:var(--c-muted-bg);color:var(--c-muted-fg);border-radius:var(--radius-md);padding:.95rem;min-height:8.4rem;text-decoration:none;display:flex;flex-direction:column;justify-content:space-between;}
.contacts-foldmark .foldmark-wide{grid-column:span 2;}
.contacts-foldmark small{font-size:.8rem;color:var(--neutral-600);}
.contacts-foldmark .address,.contacts-foldmark p,.contacts-foldmark strong{margin:0;font-style:normal;line-height:1.32;font-weight:700;}
.contacts-foldmark .foldmark-links{grid-column:2;display:flex;gap:.5rem;flex-wrap:wrap;}
.contacts-foldmark .foldmark-links a{border:1px solid var(--c-card-border);color:var(--c-card-fg);text-decoration:none;border-radius:999px;padding:.5rem .68rem;background:var(--c-card-bg);}
.contacts-foldmark .foldmark-links span{color:var(--neutral-600);}
@media (max-width:820px){.contacts-foldmark .foldmark-shell,.contacts-foldmark .foldmark-links{grid-template-columns:1fr;}.contacts-foldmark .foldmark-links{grid-column:auto;}}
@media (max-width:560px){.contacts-foldmark .foldmark-directory{grid-template-columns:1fr;}.contacts-foldmark .foldmark-wide{grid-column:auto;}}

.area-map{padding:clamp(3.5rem,8vw,6rem) var(--space-x);background:var(--section-gradient-bg);color:var(--section-gradient-fg);}

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

    .area-map .band{margin-bottom:1rem;display:flex;justify-content:space-between;align-items:end;gap:1rem;flex-wrap:wrap;}

    .area-map .band h2{margin:0;font-size:clamp(2rem,4vw,3rem);}

    .area-map .band p{margin:0;color:color-mix(in srgb, currentColor 82%, transparent);}

    .area-map .shell{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;}

    .area-map .shell iframe{display:block;width:100%;min-height:24rem;border-radius:var(--radius-xl);border:1px solid color-mix(in srgb, currentColor 18%, transparent);}

    .area-map .cards{display:grid;gap:.75rem;}

    .area-map .cards article{padding:.95rem;border-radius:var(--radius-md);background:color-mix(in srgb, currentColor 12%, transparent);border:1px solid color-mix(in srgb, currentColor 18%, transparent);}

    .area-map .cards p{margin:.35rem 0 0;color:color-mix(in srgb, currentColor 84%, transparent);}

    @media (max-width: 840px){.area-map .shell{grid-template-columns:1fr;}
    }

.connect-softrail{padding:calc(var(--space-y)*2.4) var(--space-x);background:var(--c-page-bg);color:var(--c-page-fg)}
.connect-softrail .softrail-shell{max-width:var(--max-w);margin:0 auto}
.connect-softrail h2{margin:0;color:var(--c-page-fg);font-size:clamp(1.85rem,3.6vw,3rem);line-height:1.06}
.connect-softrail p{margin:.65rem 0 1rem;max-width:42rem;color:var(--c-muted-fg)}
.connect-softrail .softrail-row{display:flex;gap:.55rem;flex-wrap:wrap}
.connect-softrail a{background:var(--c-inverse-bg);color:var(--c-inverse-fg);border:1px solid var(--c-card-border);border-radius:999px;padding:.64rem .85rem;text-decoration:none;box-shadow:var(--shadow-sm)}
.connect-softrail a:hover{color:var(--link-hover);border-color:var(--ring)}

.policy-inktable{padding:calc(var(--space-y)*3) var(--space-x);background:var(--neutral-800);color:var(--neutral-0);}
.policy-inktable .inktable-wrap{max-width:var(--max-w);margin:0 auto;display:grid;gap:1rem;}.policy-inktable .header{display:grid;grid-template-columns:1fr minmax(240px,.45fr);gap:var(--gap);align-items:end;}.policy-inktable h2{margin:0;font-size:clamp(2rem,4vw,3.2rem);line-height:1.04;}.policy-inktable .header p{margin:0;}.policy-inktable .inktable-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;}.policy-inktable .article{background:var(--c-card-bg);color:var(--c-card-fg);border-radius:var(--radius-lg);padding:1rem;}.policy-inktable h3{margin:0 0 .35rem;font-size:1.05rem;}.policy-inktable .article p{margin:0;color:var(--neutral-600);}.policy-inktable .footer{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;}.policy-inktable .footer p{margin:0;background:var(--c-accent-bg);color:var(--c-accent-fg);border-radius:var(--radius-md);padding:.85rem;}
@media (max-width:800px){.policy-inktable .header,.policy-inktable .inktable-grid,.policy-inktable .footer{grid-template-columns:1fr;}}

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

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

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

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

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

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

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

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

    .terms p,.terms li{}

.done {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--section-gradient-bg);
    color: var(--section-gradient-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: 0.35rem 0 0;
    opacity: 0.9;
  }
  .done article,
  .done li {
    padding: 0.85rem;
    border-radius: var(--radius-sm);
    background: var(--chip-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    list-style: none;
    color: var(--chip-fg);
  }
  .done p {
    margin: 0;
  }
  .done a {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
  }
  .done .bento {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 0.55rem;
  }
  .done .bento article:nth-child(1) {
    grid-column: span 6;
  }
  .done .bento article:nth-child(2) {
    grid-column: span 3;
  }
  .done .bento article:nth-child(3) {
    grid-column: span 3;
  }
  .done .bento article:nth-child(4) {
    grid-column: span 4;
  }
  .done .bento article:nth-child(5) {
    grid-column: span 4;
  }
  .done .bento article:nth-child(6) {
    grid-column: span 4;
  }
  .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(--c-muted-bg);color:var(--c-muted-fg);}

    .error-page .box{max-width:760px;margin:0 auto;text-align:center;border:1px solid var(--c-card-border);border-radius:var(--radius-xl);background:var(--c-card-bg);padding:clamp(28px,4vw,46px);box-shadow:var(--shadow-md);color:var(--c-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(--c-primary-bg);color:var(--c-primary-fg);text-decoration:none;}