@layer reset, tokens, layout, components, utilities;

@layer reset {
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
  body { min-height: 100vh; }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  button { font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
  ul, ol { list-style: none; }
  input, textarea { font: inherit; color: inherit; }
  h1, h2, h3, h4 { font-family: var(--font-heading); font-weight: 600; line-height: 1.15; }
}

@layer tokens {
  :root {
    --font-heading: 'Space Grotesk', sans-serif;
    --font-body: 'Inter', sans-serif;

    --color-bg: #F8F7F3;
    --color-bg-alt: #F0EFE9;
    --color-surface: #FFFDF9;
    --color-ink: #171B1D;
    --color-ink-soft: #4E585F;
    --color-ink-faint: #8C959B;
    --color-primary: #145C6E;
    --color-primary-dark: #0C3E4B;
    --color-primary-light: #E3F0F1;
    --color-accent: #E2602E;
    --color-accent-light: #FCEAE0;
    --color-good: #2E9E6C;
    --color-good-light: #E4F5EC;
    --color-warn: #D9A441;
    --color-warn-light: #FBF1DE;
    --color-poor: #C24C42;
    --color-poor-light: #FAE7E4;
    --color-line: rgba(23,27,29,0.14);
    --color-line-strong: rgba(23,27,29,0.3);

    --radius-sm: 8px;
    --radius-md: 14px;
    --radius-lg: 22px;
    --radius-xl: 32px;
    --radius-full: 999px;

    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --space-7: 3rem;
    --space-8: 4.5rem;
    --space-9: 6.5rem;

    --shadow-sm: 0 1px 2px rgba(23,27,29,0.06), 0 1px 1px rgba(23,27,29,0.05);
    --shadow-md: 0 8px 20px rgba(23,27,29,0.08), 0 2px 6px rgba(23,27,29,0.06);
    --shadow-lg: 0 24px 48px rgba(23,27,29,0.14), 0 10px 20px rgba(23,27,29,0.08);
    --shadow-glow: 0 0 0 1px rgba(20,92,110,0.16), 0 16px 34px rgba(20,92,110,0.16);

    --ease: cubic-bezier(.4,0,.2,1);
    --transition: .3s var(--ease);
    --transition-slow: .55s var(--ease);
  }
}

@layer layout {
  body { font-family: var(--font-body); background: var(--color-bg); color: var(--color-ink); line-height: 1.6; overflow-x: hidden; }
  .u-container { width: 100%; max-width: 1240px; margin-inline: auto; padding-inline: var(--space-5); }
  main { display: block; }
  .u-section { padding-block: var(--space-9); }
  .u-section--alt { background: var(--color-bg-alt); }
  h1 { font-size: clamp(2.2rem, 4.5vw + 1rem, 3.6rem); letter-spacing: -0.02em; }
  h2 { font-size: clamp(1.7rem, 2.6vw + 0.8rem, 2.5rem); letter-spacing: -0.015em; }
  h3 { font-size: clamp(1.1rem, 1vw + 0.7rem, 1.35rem); }
  p { color: var(--color-ink-soft); }
}

@layer components {

  
  .mod-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 500;
    padding-block: var(--space-4);
    transition: background var(--transition), box-shadow var(--transition), padding var(--transition), backdrop-filter var(--transition);
    background: linear-gradient(to bottom, rgba(12,62,75,0.55), transparent);
  }
  .mod-header--solid {
    background: rgba(248,247,243,0.86);
    backdrop-filter: blur(14px);
    box-shadow: var(--shadow-md);
    padding-block: var(--space-3);
  }
  .mod-header-inner { display: flex; align-items: center; justify-content: center; position: relative; }
  .mod-header-logo { display: flex; align-items: center; gap: var(--space-2); font-family: var(--font-heading); font-weight: 700; font-size: 1.05rem; color: #fff; transition: color var(--transition); }
  .mod-header--solid .mod-header-logo { color: var(--color-ink); }
  .mod-header-nav { position: absolute; left: 50%; transform: translateX(-50%); display: flex; gap: var(--space-6); }
  .mod-header-nav a { font-size: 0.92rem; font-weight: 500; color: rgba(255,255,255,0.88); position: relative; padding-block: var(--space-1); transition: color var(--transition); }
  .mod-header-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -2px; height: 2px; background: var(--color-accent); transition: right var(--transition); }
  .mod-header-nav a:hover, .mod-header-nav a.is-active { color: #fff; }
  .mod-header-nav a:hover::after, .mod-header-nav a.is-active::after { right: 0; }
  .mod-header--solid .mod-header-nav a { color: var(--color-ink-soft); }
  .mod-header--solid .mod-header-nav a:hover, .mod-header--solid .mod-header-nav a.is-active { color: var(--color-primary); }
  .mod-header-logo { margin-inline-end: auto; }
  .mod-header-burger { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; align-items: center; justify-content: center; z-index: 600; }
  .mod-header-burger span { width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: all var(--transition); }
  .mod-header--solid .mod-header-burger span { background: var(--color-ink); }

  
  .mod-mobile-menu {
    position: fixed; inset: 0; z-index: 900;
    background: linear-gradient(160deg, var(--color-primary-dark), var(--color-primary) 65%, #0A2E38);
    display: flex; flex-direction: column;
    padding: var(--space-6) var(--space-5);
    opacity: 0; visibility: hidden; transform: translateY(-12px);
    transition: opacity var(--transition-slow), visibility var(--transition-slow), transform var(--transition-slow);
  }
  .mod-mobile-menu.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
  .mod-mobile-menu-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-8); }
  .mod-mobile-menu-logo { display: flex; align-items: center; gap: var(--space-2); color: #fff; font-family: var(--font-heading); font-weight: 700; }
  .mod-mobile-menu-close { width: 44px; height: 44px; border: 1px solid rgba(255,255,255,0.3); border-radius: var(--radius-full); color: #fff; display: flex; align-items: center; justify-content: center; transition: background var(--transition), transform var(--transition); }
  .mod-mobile-menu-close:hover { background: rgba(255,255,255,0.14); transform: rotate(90deg); }
  .mod-mobile-menu-grid { flex: 1; display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); align-content: center; }
  .mod-mobile-menu-item {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-3);
    border: 1px solid rgba(255,255,255,0.22); border-radius: var(--radius-lg);
    padding: var(--space-6) var(--space-3); color: #fff; text-align: center; min-height: 130px;
    transition: background var(--transition), border-color var(--transition), transform var(--transition);
  }
  .mod-mobile-menu-item i { font-size: 1.5rem; transition: transform var(--transition); }
  .mod-mobile-menu-item span { font-size: 0.88rem; font-weight: 500; }
  .mod-mobile-menu-item:hover { background: rgba(255,255,255,0.12); border-color: #fff; transform: translateY(-4px); }
  .mod-mobile-menu-item:hover i { transform: scale(1.15) rotate(-6deg); }
  body.mod-no-scroll { overflow: hidden; }

  
  .mod-btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2); padding: 0.85em 1.6em; border-radius: var(--radius-full); font-weight: 600; font-size: 0.94rem; border: 1.5px solid transparent; transition: background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition); white-space: nowrap; min-height: 44px; }
  .mod-btn i { transition: transform var(--transition); }
  .mod-btn--primary { background: var(--color-primary); color: #fff; border-color: var(--color-primary); box-shadow: var(--shadow-sm); }
  .mod-btn--primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); box-shadow: var(--shadow-glow); transform: translateY(-2px); }
  .mod-btn--primary:hover i { transform: translateX(3px); }
  .mod-btn--outline { background: transparent; color: var(--color-ink); border-color: var(--color-line-strong); }
  .mod-btn--outline:hover { background: var(--color-ink); color: #fff; border-color: var(--color-ink); transform: translateY(-2px); box-shadow: var(--shadow-md); }
  .mod-btn--ghost { background: rgba(0,0,0,0.15); color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.4); }
  .mod-btn--ghost:hover { background: rgba(0,0,0,0.15); color: #fff; }
  .mod-btn--sm { padding: 0.6em 1.1em; font-size: 0.82rem; min-height: 38px; }
  .mod-btn--block { width: 100%; }
  [data-aos^=fade][data-aos^=fade], [data-aos^=flip][data-aos^=flip], [data-aos=flip-up], [data-aos^=zoom][data-aos^=zoom] {
    opacity: 1 !important;
    backface-visibility: visible !important;
    transition-property: transform;
  }
  [data-aos=flip-up] {
    transform: perspective(200px) rotateX(0) !important;
  }
  .mod-hero { position: relative; padding-block: calc(var(--space-9) + 2rem) var(--space-8); background: linear-gradient(180deg, #0C3E4B 0%, #145C6E 55%, var(--color-bg) 100%); color: #fff; overflow: hidden; }
  .mod-eyebrow { display: inline-block; font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-accent); margin-bottom: var(--space-3); }
  .mod-hero-heading-wrap { max-width: 780px; margin-inline: auto; text-align: center; margin-bottom: var(--space-8); }
  .mod-hero-title { color: #fff; margin-bottom: var(--space-4); }
  .mod-hero-subtitle { color: rgba(255,255,255,0.82); font-size: 1.08rem; max-width: 620px; margin-inline: auto; }
  .mod-hero-grid { display: grid; grid-template-columns: 1.65fr 1fr; gap: var(--space-6); align-items: stretch; }
  .mod-hero-compare { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
  .mod-hero-panel { position: relative; border: 1px solid rgba(255,255,255,0.25); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; background: rgba(255,255,255,0.04); transition: border-color var(--transition), transform var(--transition); }
  .mod-hero-panel:hover { border-color: rgba(255,255,255,0.55); transform: translateY(-4px); }
  .mod-hero-panel img { height: 220px; object-fit: cover; filter: saturate(0.9); }
  .mod-hero-panel p { padding: var(--space-4); color: rgba(255,255,255,0.85); font-size: 0.9rem; }
  .mod-hero-panel-tag { position: absolute; top: var(--space-3); left: var(--space-3); padding: 0.35em 0.9em; border-radius: var(--radius-full); font-size: 0.78rem; font-weight: 600; display: flex; align-items: center; gap: 6px; backdrop-filter: blur(6px); }
  .mod-hero-panel-tag--before { background: rgba(194,76,66,0.85); color: #fff; }
  .mod-hero-panel-tag--after { background: rgba(46,158,108,0.9); color: #fff; }
  .mod-hero-content { display: flex; flex-direction: column; justify-content: center; gap: var(--space-5); border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius-lg); padding: var(--space-6); background: rgba(255,255,255,0.05); }
  .mod-hero-content p { color: rgba(255,255,255,0.85); }
  .mod-hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-3); }
  .mod-hero-badges { display: flex; flex-wrap: wrap; gap: var(--space-2); }
  .mod-badge { display: inline-flex; align-items: center; gap: 6px; border: 1px solid rgba(255,255,255,0.3); border-radius: var(--radius-full); padding: 0.4em 0.9em; font-size: 0.8rem; color: rgba(255,255,255,0.85); transition: background var(--transition), border-color var(--transition); }
  .mod-badge:hover { background: rgba(255,255,255,0.14); border-color: #fff; }

  
  .mod-page-hero { background: linear-gradient(180deg, #0C3E4B 0%, #145C6E 100%); color: #fff; padding-block: calc(var(--space-9) + 2rem) var(--space-8); text-align: center; }
  .mod-page-hero h1 { color: #fff; margin-bottom: var(--space-3); }
  .mod-page-hero p { color: rgba(255,255,255,0.82); max-width: 560px; margin-inline: auto; }
  .mod-page-hero--legal { padding-block: calc(var(--space-8) + 2rem) var(--space-7); }

  
  .mod-section-head { max-width: 700px; margin: 0 auto var(--space-7); text-align: center; }
  .mod-section-head p { margin-top: var(--space-3); }

  
  .mod-benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; gap: var(--space-5); }
  .mod-benefit-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); display: flex; flex-direction: column; gap: var(--space-3); }
  .mod-benefit-card--featured { grid-row: span 2; grid-column: span 1; background: var(--color-primary-light); }
  .mod-benefit-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-5px); }
  .mod-benefit-icon { width: 56px; height: 56px; border-radius: var(--radius-md); border: 1.5px solid var(--color-line-strong); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; color: var(--color-primary); transition: background var(--transition), color var(--transition), transform var(--transition); }
  .mod-benefit-card:hover .mod-benefit-icon { background: var(--color-primary); color: #fff; transform: rotate(-8deg) scale(1.05); }
  .mod-benefit-link { font-size: 0.86rem; font-weight: 600; color: var(--color-primary); margin-top: auto; display: inline-flex; align-items: center; gap: 6px; }
  .mod-benefit-link i { transition: transform var(--transition); }
  .mod-benefit-card:hover .mod-benefit-link i { transform: translateY(3px); }

  
  .mod-vitals-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-bottom: var(--space-7); }
  .mod-vital-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-surface); text-align: center; transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
  .mod-vital-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-5px); }
  .mod-vital-code { font-family: var(--font-heading); font-size: 2.4rem; font-weight: 700; color: var(--color-primary); margin-bottom: var(--space-2); }
  .mod-vital-card h3 { margin-bottom: var(--space-2); }
  .mod-vital-card p { margin-bottom: var(--space-4); }
  .mod-vital-scale { display: flex; flex-direction: column; gap: var(--space-2); }
  .mod-vital-scale-seg { border-radius: var(--radius-sm); padding: 0.5em 0.8em; font-size: 0.8rem; font-weight: 600; border: 1px solid; }
  .mod-vital-scale-seg--good { color: var(--color-good); border-color: var(--color-good); background: var(--color-good-light); }
  .mod-vital-scale-seg--warn { color: var(--color-warn); border-color: var(--color-warn); background: var(--color-warn-light); }
  .mod-vital-scale-seg--poor { color: var(--color-poor); border-color: var(--color-poor); background: var(--color-poor-light); }
  .mod-vitals-image img { border-radius: var(--radius-lg); border: 1.5px solid var(--color-line); width: 100%; height: 340px; object-fit: cover; }

  
  .mod-tools-layout { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-7); align-items: center; }
  .mod-tools-content h2 { margin: var(--space-2) 0 var(--space-4); }
  .mod-tools-steps { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-5); }
  .mod-tools-step { display: flex; gap: var(--space-4); align-items: flex-start; border: 1.5px solid var(--color-line); border-radius: var(--radius-md); padding: var(--space-4); transition: border-color var(--transition), background var(--transition), transform var(--transition); }
  .mod-tools-step:hover { border-color: var(--color-primary); background: var(--color-primary-light); transform: translateX(4px); }
  .mod-tools-step-num { flex-shrink: 0; width: 36px; height: 36px; border-radius: var(--radius-full); border: 1.5px solid var(--color-primary); color: var(--color-primary); display: flex; align-items: center; justify-content: center; font-weight: 700; font-family: var(--font-heading); transition: background var(--transition), color var(--transition); }
  .mod-tools-step:hover .mod-tools-step-num { background: var(--color-primary); color: #fff; }
  .mod-tools-step h3 { margin-bottom: 4px; }
  .mod-tools-media img { border-radius: var(--radius-lg); border: 1.5px solid var(--color-line); width: 100%; height: 420px; object-fit: cover; }

  
  .mod-image-section { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--space-7); align-items: center; }
  .mod-image-section-media img { border-radius: var(--radius-lg); border: 1.5px solid var(--color-line); width: 100%; height: 460px; object-fit: cover; }
  .mod-image-section-content h2 { margin: var(--space-2) 0 var(--space-4); }
  .mod-image-section-content p { margin-bottom: var(--space-4); }

  
  .mod-plugins-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: var(--space-5); }
  .mod-plugin-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-5); background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
  .mod-plugin-card:hover { border-color: var(--color-accent); box-shadow: var(--shadow-md); transform: translateY(-4px); }
  .mod-plugin-icon { width: 46px; height: 46px; border-radius: var(--radius-md); border: 1.5px solid var(--color-line-strong); display: flex; align-items: center; justify-content: center; color: var(--color-accent); margin-bottom: var(--space-3); transition: background var(--transition), color var(--transition), transform var(--transition); }
  .mod-plugin-card:hover .mod-plugin-icon { background: var(--color-accent); color: #fff; transform: rotate(10deg); }
  .mod-plugin-card h3 { margin-bottom: var(--space-2); font-size: 1.05rem; }

  
  .mod-platforms-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-bottom: var(--space-6); }
  .mod-platform-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); text-align: center; background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
  .mod-platform-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-4px); }
  .mod-platform-card i { font-size: 2.2rem; color: var(--color-primary); margin-bottom: var(--space-3); display: inline-block; transition: transform var(--transition); }
  .mod-platform-card:hover i { transform: scale(1.15); }
  .mod-platform-card h3 { margin-bottom: var(--space-2); }
  .mod-platforms-image img { border-radius: var(--radius-lg); border: 1.5px solid var(--color-line); width: 100%; height: 320px; object-fit: cover; }

  
  .mod-guides-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-5); margin-bottom: var(--space-7); }
  .mod-guide-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-5); background: var(--color-surface); transition: border-color var(--transition), background var(--transition), transform var(--transition), box-shadow var(--transition); }
  .mod-guide-card:hover { border-color: var(--color-primary); background: var(--color-primary-light); box-shadow: var(--shadow-md); transform: translateY(-4px); }
  .mod-guide-icon { width: 44px; height: 44px; border-radius: var(--radius-md); border: 1.5px solid var(--color-line-strong); display: flex; align-items: center; justify-content: center; color: var(--color-primary); margin-bottom: var(--space-3); transition: transform var(--transition); }
  .mod-guide-card:hover .mod-guide-icon { transform: rotate(-8deg) scale(1.08); }
  .mod-guide-card h3 { font-size: 1rem; margin-bottom: var(--space-1); }
  .mod-guide-card p { font-size: 0.88rem; }
  .mod-guides-image img { border-radius: var(--radius-lg); border: 1.5px solid var(--color-line); width: 100%; height: 300px; object-fit: cover; }

  
  .mod-faq-list { display: flex; flex-direction: column; gap: var(--space-4); max-width: 800px; margin-inline: auto; }
  .mod-faq-item { border: 1.5px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); overflow: hidden; transition: border-color var(--transition); }
  .mod-faq-item:hover { border-color: var(--color-primary); }
  .mod-faq-item-question { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); padding: var(--space-5); text-align: left; font-family: var(--font-heading); font-weight: 600; font-size: 1rem; }
  .mod-faq-item-question i { flex-shrink: 0; transition: transform var(--transition); color: var(--color-primary); }
  .mod-faq-item.is-open .mod-faq-item-question i { transform: rotate(45deg); }
  .mod-faq-item-answer { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--transition-slow); }
  .mod-faq-item.is-open .mod-faq-item-answer { grid-template-rows: 1fr; }
  .mod-faq-item-answer-inner { overflow: hidden; }
  .mod-faq-item-answer-inner p { padding: 0 var(--space-5) var(--space-5); }

  
  .mod-cta-banner-inner { border: 1.5px solid var(--color-line-strong); border-radius: var(--radius-xl); padding: var(--space-7); display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); flex-wrap: wrap; background: var(--color-surface); }
  .mod-cta-banner-inner h2 { margin-bottom: var(--space-2); }

  
  .mod-footer { background: #0C1618; color: rgba(255,255,255,0.75); padding-block: var(--space-8) var(--space-5); margin-top: auto; }
  .mod-footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: var(--space-6); padding-bottom: var(--space-6); }
  .mod-footer .mod-header-logo { color: #fff; margin-bottom: var(--space-3); }
  .mod-footer-brand p { color: rgba(255,255,255,0.6); font-size: 0.9rem; }
  .mod-footer-col h4 { color: #fff; font-size: 0.92rem; margin-bottom: var(--space-3); }
  .mod-footer-col a, .mod-footer-col p { display: block; font-size: 0.9rem; color: rgba(255,255,255,0.65); margin-bottom: var(--space-2); transition: color var(--transition); }
  .mod-footer-col a:hover { color: var(--color-accent); }
  .mod-footer-col i { margin-right: 6px; color: var(--color-accent); }
  .mod-footer-bottom { border-top: 1px solid rgba(255,255,255,0.12); padding-top: var(--space-5); font-size: 0.82rem; color: rgba(255,255,255,0.5); }

  html, body { height: 100%; }
  body { display: flex; flex-direction: column; }
  main { flex: 1 0 auto; }
  .mod-footer { flex-shrink: 0; }

  
  .mod-about-intro { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-7); align-items: center; }
  .mod-about-intro h2 { margin-bottom: var(--space-4); }
  .mod-about-intro p { margin-bottom: var(--space-3); }
  .mod-about-image img { border-radius: var(--radius-lg); border: 1.5px solid var(--color-line); width: 100%; height: 420px; object-fit: cover; }
  .mod-team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); margin-bottom: var(--space-7); }
  .mod-team-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); overflow: hidden; background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
  .mod-team-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-4px); }
  .mod-team-card img { height: 280px; object-fit: cover; }
  .mod-team-card h3, .mod-team-card p { padding-inline: var(--space-5); }
  .mod-team-card h3 { margin-top: var(--space-4); }
  .mod-team-card p { padding-bottom: var(--space-5); margin-top: var(--space-2); }
  .mod-about-values { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
  .mod-about-value { border: 1.5px solid var(--color-line); border-radius: var(--radius-md); padding: var(--space-5); text-align: center; transition: border-color var(--transition), transform var(--transition); }
  .mod-about-value:hover { border-color: var(--color-primary); transform: translateY(-4px); }
  .mod-about-value i { font-size: 1.5rem; color: var(--color-primary); margin-bottom: var(--space-3); display: inline-block; transition: transform var(--transition); }
  .mod-about-value:hover i { transform: scale(1.2) rotate(-6deg); }
  .mod-about-value h4 { margin-bottom: var(--space-2); font-size: 0.98rem; }
  .mod-about-value p { font-size: 0.86rem; }

  
  .mod-topics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-5); }
  .mod-topic-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); display: flex; flex-direction: column; gap: var(--space-3); }
  .mod-topic-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-5px); }
  .mod-topic-icon { width: 50px; height: 50px; border-radius: var(--radius-md); border: 1.5px solid var(--color-line-strong); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: var(--color-primary); transition: background var(--transition), color var(--transition), transform var(--transition); }
  .mod-topic-card:hover .mod-topic-icon { background: var(--color-primary); color: #fff; transform: rotate(-8deg); }
  .mod-topic-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: auto; }
  .mod-topic-tags span { border: 1px solid var(--color-line-strong); border-radius: var(--radius-full); padding: 0.2em 0.7em; font-size: 0.74rem; color: var(--color-ink-soft); }
  .mod-topic-detail { max-width: 780px; margin-inline: auto; }
  .mod-topic-detail h2 { margin: var(--space-2) 0 var(--space-4); }
  .mod-topic-detail p { margin-bottom: var(--space-3); }
  .mod-topic-detail.mod-image-section { max-width: 1100px; }

  
  .mod-popular-featured { display: grid; grid-template-columns: 1fr 1fr; border: 1.5px solid var(--color-line-strong); border-radius: var(--radius-xl); overflow: hidden; margin-bottom: var(--space-6); background: var(--color-surface); transition: box-shadow var(--transition); }
  .mod-popular-featured:hover { box-shadow: var(--shadow-lg); }
  .mod-popular-featured-media img { height: 100%; min-height: 320px; object-fit: cover; }
  .mod-popular-featured-content { padding: var(--space-7); display: flex; flex-direction: column; justify-content: center; gap: var(--space-3); }
  .mod-tag { display: inline-block; align-self: flex-start; border: 1px solid var(--color-accent); color: var(--color-accent); border-radius: var(--radius-full); padding: 0.3em 0.9em; font-size: 0.76rem; font-weight: 600; }
  .mod-popular-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
  .mod-popular-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); display: flex; flex-direction: column; gap: var(--space-2); }
  .mod-popular-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-4px); }
  .mod-popular-card-link { margin-top: auto; font-weight: 600; font-size: 0.88rem; color: var(--color-primary); display: inline-flex; align-items: center; gap: 6px; }
  .mod-popular-card-link i { transition: transform var(--transition); }
  .mod-popular-card:hover .mod-popular-card-link i { transform: translateX(3px); }

  .mod-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
  .mod-gallery-item { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: 1.5px solid var(--color-line); display: block; }
  .mod-gallery-item img { height: 230px; object-fit: cover; transition: transform var(--transition-slow); }
  .mod-gallery-item-overlay { position: absolute; inset: 0; background: rgba(12,62,75,0.55); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.4rem; opacity: 0; transition: opacity var(--transition); }
  .mod-gallery-item:hover img { transform: scale(1.08); }
  .mod-gallery-item:hover .mod-gallery-item-overlay { opacity: 1; }

  
  .mod-contact-grid { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: var(--space-7); }
  .mod-contact-form-wrap h2 { margin-bottom: var(--space-5); }
  .mod-contact-form { display: flex; flex-direction: column; gap: var(--space-4); }
  .mod-form-group { display: flex; flex-direction: column; gap: var(--space-2); }
  .mod-form-group label { font-size: 0.88rem; font-weight: 600; }
  .mod-form-group input:not([type=checkbox]), .mod-form-group textarea { border: 1.5px solid var(--color-line-strong); border-radius: var(--radius-md); padding: 0.85em 1em; background: var(--color-surface); transition: border-color var(--transition), box-shadow var(--transition); min-height: 44px; }
  .mod-form-group textarea { min-height: 130px; resize: vertical; }
  .mod-form-group input:focus, .mod-form-group textarea:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(20,92,110,0.14); }
  .mod-form-group--checkbox { flex-direction: row; align-items: flex-start; gap: var(--space-3); }
  .mod-form-group--checkbox input { width: 20px; height: 20px; margin-top: 3px; accent-color: var(--color-primary); flex-shrink: 0; }
  .mod-form-group--checkbox label { font-weight: 400; font-size: 0.86rem; color: var(--color-ink-soft); }
  .mod-form-group--checkbox a { color: var(--color-primary); font-weight: 600; }
  .mod-form-note { font-size: 0.85rem; color: var(--color-poor); min-height: 1.2em; }
  .mod-contact-info { display: flex; flex-direction: column; gap: var(--space-4); }
  .mod-contact-info-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-md); padding: var(--space-4); display: flex; gap: var(--space-4); align-items: flex-start; transition: border-color var(--transition), transform var(--transition); }
  .mod-contact-info-card:hover { border-color: var(--color-primary); transform: translateX(4px); }
  .mod-contact-info-card i { font-size: 1.2rem; color: var(--color-primary); margin-top: 3px; }
  .mod-contact-info-card h4 { margin-bottom: 3px; font-size: 0.92rem; }
  .mod-contact-info-card p, .mod-contact-info-card a { font-size: 0.9rem; }
  .mod-contact-info-card a:hover { color: var(--color-primary); }
  .mod-map { border-radius: var(--radius-md); overflow: hidden; border: 1.5px solid var(--color-line); }
  .mod-contact-image { border-radius: var(--radius-md); border: 1.5px solid var(--color-line); width: 100%; height: 180px; object-fit: cover; }

  
  .mod-thanks-inner { text-align: center; max-width: 600px; margin-inline: auto; display: flex; flex-direction: column; align-items: center; gap: var(--space-4); }
  .mod-thanks-icon { width: 80px; height: 80px; border-radius: var(--radius-full); border: 2px solid var(--color-good); color: var(--color-good); display: flex; align-items: center; justify-content: center; font-size: 2.2rem; margin-bottom: var(--space-2); }
  .mod-thanks-timeline { width: 100%; margin-top: var(--space-8); display: flex; flex-direction: column; gap: var(--space-5); text-align: left; }
  .mod-timeline-item { display: flex; gap: var(--space-4); align-items: flex-start; }
  .mod-timeline-dot { width: 40px; height: 40px; border-radius: var(--radius-full); border: 2px solid var(--color-line-strong); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--color-ink-faint); }
  .mod-timeline-item--done .mod-timeline-dot, .mod-timeline-item--current .mod-timeline-dot { border-color: var(--color-good); color: var(--color-good); background: var(--color-good-light); }
  .mod-timeline-item--current h4 { color: var(--color-good); }
  .mod-timeline-item--upcoming { opacity: 0.55; }
  .mod-timeline-item h4 { margin-bottom: 2px; }

  
  .mod-legal { display: flex; flex-direction: column; gap: var(--space-5); }
  .mod-legal-card { border: 1.5px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-surface); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition), border-color var(--transition); }
  .mod-legal-card:hover { box-shadow: var(--shadow-md); border-color: var(--color-line-strong); }
  .mod-legal-card h2 { margin-bottom: var(--space-3); color: var(--color-primary-dark); }
  .mod-legal-card p { margin-bottom: 0; }
  .mod-legal-card a { color: var(--color-primary); font-weight: 600; }

  
  .mod-cookie-consent {
    position: fixed; bottom: var(--space-5); right: var(--space-5); z-index: 800;
    width: min(340px, calc(100vw - 2.5rem));
    background: var(--color-surface); border: 1.5px solid var(--color-line-strong); border-radius: var(--radius-lg);
    padding: var(--space-5); box-shadow: var(--shadow-lg);
    transform: translateY(120%); opacity: 0; transition: transform var(--transition-slow), opacity var(--transition-slow);
  }
  .mod-cookie-consent.is-visible { transform: translateY(0); opacity: 1; }
  .mod-cookie-consent-icon { width: 46px; height: 46px; border-radius: var(--radius-md); border: 1.5px solid var(--color-line-strong); display: flex; align-items: center; justify-content: center; color: var(--color-accent); font-size: 1.2rem; margin-bottom: var(--space-3); }
  .mod-cookie-consent h4 { margin-bottom: var(--space-2); }
  .mod-cookie-consent p { font-size: 0.85rem; margin-bottom: var(--space-4); }
  .mod-cookie-consent-toggles { display: none; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
  .mod-cookie-consent.is-customizing .mod-cookie-consent-toggles { display: flex; }
  .mod-cookie-toggle { display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; border: 1px solid var(--color-line); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); }
  .mod-cookie-toggle input { width: 18px; height: 18px; accent-color: var(--color-primary); }
  .mod-cookie-consent-actions { display: flex; flex-direction: column; gap: var(--space-2); }
  .mod-cookie-save { display: none; }
  .mod-cookie-consent.is-customizing .mod-cookie-save { display: inline-flex; }
  .mod-cookie-consent.is-customizing #modCookieAccept, .mod-cookie-consent.is-customizing #modCookieReject { display: none; }

}

@layer utilities {
  .u-text-center { text-align: center; }
  .u-visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
}


@media (max-width: 1024px) {
  .mod-hero-grid { grid-template-columns: 1fr; }
  .mod-hero-compare { grid-template-columns: 1fr 1fr; }
  .mod-benefits-grid { grid-template-columns: repeat(2, 1fr); }
  .mod-benefit-card--featured { grid-row: span 1; }
  .mod-vitals-grid { grid-template-columns: 1fr; }
  .mod-tools-layout, .mod-image-section, .mod-about-intro, .mod-contact-grid { grid-template-columns: 1fr; }
  .mod-platforms-grid { grid-template-columns: 1fr; }
  .mod-team-grid { grid-template-columns: 1fr; }
  .mod-about-values { grid-template-columns: repeat(2, 1fr); }
  .mod-popular-featured { grid-template-columns: 1fr; }
  .mod-popular-grid { grid-template-columns: 1fr; }
  .mod-gallery { grid-template-columns: repeat(2, 1fr); }
  .mod-footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .mod-header-nav { display: none; }
  .mod-header-burger { display: flex; }
  .mod-hero-compare { grid-template-columns: 1fr; }
  .mod-benefits-grid { grid-template-columns: 1fr; }
  .mod-plugins-grid { grid-template-columns: 1fr 1fr; }
  .mod-about-values { grid-template-columns: 1fr 1fr; }
  .mod-gallery { grid-template-columns: 1fr; }
  .mod-footer-grid { grid-template-columns: 1fr; gap: var(--space-5); }
  .mod-cta-banner-inner { flex-direction: column; text-align: center; }
  .mod-mobile-menu-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .u-container { padding-inline: var(--space-4); }
  .mod-plugins-grid { grid-template-columns: 1fr; }
  .mod-about-values { grid-template-columns: 1fr; }
  .mod-cookie-consent { right: var(--space-3); bottom: var(--space-3); width: calc(100vw - 1.5rem); }
}