:root {
  --font-family: "Space Grotesk", sans-serif;
  --font-size-base: 17.1px;
  --line-height-base: 1.65;

  --max-w: 1560px;
  --space-x: 2.05rem;
  --space-y: 1.5rem;
  --gap: 2.49rem;
  --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.26rem;
  --radius-lg: 0.79rem;
  --radius-md: 0.6rem;
  --radius-sm: 0.32rem;

  --shadow-sm: 0 2px 5px rgba(0,0,0,0.09);
  --shadow-md: 0 10px 26px rgba(0,0,0,0.12);
  --shadow-lg: 0 22px 52px rgba(0,0,0,0.14);

  --overlay: rgba(30,30,30,0.7);
  --anim-duration: 450ms;
  --anim-ease: cubic-bezier(0.16,1,0.3,1);
  --random-number: 1;

  --brand: #b87333;
  --brand-contrast: #ffffff;
  --accent: #d97706;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f5f5f5;
  --neutral-300: #d4d4d4;
  --neutral-600: #737373;
  --neutral-800: #262626;
  --neutral-900: #171717;

  --page-bg: #fafafa;
  --page-fg: #1a1a1a;
  --muted-bg: #f0f0f0;
  --muted-fg: #1a1a1a;
  --card-bg: #ffffff;
  --card-fg: #1a1a1a;
  --card-border: #e5e5e5;
  --inverse-bg: #2c2c2c;
  --inverse-fg: #f5f5f5;
  --primary-bg: #b87333;
  --primary-fg: #ffffff;
  --primary-hover: #a05a2c;
  --accent-bg: #d97706;
  --accent-fg: #ffffff;
  --accent-hover: #b45309;
  --gradient-hero-bg: linear-gradient(135deg, #2c2c2c 0%, #4a4a4a 50%, #6b6b6b 100%);
  --gradient-hero-fg: #f5f5f5;
  --gradient-accent-bg: linear-gradient(135deg, #b87333 0%, #d97706 100%);
  --gradient-accent-fg: #ffffff;

  --ring: #b87333;

  --link: #b87333;
  --link-hover: #d97706;

  --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 {
        background-color: var(--page-bg);
        border-bottom: 1px solid var(--muted-bg);
        width: 100%;
    }

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

    .logo {
        font-size: var(--font-size-h3);
        font-weight: 700;
        color: var(--page-fg);
        text-decoration: none;
        white-space: nowrap;
        line-height: var(--line-height-base);
    }

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

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

    .nav-menu a {
        text-decoration: none;
        color: var(--page-fg);
        font-size: var(--font-size-md);
        padding: var(--space-y) 0;
        transition: color var(--anim-duration) var(--anim-ease);
        line-height: var(--line-height-base);
    }

    .nav-menu a:hover {
        color: var(--link-hover);
    }

    .cta-button {
        display: inline-block;
        padding: var(--space-y) var(--space-x);
        background-color: var(--primary-bg);
        color: var(--primary-fg);
        border-radius: var(--radius-md);
        text-decoration: none;
        font-size: var(--font-size-md);
        font-weight: 600;
        transition: background-color var(--anim-duration) var(--anim-ease);
        white-space: nowrap;
        line-height: var(--line-height-base);
    }

    .cta-button:hover {
        background-color: var(--primary-hover);
    }

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

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

    .burger.active span:nth-child(1) {
        transform: rotate(45deg) translate(5px, 5px);
    }

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

    .burger.active span:nth-child(3) {
        transform: rotate(-45deg) translate(5px, -5px);
    }

    @media (max-width: 767px) {
        .nav-menu {
            display: none;
            position: absolute;
            top: 100%;
            left: 0;
            width: 100%;
            background-color: var(--page-bg);
            border-bottom: 1px solid var(--muted-bg);
            padding: var(--space-y) var(--space-x);
            box-shadow: var(--shadow-md);
            z-index: 100;
        }

        .nav-menu.open {
            display: block;
        }

        .nav-menu ul {
            flex-direction: column;
            gap: var(--space-y);
        }

        .nav-menu a {
            display: block;
            padding: var(--space-y) 0;
        }

        .cta-button {
            display: none;
        }

        .burger {
            display: flex;
        }

        header {
            position: relative;
        }
    }

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

.site-footer {
  background-color: #1a1f2e;
  color: #e0e4ec;
  font-family: 'Segoe UI', Roboto, system-ui, -apple-system, sans-serif;
  padding: 2.5rem 1.5rem 1rem;
  line-height: 1.6;
}

.footer-container {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
  justify-content: space-between;
}

.footer-column {
  flex: 1 1 180px;
  min-width: 150px;
}

.brand-column {
  flex: 2 1 240px;
}

.footer-logo {
  font-size: 1.4rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.5px;
  margin-bottom: 0.5rem;
}

.footer-description {
  font-size: 0.9rem;
  color: #b0b8c9;
  margin: 0;
}

.footer-heading {
  font-size: 0.95rem;
  font-weight: 600;
  color: #ffffff;
  margin: 0 0 0.75rem 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer-nav,
.footer-legal {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-nav li,
.footer-legal li {
  margin-bottom: 0.4rem;
}

.footer-nav a,
.footer-legal a {
  color: #b0b8c9;
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 0.2s ease;
}

.footer-nav a:hover,
.footer-legal a:hover {
  color: #ffffff;
}

.contact-section {
  margin: 0;
}

.contact-item {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
}

.contact-label {
  font-weight: 600;
  color: #c8cedb;
  white-space: nowrap;
}

.contact-value {
  color: #b0b8c9;
  word-break: break-word;
}

.contact-value a {
  color: #b0b8c9;
  text-decoration: none;
}

.contact-value a:hover {
  color: #ffffff;
}

.footer-disclaimer {
  max-width: 1200px;
  margin: 1.5rem auto 0.5rem;
  padding-top: 1rem;
  border-top: 1px solid #2e3548;
  font-size: 0.8rem;
  color: #8f97aa;
  line-height: 1.5;
  text-align: center;
}

.footer-disclaimer p {
  margin: 0;
}

.footer-bottom {
  max-width: 1200px;
  margin: 0.5rem auto 0;
  text-align: center;
  font-size: 0.8rem;
  color: #7a8296;
}

.footer-bottom p {
  margin: 0;
}

@media (max-width: 640px) {
  .footer-container {
    flex-direction: column;
    gap: 1.5rem;
  }
  .footer-column {
    flex: 1 1 100%;
  }
  .footer-disclaimer {
    text-align: left;
  }
}

.cookies{position:fixed;left:12px;right:12px;bottom:12px;z-index:1200;}

    .cookies .wrap{max-width:var(--max-w);margin:0 auto;padding:14px 12px;border:1px solid var(--card-border);border-radius:12px;background:var(--card-bg);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:var(--gap);flex-wrap:wrap;color:var(--card-fg);}

    .cookies .wrap p{margin:0;}

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

    .cookies .actions button{border:0;border-radius:999px;background:var(--muted-bg);color:var(--muted-fg);padding:7px 11px;cursor:pointer;}

    .cookies .actions button[data-choice='accept']{background:var(--primary-bg);color:var(--primary-fg);}

    @media (max-width: 760px){.cookies{border-radius:var(--radius-lg);}
    }

.lead {
    background: var(--primary-fg);
    padding: clamp(60px, 10vw, 120px) clamp(16px, 3vw, 40px);
    position: relative;
    overflow: hidden;
    color: var(--primary-bg);
}

.lead::after {
    content: '';
    position: absolute;
    bottom: -100px;
    left: -100px;
    width: 400px;
    height: 400px;
    background: var(--accent-bg);
    border-radius: 50%;
    opacity: 0.1;
    filter: blur(80px);
    animation: pulseGlow 4s ease-in-out infinite;
    color: var(--accent-fg);
}

@keyframes pulseGlow {
    0%, 100% {
        transform: scale(1);
        opacity: 0.1;
    }
    50% {
        transform: scale(1.2);
        opacity: 0.15;
    }
}

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

.lead .grid {
    display: grid;
    grid-template-columns:1fr;
    gap: clamp(32px, 5vw, 64px);
    align-items: center;
}

@media (min-width: 768px) {
    .lead .grid {
        grid-template-columns:1.2fr 1fr;
    }
}

.lead .visual {
    order: var(--random-number);
}

.lead .title {
    font-size: clamp(32px, 6vw, 56px);
    font-weight: 800;
    margin: 0 0 1.5rem;
    line-height: 1.1;
    position: relative;
}

.lead .title::after {
    content: '';
    position: absolute;
    bottom: -12px;
    left: 0;
    width: 80px;
    height: 4px;
    background: var(--accent-bg);
    border-radius: var(--radius-sm);
    animation: expandLine 1s ease-out 0.8s forwards;
    transform: scaleX(0);
    transform-origin: left;
    color: var(--accent-fg);
}

@keyframes expandLine {
    to {
        transform: scaleX(1);
    }
}

.lead .description {
    font-size: clamp(16px, 2vw, 20px);
    margin: 2rem 0 0;
    opacity: 0.9;
    line-height: var(--line-height-base);
}

.lead .card {
    background: var(--gradient-hero-bg);
    padding: clamp(32px, 4vw, 48px);
    border-radius: var(--radius-xl);
    text-align: center;
    box-shadow: var(--shadow-lg);
    position: relative;
    overflow: hidden;
    color: var(--gradient-hero-fg);
}

.lead .card::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, color-mix(in srgb, currentColor 30%, transparent), transparent);
    animation: shimmer 3s infinite;
}

@keyframes shimmer {
    to {
        left: 100%;
    }
}

.lead .intro-focus-alt__icon {
    font-size: clamp(48px, 6vw, 64px);
    margin-bottom: 1rem;
}

.lead .fact {
    font-size: clamp(40px, 6vw, 56px);
    font-weight: 900;
    margin-bottom: 0.5rem;
    line-height: 1;
}

.lead .caption {
    font-size: clamp(14px, 1.5vw, 18px);
    font-weight: 600;
}

.voices{padding:clamp(18px,3vw,44px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);position:relative;overflow:hidden;}

    .voices::before{content:'';position:absolute;inset:-30%;background:radial-gradient(circle at 25% 25%,color-mix(in srgb, currentColor 14%, transparent),transparent 55%),radial-gradient(circle at 80% 55%,rgba(255, 107, 53,0.18),transparent 55%);filter:blur(18px);animation:socialC2Bg 7s var(--anim-ease) infinite;pointer-events:none;}

    @keyframes socialC2Bg{
        0%, 100% {transform:translate3d(-1%, 0,0) scale(1);}
        50%{transform:translate3d(1.5%,-1%,0) scale(1.04);}
    }

    .voices .c{max-width:var(--max-w);margin:0 auto;position:relative;}

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

    .voices .title{margin:0;font-size:clamp(24px,4.6vw,44px);letter-spacing:-.02em;line-height:1.1;}

    .voices .sub{margin:10px 0 0;max-width:70ch;color:color-mix(in srgb, currentColor 82%, transparent);}

    .voices .grid{display:grid;grid-template-columns:1.2fr 0.8fr;gap:14px;align-items:stretch;}

    .voices .quotes{position:relative;border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 10%, transparent);border:1px solid color-mix(in srgb, currentColor 16%, transparent);box-shadow:var(--shadow-lg);overflow:hidden;}

    .voices .quote{display:none;padding:18px 18px 16px;}

    .voices .quote.is-on{display:block;}

    .voices .qtext{font-size:clamp(16px,2.2vw,20px);line-height:1.7;color:color-mix(in srgb, currentColor 92%, transparent);}

    .voices .qmeta{margin-top:14px;display:flex;gap:10px;align-items:baseline;flex-wrap:wrap;}

    .voices .qname{font-weight:900;}

    .voices .qrole{opacity:.85;}

    .voices .metrics{display:grid;gap:12px;}

    .voices .metric{border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 14%, transparent);border:1px solid color-mix(in srgb, currentColor 14%, transparent);box-shadow:var(--shadow-md);padding:16px;}

    .voices .mval{font-weight:900;font-size:clamp(22px,3vw,32px);letter-spacing:-.01em;}

    .voices .mlbl{margin-top:6px;color:color-mix(in srgb, currentColor 82%, transparent);}

    @media (max-width: 980px){.voices .grid{grid-template-columns:1fr;}
    }

    @media (prefers-reduced-motion: reduce){.voices::before{animation:none;}
    }

.value-points {
    padding: calc(var(--space-y) * 2) var(--space-x);
    background: var(--muted-bg);
    color: var(--muted-fg);
}

.value-points .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
}

.value-points h2, .value-points h3, .value-points p {
    margin: 0;
}

.value-points .split, .value-points .duo {
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: var(--gap);
}

.value-points .split img, .value-points .gallery img {
    display: block;
    width: 100%;
    object-fit: cover;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
}

.value-points .split img {
    aspect-ratio: 4/3;
}

.value-points .split div {
    display: grid;
    gap: .5rem;
}

.value-points .cards {
    margin-top: var(--space-y);
    display: grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap: var(--gap);
}

.value-points article, .value-points .values div, .value-points .facts div, .value-points .quote, .value-points .statement {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-lg);
    padding: .85rem;
    color: var(--card-fg);
}

.value-points .timeline {
    display: grid;
    gap: .65rem;
}

.value-points .timeline article {
    position: relative;
    padding-left: 1.25rem;
}

.value-points .timeline article::before {
    content: "";
    position: absolute;
    left: 0;
    top: .55rem;
    width: .5rem;
    height: .5rem;
    background: var(--accent-bg);
    border-radius: 50%;
    color: var(--accent-fg);
}

.value-points .values, .value-points .facts {
    display: grid;
    gap: .6rem;
}

.value-points .gallery {
    display: grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap: var(--gap);
}

.value-points .gallery img {
    aspect-ratio: 1/1;
}

.value-points .statement {
    display: grid;
    gap: .5rem;
}

.value-points .actions {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
}

.value-points .actions a {
    display: inline-flex;
    min-height: 2.4rem;
    padding: 0 .85rem;
    border-radius: var(--radius-sm);
    align-items: center;
    text-decoration: none;
    background: var(--primary-bg);
    color: var(--primary-fg);
    border: 1px solid var(--ring);
}

@media (max-width: 900px) {
    .value-points .split, .value-points .duo, .value-points .cards, .value-points .gallery {
        grid-template-columns:1fr 1fr;
    }
}

@media (max-width: 680px) {
    .value-points .split, .value-points .duo, .value-points .cards, .value-points .gallery {
        grid-template-columns:1fr;
    }
}

.action{padding:calc(var(--space-y) * 1.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}

    .action .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}

    .action h2,.action h3,.action p{margin:0;}

    .action a{text-decoration:none;}

    .action .center,.action .banner,.action .stack,.action .bar,.action .split,.action .duo article{padding:.9rem;border-radius:var(--radius-xl);background:var(--accent-bg);border:1px solid var(--card-border);color:var(--accent-fg);}

    .action .center{display:grid;gap:.5rem;justify-items:center;text-align:center;}

    .action .split{display:grid;grid-template-columns:1fr auto;gap:var(--gap);align-items:center;}

    .action .actions{display:flex;gap:.45rem;flex-wrap:wrap;}

    .action .actions a,.action .center a,.action .banner > a,.action .duo a{display:inline-flex;min-height:2.35rem;padding:0 .85rem;align-items:center;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-fg);border:1px solid var(--ring);}

    .action .banner{display:grid;gap:.6rem;}

    .action .numbers{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;}

    .action .numbers div{padding:.6rem;border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);}

    .action .duo{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);}

    .action .duo article{display:grid;gap:.45rem;}

    .action .stack{display:grid;gap:.6rem;justify-items:start;}

    .action .chips{display:flex;gap:.35rem;flex-wrap:wrap;}

    .action .chips span{padding:.28rem .5rem;border-radius:var(--radius-sm);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);}

    .action .bar{display:grid;grid-template-columns:1fr auto;gap:var(--gap);align-items:center;}

    @media (max-width: 820px){.action .split,.action .bar,.action .duo{grid-template-columns:1fr;}

        .action .numbers{grid-template-columns:1fr 1fr;}
    }

    @media (max-width: 620px){.action .numbers{grid-template-columns:1fr;}
    }

.faq-guide-article {
  background: var(--page-bg);
  color: var(--page-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-guide-article .wrap {
  width: min(100%, var(--max-w));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .76fr) minmax(0, .62fr);
  gap: var(--space-block);
}
.faq-guide-article h2,
.faq-guide-article h3,
.faq-guide-article p { margin: 0; }
.faq-guide-article h2 { font-size: var(--font-size-h1); line-height: 1.03; }
.faq-guide-article h3 { font-size: var(--font-size-h3); line-height: 1.16; }
.faq-guide-article p { font-size: var(--font-size-md); line-height: var(--line-height-base); }
.faq-guide-article .[data-block] {
  display: grid;
  gap: var(--space-y);
  max-width: 62ch;
}
.faq-guide-article .chapter span { color: var(--muted-fg); }
.faq-guide-article .chapters {
  display: grid;
  gap: var(--space-card);
}
.faq-guide-article .chapter {
  display: grid;
  gap: var(--space-card);
  padding: 0 0 var(--space-y) var(--space-y);
  border-left: 1px solid var(--card-border);
}
.faq-guide-article .chapter:nth-child(2n) { padding-top: var(--space-card); }
.faq-guide-article .cta {
  grid-column: 1 / -1;
  width: fit-content;
  padding: calc(var(--space-card) * .75) var(--space-y);
  border-radius: var(--radius-md);
  background: var(--primary-bg);
  color: var(--primary-fg);
  text-decoration: none;
}
@media (max-width: 860px) {
  .faq-guide-article .wrap { grid-template-columns: 1fr; }
  .faq-guide-article h2 { font-size: clamp(var(--font-size-h2), 13vw, var(--font-size-h1)); }
}

.panel-project-list.light {
    padding: 48px 20px;
    background: var(--card-bg);
    color: var(--card-fg);
}

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

.panel-project-list .inner h2 {
    margin: 0 0 10px;
    font-size: clamp(22px, 3.5vw, 28px);
}

.panel-project-list .list {
    margin: 0;
    padding: 0;
    list-style: none;
    border-radius: var(--radius-xl);
    background: var(--page-bg);
    border: 1px solid var(--card-border);
    overflow: hidden;
    color: var(--page-fg);
}

.panel-project-list .row {
    display: grid;
    grid-template-columns:minmax(0, 1.6fr) auto;
    gap: 12px;
    padding: 8px 12px;
    border-top: 1px solid var(--card-border);
}

.panel-project-list .row:first-child {
    border-top: none;
}

.panel-project-list .row-title {
    font-size: 0.9rem;
}

.panel-project-list .row-meta {
    font-size: 0.9rem;
}

.suggestions{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--inverse-bg);color:var(--inverse-fg);}
.suggestions .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}
.suggestions h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;}
.suggestions .sub{margin:.35rem 0 0;opacity:.9;}
.suggestions article,.suggestions 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);}
.suggestions p{margin:0;}
.suggestions a{text-decoration:none;color:inherit;font-weight:700;}
.suggestions .table{display:grid;gap:.5rem;}
.suggestions .foot{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.65rem;}
.suggestions .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){.suggestions .split,.suggestions .media,.suggestions .grid,.suggestions .cards,.suggestions .bento,.suggestions .foot{grid-template-columns:1fr;}}

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

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

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

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

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

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

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

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

.featured-cairn{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.featured-cairn .cairn-wrap{max-width:var(--max-w);margin:0 auto}
.featured-cairn h2{margin:0 0 1.2rem;color:var(--page-fg);font-size:clamp(1.9rem,4vw,3.1rem);line-height:1.05}
.featured-cairn .cairn-list{display:flex;gap:.85rem;align-items:stretch;overflow:auto;padding-bottom:.25rem}
.featured-cairn .cairn-card{flex:0 0 min(24rem,82vw);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:1rem;box-shadow:var(--shadow-sm)}
.featured-cairn h3{margin:0;color:var(--card-fg);font-size:var(--font-size-h3);line-height:1.15}
.featured-cairn p{margin:.65rem 0 0;color:var(--card-fg);opacity:.82;line-height:1.45}

.form-finelane{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.form-finelane .finelane-wrap{max-width:var(--max-w);margin:0 auto;display:grid;gap:1rem;}.form-finelane .finelane-title{max-width:50rem;}.form-finelane h2{margin:0;font-size:clamp(1.9rem,3.5vw,2.85rem);line-height:1.06;}.form-finelane p{margin:.7rem 0 0;color:var(--neutral-600);}
.form-finelane .finelane-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.6rem;}.form-finelane label{grid-column:span 2;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:.85rem;display:grid;gap:.28rem;color:var(--card-fg);}.form-finelane span{font-size:.8rem;color:var(--neutral-600);}.form-finelane input,.form-finelane textarea{width:100%;border:0;background:var(--card-bg);color:var(--card-fg);font:inherit;outline-color:var(--ring);}
.form-finelane .finelane-wide{grid-column:1/4;}.form-finelane textarea{min-height:8rem;resize:vertical;}.form-finelane button{grid-column:4;align-self:stretch;border:0;border-radius:var(--radius-lg);background:var(--primary-bg);color:var(--primary-fg);font:inherit;font-weight:700;padding:.85rem;}
@media (max-width:850px){.form-finelane .finelane-form{grid-template-columns:1fr;}.form-finelane label,.form-finelane .finelane-wide,.form-finelane button{grid-column:auto;}}

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

.connect-softrail{padding:calc(var(--space-y)*2.4) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.connect-softrail .softrail-shell{max-width:var(--max-w);margin:0 auto}
.connect-softrail h2{margin:0;color:var(--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(--neutral-600)}
.connect-softrail .softrail-row{display:flex;gap:.55rem;flex-wrap:wrap}
.connect-softrail a{background:var(--inverse-bg);color:var(--inverse-fg);border:1px solid var(--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-deepfile{padding:calc(var(--space-y)*3) var(--space-x);background:var(--neutral-900);color:var(--neutral-0);}
.policy-deepfile .deepfile-wrap{max-width:var(--max-w);margin:0 auto;}.policy-deepfile h2{margin:0 0 1rem;font-size:clamp(2rem,4vw,3.2rem);line-height:1.04;}.policy-deepfile .deepfile-body{display:grid;grid-template-columns:.55fr 1.45fr;gap:var(--gap);}.policy-deepfile .deepfile-body>p{margin:0;color:var(--neutral-300);}.policy-deepfile .deepfile-body>div{display:grid;gap:.65rem;}.policy-deepfile .article{border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-md);padding:.85rem;}.policy-deepfile h3{margin:0 0 .3rem;color:var(--neutral-0);font-size:1rem;}.policy-deepfile .article p{margin:0;color:var(--neutral-300);}
@media (max-width:780px){.policy-deepfile .deepfile-body{grid-template-columns:1fr;}}

.conditions{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:var(--card-bg);color:var(--card-fg);}

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

    .conditions .section-head{margin-bottom:16px;text-align:center;}

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

    .conditions .section-head p{margin:10px auto 0;color:var(--neutral-600);max-width:70ch;}

    .conditions ol{margin:0;padding-left:18px;display:grid;gap:10px;}

    .conditions li{background:var(--muted-bg);border-radius:var(--radius-md);border:1px solid var(--card-border);padding:12px;color:var(--muted-fg);}

    .conditions h3{margin:0;font-size:1rem;}

    .conditions li p{margin:8px 0 0;color:var(--neutral-600);}

.confirmation{padding:calc(var(--space-y)*2.8) var(--space-x);color:var(--page-fg);background:var(--page-bg);}
.confirmation .shell{max-width:880px;margin:0 auto;display:grid;gap:.65rem;text-align:center;}
.confirmation h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.75rem);}
.confirmation .sub{margin:0;}
.confirmation .next,.confirmation .contact{padding:.9rem;border-radius:var(--radius-lg);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.confirmation h3{margin:0 0 .22rem;font-size:1rem;}
.confirmation p{margin:0;}
.confirmation a{color:var(--link);}
.confirmation a:hover{color:var(--link-hover);}

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

    .not-found .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);}

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

    .not-found p{margin:10px 0 0;}

    .not-found 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;}