:root {
  --font-family: "Exo 2", sans-serif;
  --font-size-base: 19.6px;
  --line-height-base: 1.74;

  --max-w: 1300px;
  --space-x: 1.77rem;
  --space-y: 1.5rem;
  --gap: 1.34rem;
  --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.05rem;
  --radius-lg: 0.93rem;
  --radius-md: 0.54rem;
  --radius-sm: 0.33rem;

  --shadow-sm: 0 2px 5px rgba(0,0,0,0.14);
  --shadow-md: 0 12px 20px rgba(0,0,0,0.18);
  --shadow-lg: 0 20px 50px rgba(0,0,0,0.22);

  --overlay: rgba(15,15,25,0.7);
  --anim-duration: 330ms;
  --anim-ease: ease-in-out;
  --random-number: 1;

  --brand: #6b3fa0;
  --brand-contrast: #ffffff;
  --accent: #d32f2f;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f5f5f7;
  --neutral-300: #c7c7d1;
  --neutral-600: #6b6b7a;
  --neutral-800: #2d2d3a;
  --neutral-900: #1a1a26;

  --c-page-bg: #f5f5f7;
  --c-page-fg: #1a1a26;
  --c-muted-bg: #e8e8ee;
  --c-muted-fg: #2d2d3a;
  --c-card-bg: #ffffff;
  --c-card-fg: #1a1a26;
  --c-card-border: #d0d0db;
  --c-inverse-bg: #1a1a26;
  --c-inverse-fg: #f5f5f7;
  --c-primary-bg: #6b3fa0;
  --c-primary-fg: #ffffff;
  --c-primary-hover: #5a3490;
  --c-accent-bg: #d32f2f;
  --c-accent-fg: #ffffff;
  --c-accent-hover: #b71c1c;
  --g-hero-bg: linear-gradient(135deg, #1a1a26 0%, #2d2d3a 50%, #6b3fa0 100%);
  --g-hero-fg: #f5f5f7;
  --g-accent-bg: linear-gradient(135deg, #d32f2f 0%, #b71c1c 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: #6b3fa0;

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

  --link: #6b3fa0;
  --link-hover: #d32f2f;

  --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-muted-bg) 82%, var(--c-card-bg) 18%);
  --chip-fg: var(--c-muted-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-color: var(--section-light-bg);
  color: var(--section-light-fg);
  width: 100%;
  border-bottom: 1px solid var(--c-card-border);
}

.header-utility {
  background-color: var(--c-inverse-bg);
  color: var(--c-inverse-fg);
  font-size: var(--font-size-sm);
  padding: 0.4rem 0;
}

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

.utility-text {
  opacity: 0.85;
}

.header-main {
  padding: 0.75rem 0;
}

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

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

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

.nav-link {
  text-decoration: none;
  color: var(--section-light-fg);
  font-size: var(--font-size-md);
  padding: 0.4rem 0.2rem;
  transition: color var(--anim-duration) var(--anim-ease);
  position: relative;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background-color: var(--c-accent-bg);
  transition: width var(--anim-duration) var(--anim-ease);
}

.nav-link:hover {
  color: var(--c-accent-bg);
}

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

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

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

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

@media (max-width: 767px) {
  .nav-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: var(--section-light-bg);
    border-top: 1px solid var(--c-card-border);
    box-shadow: var(--shadow-md);
    z-index: 100;
  }

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

  .nav-list {
    flex-direction: column;
    padding: var(--space-y) var(--space-x);
    gap: 0.5rem;
  }

  .nav-link {
    display: block;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--c-card-border);
  }

  .nav-link:last-child {
    border-bottom: none;
  }

  .burger {
    display: flex;
  }

  .header-main {
    position: relative;
  }
}

footer {
    background: linear-gradient(135deg, #0b0f1c 0%, #1a1f33 100%);
    color: #e0e5f0;
    font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
    padding: 3rem 2rem 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.5);
  }

  .footer-container {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 2rem;
    max-width: 1280px;
    margin: 0 auto;
  }

  .footer-column h3, .footer-column h4 {
    margin: 0 0 1rem 0;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #ffffff;
  }

  .footer-logo {
    font-size: 1.8rem;
    font-weight: 700;
    background: linear-gradient(135deg, #a0b4ff, #7a8cff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 0.5rem;
  }

  .footer-tagline {
    font-size: 0.95rem;
    opacity: 0.75;
    line-height: 1.5;
  }

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

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

  .footer-nav a, .footer-legal a {
    color: #c8d0e6;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s ease, padding-left 0.2s ease;
    display: inline-block;
  }

  .footer-nav a:hover, .footer-legal a:hover {
    color: #a0b4ff;
    padding-left: 4px;
  }

  .footer-contact {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .footer-contact h4 {
    margin-bottom: 0.5rem;
  }

  .contact-item {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.6;
    display: flex;
    flex-wrap: wrap;
  }

  .contact-label {
    font-weight: 600;
    color: #a0b4ff;
    margin-right: 0.4rem;
    min-width: 5rem;
  }

  .contact-item a {
    color: #c8d0e6;
    text-decoration: none;
    transition: color 0.2s;
  }

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

  .footer-disclaimer {
    max-width: 1280px;
    margin: 2rem auto 1.5rem;
    padding: 1rem 1.5rem;
    background: rgba(255, 255, 255, 0.04);
    border-radius: 8px;
    border-left: 3px solid #7a8cff;
    font-size: 0.85rem;
    line-height: 1.5;
    color: #b0b8d0;
    text-align: center;
  }

  .footer-disclaimer p {
    margin: 0;
  }

  .footer-bottom {
    max-width: 1280px;
    margin: 0 auto;
    text-align: center;
    padding-top: 1.2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    font-size: 0.85rem;
    color: #8890a8;
  }

  .footer-bottom p {
    margin: 0;
  }

  /* Responsywność */
  @media (max-width: 1024px) {
    .footer-container {
      grid-template-columns: 1fr 1fr;
      gap: 2rem;
    }
  }

  @media (max-width: 640px) {
    footer {
      padding: 2rem 1.2rem 1rem;
    }

    .footer-container {
      grid-template-columns: 1fr;
      gap: 1.8rem;
    }

    .footer-logo {
      font-size: 1.6rem;
    }

    .footer-disclaimer {
      padding: 0.8rem 1rem;
      font-size: 0.8rem;
    }
  }

.cookies{position:fixed;left:var(--space-x);bottom:var(--space-y);width:min(360px,calc(100vw - (var(--space-x) * 2)));z-index:1200;}

    .cookies .card{border-radius:var(--radius-lg);padding:var(--space-y) var(--space-x);background:linear-gradient(140deg,var(--c-primary-bg),var(--c-primary-hover));color:var(--c-primary-fg);box-shadow:var(--shadow-lg);}

    .cookies .card h3{margin:0 0 6px;}

    .cookies .card p{margin:0;opacity:.92;}

    .cookies .actions{margin-top:12px;display:grid;gap:8px;}

    .cookies .actions button{border:1px solid color-mix(in srgb, currentColor 28%, transparent);background:color-mix(in srgb, currentColor 14%, transparent);color:inherit;border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;}

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

.intro-linedock{padding:calc(var(--space-y)*3) var(--space-x);background:var(--c-card-bg);color:var(--c-card-fg);}
.intro-linedock .linedock-wrap{max-width:var(--max-w);margin:0 auto;border-top:1px solid var(--c-card-border);border-bottom:1px solid var(--c-card-border);padding:1rem 0;}.intro-linedock h1{margin:.8rem 0;font-size:clamp(2.4rem,6.2vw,5.6rem);line-height:.94;max-width:920px;}.intro-linedock .linedock-bottom{display:flex;justify-content:space-between;gap:var(--gap);align-items:center;}.intro-linedock span{max-width:38rem;color:var(--neutral-600);}.intro-linedock .nav{display:flex;gap:.5rem;flex-wrap:wrap;}.intro-linedock a{background:var(--c-primary-bg);color:var(--c-primary-fg);text-decoration:none;border-radius:var(--radius-sm);padding:.68rem .88rem;}.intro-linedock a+a{background:var(--c-muted-bg);color:var(--c-muted-fg);}
@media (max-width:760px){.intro-linedock .linedock-bottom{display:grid;}}

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

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

    .faq .shell{max-width:920px;margin:0 auto;display:grid;gap:1rem;}

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

    .faq .list{display:grid;gap:var(--gap);padding:0;margin:0;counter-reset:faqnum;}

    .faq li{list-style:none;padding:1rem 1rem 1rem 3rem;border:1px solid var(--c-card-border);border-radius:var(--radius-md);position:relative;background:var(--c-muted-bg);color:var(--c-muted-fg);}

    .faq li::before{counter-increment:faqnum;content:counter(faqnum);position:absolute;left:1rem;top:1rem;width:1.4rem;height:1.4rem;border-radius:50%;display:grid;place-items:center;background:var(--c-primary-bg);color:var(--c-primary-fg);font-size:.78rem;font-weight:700;}

    .faq h3{margin:0 0 .45rem;}

    .faq p{margin:0;}

.plans-overview{padding:clamp(54px,7vw,96px) clamp(16px,4vw,36px);background:var(--section-gradient-bg);color:var(--section-gradient-fg);}

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

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

    .plans-overview .head h2{margin:0;font-size:clamp(30px,5vw,48px);}

    .plans-overview .head p{margin:8px 0 0;opacity:.92;}

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

    .plans-overview .card{border-radius:var(--radius-lg);border:1px solid color-mix(in srgb, currentColor 28%, transparent);background:var(--c-card-bg);padding:var(--space-y) var(--space-x);transition:transform var(--anim-duration) var(--anim-ease),border-color var(--anim-duration) var(--anim-ease);color:var(--c-card-fg);}

    .plans-overview .card.is-active{transform:translateY(-4px);border-color:var(--c-accent-bg);}

    .plans-overview .line{display:flex;justify-content:space-between;gap:8px;align-items:center;}

    .plans-overview .line h3{margin:0;}

    .plans-overview .line span{font-size:.82rem;padding:4px 8px;border-radius:999px;background:var(--chip-bg);color:var(--chip-fg);}

    .plans-overview .list p{margin:10px 0 6px;opacity:.92;}

    .plans-overview .card button{width:100%;margin-top:8px;border:0;border-radius:var(--radius-sm);padding:9px 12px;background:var(--c-accent-bg);color:var(--c-accent-fg);}

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

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

.area-product-list .header{text-align:center;margin-bottom:24px;}

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

.area-product-list .header p{margin:0;}

.area-product-list .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;}

.area-product-list .card{border-radius:var(--radius-xl);padding:var(--space-y);background:var(--c-primary-bg);color:var(--c-primary-fg);border:1px solid rgba(148,163,184,0.7);}

.area-product-list .mod-bestseller{border-color:var(--c-accent-bg);}
.area-product-list .mod-limited{border-color:var(--c-accent-bg);}
.area-product-list .mod-new{border-color:var(--c-primary-bg);}

.area-product-list .name{margin:0 0 4px;font-size:0.95rem;}

.area-product-list .note{margin:0;font-size:0.9rem;}

.stay-in-touch{padding:clamp(56px,8vw,96px) clamp(16px,3vw,36px);background:var(--section-light-bg);color:var(--section-light-fg);}

    .stay-in-touch .wrap{max-width:900px;margin:0 auto;}

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

    .stay-in-touch .lead{margin:10px 0 14px;}

    .stay-in-touch .list{display:grid;gap:8px;}

    .stay-in-touch .row{border:1px solid var(--c-card-border);border-radius:var(--radius-md);background:var(--c-card-bg);padding:10px 12px;display:flex;justify-content:space-between;gap:10px;align-items:center;color:var(--c-card-fg);}

    .stay-in-touch .title{margin:0 0 4px;font-weight:600;}

    .stay-in-touch .text{margin:0;}

    .stay-in-touch .row a{text-decoration:none;white-space:nowrap;}

    .stay-in-touch .cta{display:inline-block;margin-top:12px;text-decoration:none;padding:10px 16px;border-radius:var(--radius-md);background:var(--c-primary-bg);color:var(--c-primary-fg);}

    @media (max-width: 700px){.stay-in-touch .row{flex-direction:column;align-items:flex-start;}

        .stay-in-touch .row a{white-space:normal;}
    }

.blog-item{padding:clamp(48px,8vw,80px) 0;color:var(--section-light-fg);background:var(--section-light-bg);}

.blog-item .inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--space-x);}

.blog-item .content{max-width:800px;margin:0 auto;}

.blog-item .content h2{margin-top:2rem;margin-bottom:1rem;}

.blog-item .content p{max-width:100%;margin-bottom:1.5rem;}

.blog-item .content ul,.blog-item .content ol{margin-left:2rem;margin-bottom:1.5rem;}

.blog-item .content li{margin-bottom:0.5rem;line-height:1.6;}

.blog-item .callout{margin-top:2rem;padding:clamp(16px,3vw,24px);background-color:var(--c-muted-bg);border-radius:var(--radius-lg);border:1px solid var(--c-card-border);color:var(--c-muted-fg);}

.blog-item .callout p{margin:0;}

.blog-item .actions{margin-top:2rem;text-align:center;}

.blog-item .btn{display:inline-block;padding:12px 30px;border-radius:var(--radius-md);font-weight:500;text-align:center;transition:all var(--anim-duration) var(--anim-ease);cursor:pointer;border:1px solid var(--c-primary-bg);font-size:1rem;background-color:var(--c-primary-bg);color:var(--c-primary-fg);}

.blog-item .btn:hover{background-color:var(--c-primary-hover);border-color:var(--c-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--c-primary-fg);}

.block-checkout.light{padding:48px 20px;background:var(--section-light-bg);color:var(--section-light-fg);}

.block-checkout .inner{max-width:480px;margin:0 auto;}

.block-checkout .title{margin:0 0 6px;font-size:clamp(22px,3.5vw,28px);}

.block-checkout .text{margin:0;}

.service-desk{padding:clamp(54px,7vw,94px) clamp(16px,4vw,36px);background:var(--section-gradient-bg);color:var(--section-gradient-fg);}

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

    .service-desk .head{margin-bottom:14px;}

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

    .service-desk .head p{margin:8px 0 0;opacity:.92;}

    .service-desk .list{display:grid;gap:10px;}

    .service-desk .item{border:1px solid color-mix(in srgb, currentColor 32%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, currentColor 12%, transparent);overflow:hidden;}

    .service-desk .item button{width:100%;border:0;background:transparent;color:inherit;text-align:left;font:inherit;font-weight:700;padding:11px 12px;cursor:pointer;}

    .service-desk .item p{margin:0;max-height:0;overflow:hidden;padding:0 12px;transition:max-height var(--anim-duration) var(--anim-ease),padding var(--anim-duration) var(--anim-ease);opacity:.95;}

    .service-desk .item.is-open p{max-height:220px;padding:0 12px 12px;}

.form {padding:calc(var(--space-y) * 2.9) var(--space-x);background:var(--section-gradient-bg);color:var(--section-gradient-fg);}

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

.form h2 {margin:0;font-size:clamp(1.85rem, 3.6vw, 2.8rem);line-height:1.1;}

.form .sub {margin:.35rem 0 0;opacity:.9;}

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

.form form {display:grid;gap:.75rem;}

.form .field {display:grid;gap:.28rem;}

.form .field span {font-size:.82rem;font-weight:700;}

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

.form input:focus, .form textarea:focus {border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb, var(--ring) 22%, transparent);}

.form textarea {min-height:120px;resize:vertical;}

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

.form button:hover {transform:translateY(-1px);background:var(--c-primary-hover);color:var(--c-primary-fg);}

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

.form .grid {display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:.65rem;}

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

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

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

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

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

.form .agree {display:flex;align-items:center;gap:.45rem;font-size:.86rem;}

.form .media {display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);}

.form .media img, .form .frame img {width:100%;height:100%;min-height:320px;object-fit:cover;border-radius:var(--radius-xl);}

.form .frame {display:grid;grid-template-columns:1.1fr .9fr;gap:var(--gap);}

.form .full {grid-column:1/-1;}

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

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

.contacts-calmgrid{padding:calc(var(--space-y)*2.6) var(--space-x);background:var(--c-muted-bg);color:var(--c-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(--c-card-border);background:var(--c-card-bg);color:var(--c-card-fg);}
.contacts-calmgrid .article{min-height:9.2rem;padding:1rem;border-right:1px solid var(--c-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(--c-card-bg);border:1px solid var(--c-card-border);color:var(--c-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(--c-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(--c-card-border);}}

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

.policy-softindex{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--c-page-bg);color:var(--c-page-fg);}
.policy-softindex .softindex-shell{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.7fr 1.3fr;gap:var(--gap);}.policy-softindex .aside{background:var(--c-card-bg);border:1px solid var(--c-card-border);border-radius:var(--radius-xl);padding:1.15rem;align-self:start;color:var(--c-card-fg);}.policy-softindex h2{margin:0;font-size:clamp(1.9rem,3.5vw,2.85rem);line-height:1.06;}.policy-softindex .aside p{margin:.75rem 0 0;color:var(--neutral-600);}.policy-softindex .softindex-list{display:grid;gap:.55rem;}.policy-softindex .article{display:block;background:var(--c-card-bg);border:1px solid var(--c-card-border);border-radius:var(--radius-md);padding:.8rem;color:var(--c-card-fg);}.policy-softindex h3{margin:0 0 .25rem;font-size:1rem;}.policy-softindex .article p{margin:0;color:var(--neutral-600);}
@media (max-width:820px){.policy-softindex .softindex-shell{grid-template-columns:1fr;}}

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

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

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

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

    .rules .section-head p{margin:10px auto 0;max-width:72ch;}

    .rules .columns{columns:2 260px;column-gap:14px;}

    .rules article{break-inside:avoid;margin-bottom:12px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb, currentColor 22%, transparent);padding:12px;background:color-mix(in srgb, currentColor 5%, transparent);}

    .rules h3{margin:0;}

    .rules .meta{margin:7px 0 0;}

    .rules article p:last-child{margin:7px 0 0;}

.thank{padding:calc(var(--space-y)*3) var(--space-x);background:var(--c-muted-bg);color:var(--c-muted-fg);}
.thank .wrap{max-width:900px;margin:0 auto;display:grid;gap:.72rem;}
.thank .hero{padding:1rem;border-radius:var(--radius-xl);border:1px solid var(--c-card-border);background:var(--c-card-bg);text-align:center;color:var(--c-card-fg);}
.thank h2{margin:0;font-size:clamp(1.75rem,3.2vw,2.45rem);}
.thank .hero p{margin:.4rem 0 0;}
.thank ul{margin:0;padding:0;list-style:none;display:grid;gap:.45rem;}
.thank li{padding:.72rem .82rem;border-radius:var(--radius-md);background:var(--c-card-bg);border-inline-start:4px solid var(--c-primary-bg);color:var(--c-card-fg);}
.thank .line{margin:0;padding:.75rem;border-radius:var(--radius-md);background:var(--c-card-bg);border:1px dashed var(--c-card-border);color:var(--c-card-fg);}

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

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

    .not-found .chip::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--section-gradient-bg);color:var(--section-gradient-fg);}

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

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

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