:root {
  --font-family: "Sora", sans-serif;
  --font-size-base: 18.6px;
  --line-height-base: 1.6;

  --max-w: 1300px;
  --space-x: 2.15rem;
  --space-y: 1.5rem;
  --gap: 1.79rem;
  --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.07rem;
  --radius-lg: 0.76rem;
  --radius-md: 0.61rem;
  --radius-sm: 0.34rem;

  --shadow-sm: 0 2px 8px rgba(0,0,0,0.08);
  --shadow-md: 0 12px 26px rgba(0,0,0,0.11);
  --shadow-lg: 0 20px 32px rgba(0,0,0,0.13);

  --overlay: rgba(30,35,40,0.7);
  --anim-duration: 260ms;
  --anim-ease: ease-in-out;
  --random-number: 1;

  --brand: #2d5a4b;
  --brand-contrast: #ffffff;
  --accent: #1e7e5e;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f2f4f5;
  --neutral-300: #c5cbd0;
  --neutral-600: #6b7680;
  --neutral-800: #2d3338;
  --neutral-900: #1a1e22;

  --page-bg: #f7f8f9;
  --page-fg: #1a1e22;
  --muted-bg: #eef1f3;
  --muted-fg: #2d3338;
  --card-bg: #ffffff;
  --card-fg: #1a1e22;
  --card-border: #d6dce0;
  --inverse-bg: #1a1e22;
  --inverse-fg: #e8f0ed;
  --primary-bg: #2d5a4b;
  --primary-fg: #ffffff;
  --primary-hover: #234a3d;
  --accent-bg: #1e7e5e;
  --accent-fg: #ffffff;
  --accent-hover: #166a4e;
  --gradient-hero-bg: linear-gradient(135deg, #1a1e22 0%, #2d3338 50%, #1e7e5e 100%);
  --gradient-hero-fg: #e8f0ed;
  --gradient-accent-bg: linear-gradient(135deg, #1e7e5e 0%, #2d5a4b 100%);
  --gradient-accent-fg: #ffffff;

  --ring: #1e7e5e;

  --link: #2d5a4b;
  --link-hover: #1e7e5e;

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

/* ---------- reset / base for header ---------- */
.site-header {
  width: 100%;
  background-color: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--muted-bg, #e5e7eb);
  font-family: var(--font-family, system-ui, -apple-system, sans-serif);
  font-size: var(--font-size-base, 1rem);
  line-height: var(--line-height-base, 1.5);
  box-sizing: border-box;
}

/* wrapper: full-width background, inner content max-width */
.wrapper {
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding-left: var(--space-x, 1.5rem);
  padding-right: var(--space-x, 1.5rem);
  box-sizing: border-box;
}

/* ----- utility row ----- */
.header-utility {
  background-color: var(--muted-bg, #f3f4f6);
  color: var(--muted-fg, #1f2937);
  font-size: var(--font-size-sm, 0.875rem);
  padding-top: 0.4rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--card-border, #d1d5db);
}

.utility-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 1.2rem;
}

.utility-phone,
.utility-email {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

/* ----- main row: logo + nav + burger ----- */
.header-main {
  background-color: var(--page-bg, #ffffff);
  color: var(--page-fg, #111827);
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
}

.main-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
}

.logo {
  font-size: var(--font-size-h2, 1.75rem);
  font-weight: 600;
  text-decoration: none;
  color: var(--page-fg, #111827);
  letter-spacing: -0.02em;
  line-height: 1.2;
  flex-shrink: 0;
}

.logo:hover {
  opacity: 0.85;
}

/* horizontal navigation */
.nav-horizontal {
  display: flex;
  align-items: center;
}

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

.nav-link {
  text-decoration: none;
  color: var(--page-fg, #111827);
  font-weight: 500;
  font-size: var(--font-size-md, 1rem);
  padding: 0.25rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
}

.nav-link:hover {
  border-bottom-color: var(--accent-bg, #2563eb);
  color: var(--accent-fg, #ffffff);
  background-color: var(--accent-bg, #2563eb);
  border-radius: var(--radius-sm, 4px);
  padding: 0.25rem 0.5rem;
  margin: -0.25rem -0.5rem;
}

/* burger button – hidden on desktop */
.burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.25rem;
  gap: 4px;
  border-radius: var(--radius-sm, 4px);
  transition: background var(--anim-duration, 0.2s);
}

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

.burger-line {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--page-fg, #111827);
  border-radius: 2px;
  transition: all var(--anim-duration, 0.2s);
}

/* ---------- mobile styles ---------- */
@media (max-width: 767px) {
  .nav-horizontal {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: var(--page-bg, #ffffff);
    box-shadow: var(--shadow-lg, 0 10px 25px rgba(0,0,0,0.12));
    border-top: 1px solid var(--card-border, #d1d5db);
    max-height: 0;
    overflow: hidden;
    visibility: hidden;
    transition: max-height 0.35s ease, visibility 0.35s ease, opacity 0.25s ease;
    opacity: 0;
    z-index: 100;
  }

  .nav-horizontal.is-open {
    max-height: 400px;
    visibility: visible;
    opacity: 1;
    overflow: visible;
  }

  .nav-list {
    flex-direction: column;
    gap: 0.25rem;
    padding: 1rem var(--space-x, 1.5rem);
    width: 100%;
  }

  .nav-link {
    display: block;
    padding: 0.6rem 0.75rem;
    font-size: var(--font-size-md, 1rem);
    border-bottom: none;
    border-radius: var(--radius-sm, 4px);
  }

  .nav-link:hover {
    background-color: var(--muted-bg, #f3f4f6);
    border-bottom: none;
    padding: 0.6rem 0.75rem;
    margin: 0;
  }

  .burger {
    display: flex;
  }

  /* adjust utility row for small screens */
  .utility-inner {
    justify-content: center;
    gap: 1rem;
  }

  .header-main {
    position: relative; /* anchor for absolute nav */
  }
}

/* tiny screens: utility wrap */
@media (max-width: 480px) {
  .utility-inner {
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
  }
}

footer {
    background-color: #1a1a2e;
    color: #e0e0e0;
    padding: 2rem 1rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
  }
  .footer-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1.5rem;
  }
  .footer-contact address {
    font-style: normal;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  .contact-item {
    color: #b0b0c0;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.3s ease;
  }
  .contact-item:hover {
    color: #ffffff;
  }
  .footer-brand .brand-logo {
    font-size: 1.8rem;
    font-weight: 700;
    color: #f0a500;
    letter-spacing: 2px;
    text-transform: uppercase;
  }
  .footer-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.2rem;
  }
  .footer-nav a {
    color: #c0c0d0;
    text-decoration: none;
    font-size: 1rem;
    padding: 0.3rem 0;
    border-bottom: 2px solid transparent;
    transition: all 0.3s ease;
  }
  .footer-nav a:hover {
    color: #f0a500;
    border-bottom-color: #f0a500;
  }
  .footer-legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
  }
  .footer-legal a {
    color: #9090a0;
    text-decoration: none;
    font-size: 0.85rem;
    transition: color 0.3s ease;
  }
  .footer-legal a:hover {
    color: #f0a500;
  }
  .footer-disclaimer p {
    font-size: 0.8rem;
    color: #808090;
    max-width: 800px;
    margin: 0 auto;
    line-height: 1.4;
  }
  .footer-copyright p {
    font-size: 0.8rem;
    color: #707080;
    margin: 0;
  }
  @media (min-width: 768px) {
    footer {
      padding: 3rem 2rem;
    }
    .footer-container {
      gap: 2rem;
    }
    .footer-contact address {
      flex-direction: row;
      gap: 2rem;
    }
    .footer-nav {
      gap: 2rem;
    }
    .footer-legal {
      gap: 2rem;
    }
  }

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

    .cookies .inner{max-width:var(--max-w);margin:0 auto;padding:calc(var(--space-y) * 0.8) var(--space-x);background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -8px 24px rgba(15, 23, 42,0.12);display:flex;flex-wrap:wrap;gap:12px var(--gap);align-items:center;justify-content:space-between;color:var(--card-fg);}

    .cookies .text{flex:1 1 420px;}

    .cookies .badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:12px;font-weight:700;margin-bottom:6px;background:var(--muted-bg);color:var(--muted-fg);}

    .cookies .text strong{display:block;margin-bottom:4px;}

    .cookies .text p{margin:0;}

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

    .cookies .actions button{border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-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;}

.intro-nightledger{padding:calc(var(--space-y)*3.2) var(--space-x);background:var(--neutral-900);color:var(--neutral-0);}
.intro-nightledger .nightledger-wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1.25fr .75fr;gap:var(--gap);align-items:end;}.intro-nightledger h1{margin:0;font-size:clamp(2.6rem,7vw,6.2rem);line-height:.92;}.intro-nightledger .aside{border-left:1px solid rgba(255,255,255,.24);padding-left:1rem;}.intro-nightledger span{display:block;color:var(--neutral-300);}.intro-nightledger .nav{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.1rem;}.intro-nightledger a{color:var(--accent-fg);background:var(--accent-bg);text-decoration:none;border-radius:999px;padding:.72rem .95rem;font-weight:700;}
@media (max-width:760px){.intro-nightledger .nightledger-wrap{grid-template-columns:1fr;}.intro-nightledger .aside{border-left:0;padding-left:0;}}

.tpl-variant-next-step-light-v9{background-image:linear-gradient(135deg,color-mix(in srgb,currentColor 6%,transparent),transparent 48%);}
.tpl-variant-next-step-light-v9 .grid,.tpl-variant-next-step-light-v9 .cards,.tpl-variant-next-step-light-v9 .list,.tpl-variant-next-step-light-v9 .stack{gap:calc(var(--gap,1rem) * 1.08);}
.tpl-variant-next-step-light-v9 article:nth-child(even),.tpl-variant-next-step-light-v9 .card:nth-child(even),.tpl-variant-next-step-light-v9 .item:nth-child(even){transform:translateY(0.35rem);}
.followup{padding:calc(var(--space-y) * 1.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

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

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

    .followup a{text-decoration:none;}

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

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

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

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

    .followup .actions a,.followup .center a,.followup .banner > a,.followup .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);}

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

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

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

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

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

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

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

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

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

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

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

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

.reasons {
    padding: clamp(3rem, 7vw, 5.8rem) var(--space-x);
    background: linear-gradient(180deg, var(--primary-bg), var(--gradient-hero-bg));
    color: var(--gradient-hero-fg);
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.reasons::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0 18%, color-mix(in srgb, currentColor 9%, transparent) 18% 19%, transparent 19% 42%, color-mix(in srgb, currentColor 7%, transparent) 42% 43%, transparent 43%);
    background-size: 38rem 100%;
    animation: whyChooseDrift 14s linear infinite;
    pointer-events: none;
    z-index: -1;
}

@keyframes whyChooseDrift {
    from {
        background-position: 0 0;
    }

    to {
        background-position: 38rem 0;
    }
}

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

.reasons .band {
    display: grid;
    grid-template-columns:1fr minmax(14rem, .55fr);
    gap: var(--gap);
    align-items: end;
    margin-bottom: 1rem;
}

.reasons h2 {
    margin: 0;
    font-size: clamp(2rem, 4.8vw, 4rem);
    line-height: 1;
}

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

.reasons .tiles {
    display: grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap: 1px;
    background: color-mix(in srgb, currentColor 22%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 22%, transparent);
}

.reasons article {
    min-height: 12rem;
    padding: clamp(1rem, 2vw, 1.35rem);
    background: color-mix(in srgb, currentColor 9%, transparent);
    display: grid;
    align-content: space-between;
    gap: 2rem;
}

.reasons .topline {
    display: flex;
    gap: .8rem;
    align-items: flex-start;
}

.reasons span {
    font-weight: 800;
    color: var(--accent-bg);
}

.reasons strong {
    font-size: clamp(1rem, 2vw, 1.25rem);
}

.reasons article p {
    margin: 0;
    color: color-mix(in srgb, currentColor 82%, transparent);
    line-height: var(--line-height-base);
}

@media (max-width: 760px) {
    .reasons .band, .reasons .tiles {
        grid-template-columns:1fr;
    }

    .reasons article {
        min-height: auto;
    }
}

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

.voices{padding:clamp(18px,3vw,44px);background:var(--page-bg);color:var(--page-fg);}

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

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

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

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

    .voices .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;}

    .voices .card{grid-column:span 4;border-radius:var(--radius-xl);background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow-md);padding:16px;position:relative;transform-style:preserve-3d;transition:transform 420ms var(--anim-ease);min-height:170px;color:var(--card-fg);}

    .voices .card:hover{transform:rotateY(180deg);}

    .voices .front,.voices .back{position:absolute;inset:0;padding:16px;backface-visibility:hidden;border-radius:inherit;}

    .voices .front::before{content:'';position:absolute;inset:-1px;background:radial-gradient(260px 130px at 20% 15%,rgba(0, 86, 179,0.12),transparent 60%),radial-gradient(240px 140px at 85% 35%,rgba(255, 107, 53,0.12),transparent 62%);pointer-events:none;border-radius:inherit;color:var(--neutral-0);}

    .voices .chip{display:inline-flex;padding:6px 10px;border-radius:999px;background:var(--accent-bg);color:var(--accent-fg);border:1px solid color-mix(in srgb, currentColor 6%, transparent);font-weight:900;position:relative;}

    .voices .big{margin-top:12px;font-weight:900;font-size:clamp(18px,2.4vw,28px);letter-spacing:-.01em;position:relative;}

    .voices .small{margin-top:8px;line-height:var(--line-height-base);position:relative;}

    .voices .back{transform:rotateY(180deg);background:var(--muted-bg);border:1px solid var(--card-border);color:var(--muted-fg);}

    .voices .backtitle{font-weight:900;letter-spacing:-.01em;margin-bottom:8px;}

    .voices .backtext{line-height:var(--line-height-base);}

    @media (max-width: 980px){.voices .card{grid-column:span 6;}
    }

    @media (max-width: 640px){.voices .card{grid-column:span 12;}
    }

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

.faq-panelaccordion {
  background: var(--inverse-bg);
  color: var(--inverse-fg);
  padding: var(--space-section-y) var(--space-section-x);
}
.faq-panelaccordion .panel {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
  gap: var(--space-block);
}
.faq-panelaccordion .intro {
  display: grid;
  gap: var(--space-card);
  align-content: start;
}
.faq-panelaccordion h2,
.faq-panelaccordion p {
  margin: 0;
}
.faq-panelaccordion h2 {
  font-size: var(--font-size-h1);
  line-height: .96;
}
.faq-panelaccordion .intro span {
  color: var(--primary-bg);
  font-size: var(--font-size-sm);
}
.faq-panelaccordion .accordion {
  display: grid;
  gap: var(--space-card);
}
.faq-panelaccordion .item {
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.faq-panelaccordion button {
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  padding: var(--space-card);
  font: inherit;
  font-size: var(--font-size-lg);
  text-align: left;
  cursor: pointer;
}
.faq-panelaccordion .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-panelaccordion .item.is-open p {
  max-height: calc(var(--space-block) * 5);
  padding-bottom: var(--space-card);
}
@media (max-width: 760px) {
  .faq-panelaccordion .panel {
    grid-template-columns: 1fr;
  }
}

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

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

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

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

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

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

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

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

.recommendations{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .recommendations .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .recommendations h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .recommendations .sub{margin:.35rem 0 0;opacity:.9;} .recommendations article,.recommendations 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);} .recommendations p{margin:0;} .recommendations a{text-decoration:none;color:inherit;font-weight:700;} .recommendations .cards{padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;} .recommendations article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .recommendations article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.recommendations .split,.recommendations .media,.recommendations .grid,.recommendations .cards,.recommendations .bento,.recommendations .foot{grid-template-columns:1fr;}}

.panel-project-item.colored{padding:56px 20px;background:var(--inverse-bg);color:var(--inverse-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(--gradient-hero-bg);color:var(--gradient-hero-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(--gradient-hero-bg);color:var(--gradient-hero-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(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);box-shadow:var(--shadow-md);color:var(--accent-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(--card-border);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);}

.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(--primary-bg);color:var(--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(--primary-hover);color:var(--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(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}

.inquiry .bar {display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:.65rem;padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}

.inquiry .stack {padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);}

.inquiry .steps {display:flex;gap:.45rem;flex-wrap:wrap;}

.inquiry .steps span {padding:.33rem .55rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);font-size:.8rem;color:var(--accent-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;}

@media (max-width: 860px) {
    .inquiry .split, .inquiry .media, .inquiry .frame {grid-template-columns:1fr;}

    .inquiry .grid, .inquiry .bar {grid-template-columns:1fr;}
}

.area-map{padding:clamp(3.1rem,7vw,5.7rem) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

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

    .area-map .head{text-align:center;margin-bottom:1rem;}

    .area-map .head p{margin:0;}

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

    .area-map .frame{overflow:hidden;border-radius:var(--radius-xl);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);}

    .area-map .frame iframe{display:block;width:100%;height:24rem;}

    .area-map .grid{margin-top:1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--gap);}

    .area-map .grid article{padding:.95rem;border-radius:var(--radius-md);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}

    .area-map .grid p{margin:.35rem 0 0;}

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

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

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

    .support .head{margin-bottom:14px;}

    .support .head p{margin:0;font-weight:700;opacity:.9;}

    .support .head h2{margin:7px 0 0;font-size:clamp(30px,5vw,46px);}

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

    .support .grid article{border-radius:var(--radius-lg);border:1px solid color-mix(in srgb, currentColor 12%, transparent);background:color-mix(in srgb, currentColor 32%, transparent);padding:13px;box-shadow:var(--shadow-sm);}

    .support .grid span{font-size:.82rem;}

    .support .grid h3{margin:var(--space-x) 0;}

    .support .grid p{margin:0;}

.contacts-calmgrid{padding:calc(var(--space-y)*2.6) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.contacts-calmgrid .calmgrid-box{max-width:var(--max-w);margin:0 auto;}
.contacts-calmgrid .calmgrid-intro{max-width:45rem;margin-bottom:1.35rem;}
.contacts-calmgrid h2{margin:0;font-size:clamp(1.85rem,3.2vw,2.75rem);line-height:1.08;}
.contacts-calmgrid .calmgrid-intro p{margin:.75rem 0 0;color:var(--neutral-600);}
.contacts-calmgrid .calmgrid-info{display:grid;grid-template-columns:1.1fr .9fr .85fr .85fr;border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.contacts-calmgrid .article{min-height:9.2rem;padding:1rem;border-right:1px solid var(--card-border);display:flex;flex-direction:column;justify-content:space-between;}
.contacts-calmgrid .article:last-child{border-right:0;}
.contacts-calmgrid b{font-size:.82rem;color:var(--neutral-600);}
.contacts-calmgrid .address,.contacts-calmgrid .article p{margin:0;font-style:normal;line-height:1.32;}
.contacts-calmgrid a{text-decoration:none;overflow-wrap:anywhere;}
.contacts-calmgrid .calmgrid-action a{font-weight:700;}
.contacts-calmgrid .calmgrid-chips{list-style:none;margin:.8rem 0 0;padding:0;display:flex;gap:.55rem;flex-wrap:wrap;}
.contacts-calmgrid .calmgrid-chips a{display:inline-flex;gap:.4rem;align-items:center;border-radius:var(--radius-sm);padding:.55rem .7rem;background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.contacts-calmgrid .calmgrid-chips span{color:var(--neutral-600);}
@media (max-width:900px){.contacts-calmgrid .calmgrid-info{grid-template-columns:1fr 1fr;}.contacts-calmgrid .article:nth-child(2){border-right:0;}.contacts-calmgrid .article{border-bottom:1px solid var(--card-border);}}
@media (max-width:560px){.contacts-calmgrid .calmgrid-info{grid-template-columns:1fr;}.contacts-calmgrid .article{border-right:0;min-height:auto;gap:1.2rem;}.contacts-calmgrid .article:nth-child(2){border-bottom:1px solid var(--card-border);}}

.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 .rail{display:flex;gap:.55rem;overflow:auto;} .privacy .rail article{min-width:240px;} .privacy article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .privacy article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.privacy .split,.privacy .media,.privacy .grid,.privacy .cards,.privacy .bento,.privacy .foot{grid-template-columns:1fr;}}

.terms-contrastfile{padding:calc(var(--space-y)*3) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}
.terms-contrastfile .contrastfile-wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.72fr 1.28fr;gap:var(--gap);}.terms-contrastfile h2{margin:0;font-size:clamp(2rem,4vw,3.2rem);line-height:1.04;}.terms-contrastfile .contrastfile-head p{margin:.8rem 0 0;}.terms-contrastfile ol{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;}.terms-contrastfile li{background:var(--card-bg);color:var(--card-fg);border-radius:var(--radius-lg);padding:.9rem;}.terms-contrastfile h3{margin:0 0 .3rem;font-size:1rem;}.terms-contrastfile li p{margin:0;color:var(--neutral-600);}
@media (max-width:860px){.terms-contrastfile .contrastfile-wrap,.terms-contrastfile ol{grid-template-columns:1fr;}}

.received {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
  }
  .received .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
  }
  .received h2 {
    margin: 0;
    font-size: clamp(1.85rem, 3.6vw, 2.8rem);
    line-height: 1.1;
  }
  .received .sub {
    margin: 0.35rem 0 0;
    opacity: 0.9;
  }
  .received article,
  .received li {
    padding: 0.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);
  }
  .received p {
    margin: 0;
  }
  .received a {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
  }
  .received .pulse {
    margin-top: 0.8rem;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    animation: thank-u1Pulse 2.8s ease-in-out infinite;
    color: var(--accent-fg);
  }
  @keyframes thank-u1Pulse {
    0%,
    100% {
      transform: scale(1);
    }
    50% {
      transform: scale(1.01);
    }
  }
  @media (max-width: 860px) {
    .received .split,
    .received .media,
    .received .grid,
    .received .cards,
    .received .bento,
    .received .foot {
      grid-template-columns: 1fr;
    }
  }

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

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

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

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

    .error-page a{display:inline-block;margin-top:18px;text-decoration:none;border-bottom:2px solid var(--link);padding-bottom:2px;}