

    :root{
      --forest: #124734;
      --forest-2:#0f3b2c;
      --olive:  #6b7a3a;
      --olive-2:#55632f;
      --beige:  #efe6d6;
      --ivory:  #fbf8f1;
      --ink:    #14211b;
      --muted:  #5a6a62;

      --card: #ffffffcc;
      --stroke: rgba(18,71,52,.14);
      --shadow: 0 18px 45px rgba(18,71,52,.12);
      --shadow2: 0 12px 30px rgba(0,0,0,.10);

      --radius: 18px;
      --radius-sm: 14px;

      --hfont: "Libre Baskerville", serif;
      --bfont: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

      --container: 1180px;
      --header-h: 76px;
    }

    
    html{ scroll-behavior:smooth; }
    body{
      margin:0;
      font-family: var(--bfont);
      color: var(--ink);
      background:
        radial-gradient(1200px 700px at 15% -10%, rgba(107,122,58,.22), transparent 55%),
        radial-gradient(900px 600px at 105% 10%, rgba(18,71,52,.20), transparent 60%),
        linear-gradient(180deg, var(--ivory), #fff 35%, var(--ivory));
      line-height:1.6;
      overflow-x:hidden;
    }

 
    :focus-visible{ outline: 3px solid rgba(107,122,58,.45); outline-offset: 3px; border-radius: 10px; }
    .sr-only{
      position:absolute!important;
      height:1px;width:1px;
      overflow:hidden;clip:rect(1px,1px,1px,1px);
      white-space:nowrap;
    }


    .container{
      width: min(var(--container), calc(100% - 40px));
      margin: 0 auto;
    }
    .section{
      padding: 84px 0;
      position: relative;
    }
    .section-title{
      display:flex;
      flex-direction:column;
      gap:10px;
      margin-bottom: 34px;
    }
    .kicker{
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--olive-2);
      font-size: 12px;
    }
    h1,h2,h3,h4{ font-family: var(--hfont); line-height:1.2; margin:0; }
    h2{ font-size: clamp(26px, 3vw, 40px); }
    p{ margin:0; color: var(--muted); }

 
    .btn{
      appearance:none; border:0; cursor:pointer;
      display:inline-flex; align-items:center; gap:10px;
      padding: 12px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration:none;
      transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
      user-select:none;
      white-space:nowrap;
    }
    .btn i{ font-size: 14px; }
    .btn-primary{
      background: linear-gradient(135deg, var(--forest), #1a5a41);
      color: #fff;
      box-shadow: 0 14px 30px rgba(18,71,52,.18);
    }
    .btn-primary:hover{ transform: translateY(-2px); box-shadow: 0 18px 40px rgba(18,71,52,.22); }
    .btn-secondary{
      background: rgba(255,255,255,.72);
      color: var(--forest);
      border: 1px solid var(--stroke);
      box-shadow: 0 10px 26px rgba(18,71,52,.10);
      backdrop-filter: blur(8px);
    }
    .btn-secondary:hover{ transform: translateY(-2px); background: rgba(255,255,255,.9); }
    .btn-ghost{
      background: transparent;
      border:1px solid rgba(18,71,52,.18);
      color: var(--forest);
    }
    .btn-ghost:hover{ background: rgba(18,71,52,.06); transform: translateY(-2px); }

    
    header{
      position: sticky;
      top:0; z-index: 50;
      height: var(--header-h);
      display:flex; align-items:center;
      background: rgba(251,248,241,.7);
      backdrop-filter: blur(12px);
      border-bottom: 1px solid rgba(18,71,52,.10);
    }
    .nav-wrap{
      display:flex; align-items:center; justify-content:space-between;
      gap: 18px;
      height: var(--header-h);
    }
    .brand{
      display:flex; align-items:center; gap:12px;
      min-width: 220px;
      text-decoration:none; color: var(--ink);
    }
    .brand-mark{
      width: 40px; height: 40px;
      border-radius: 12px;
      background: linear-gradient(135deg, rgba(18,71,52,.95), rgba(107,122,58,.92));
      box-shadow: 0 12px 26px rgba(18,71,52,.18);
      display:grid; place-items:center;
      color:#fff;
    }
    .brand h3{
      font-size: 15px;
      letter-spacing: .02em;
    }
    .brand small{
      display:block;
      font-family: var(--bfont);
      font-size: 12px;
      color: var(--muted);
      margin-top:2px;
    }

    nav{ display:flex; align-items:center; gap: 14px; }
    .nav-links{
      display:flex; align-items:center; gap: 10px;
      list-style:none; padding:0; margin:0;
    }
    .nav-links a{
      text-decoration:none;
      color: rgba(20,33,27,.88);
      font-weight: 600;
      font-size: 14px;
      padding: 10px 10px;
      border-radius: 999px;
      transition: background .18s ease, transform .18s ease, color .18s ease;
    }
    .nav-links a:hover{
      background: rgba(107,122,58,.12);
      color: var(--forest);
      transform: translateY(-1px);
    }
    .nav-cta{
      display:flex; align-items:center; gap: 10px;
    }

    .mobile-toggle{
      display:none;
      width:44px;height:44px;border-radius: 12px;
      border:1px solid rgba(18,71,52,.18);
      background: rgba(255,255,255,.72);
      box-shadow: 0 10px 24px rgba(18,71,52,.08);
      cursor:pointer;
    }

    .drawer{
      position: fixed;
      top: var(--header-h);
      left:0; right:0;
      background: rgba(251,248,241,.92);
      backdrop-filter: blur(12px);
      border-bottom: 1px solid rgba(18,71,52,.10);
      transform: translateY(-16px);
      opacity:0;
      pointer-events:none;
      transition: transform .18s ease, opacity .18s ease;
      z-index: 49;
    }
    .drawer.open{
      transform: translateY(0);
      opacity:1;
      pointer-events:auto;
    }
    .drawer .drawer-inner{
      padding: 14px 0 18px;
      display:flex;
      flex-direction:column;
      gap: 12px;
    }
    .drawer a{
      padding: 12px 12px;
      border-radius: 14px;
      text-decoration:none;
      color: rgba(20,33,27,.9);
      font-weight: 700;
      background: rgba(255,255,255,.55);
      border:1px solid rgba(18,71,52,.12);
    }
    .drawer a:hover{ background: rgba(255,255,255,.85); }

  
    .hero{
      padding: 64px 0 72px;
      position: relative;
      overflow:hidden;
    }
    .hero-grid{
      display:grid;
      grid-template-columns: 1.2fr .8fr;
      gap: 42px;
      align-items:center;
      min-height: calc(86vh - var(--header-h));
    }

    .hero-card{
      background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.55));
      border: 1px solid rgba(18,71,52,.12);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 26px;
      backdrop-filter: blur(10px);
    }

    .hero h1{
      font-size: clamp(34px, 4.2vw, 56px);
      letter-spacing: -0.02em;
      margin-bottom: 12px;
      color: rgba(20,33,27,.96);
    }
    .hero .lead{
      font-size: 16px;
      color: rgba(20,33,27,.72);
      margin-bottom: 18px;
      max-width: 62ch;
    }

    .hero-ctas{ display:flex; gap: 12px; flex-wrap: wrap; margin-top: 12px; }
    .hero-badges{
      display:flex; gap:10px; flex-wrap: wrap;
      margin-top: 18px;
    }
    .badge{
      display:inline-flex; align-items:center; gap:8px;
      padding: 9px 12px;
      border-radius: 999px;
      font-weight: 700;
      font-size: 13px;
      background: rgba(107,122,58,.10);
      border: 1px solid rgba(107,122,58,.22);
      color: rgba(20,33,27,.86);
    }
    .badge i{ color: var(--forest); }

    .hero-visual{
      position:relative;
      border-radius: var(--radius);
      overflow:hidden;
      border: 1px solid rgba(18,71,52,.12);
      box-shadow: var(--shadow2);
      min-height: 520px;
      background:
        linear-gradient(145deg, rgba(18,71,52,.72), rgba(107,122,58,.55)),
        url('https://images.unsplash.com/photo-1521791055366-0d553872125f?auto=format&fit=crop&w=1400&q=70') center/cover no-repeat;
    }
    .hero-visual::after{
      content:"";
      position:absolute; inset:0;
      background:
        radial-gradient(700px 520px at 40% 20%, rgba(255,255,255,.18), transparent 55%),
        linear-gradient(180deg, rgba(18,71,52,.35), rgba(18,71,52,.50));
      pointer-events:none;
    }
    .hero-visual .visual-caption{
      position:absolute;
      left: 18px; right: 18px; bottom: 18px;
      padding: 14px 14px;
      border-radius: 16px;
      background: rgba(255,255,255,.78);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(18,71,52,.10);
      display:flex;
      justify-content:space-between;
      gap: 12px;
      align-items:center;
    }
    .caption-title{
      color: rgba(20,33,27,.92);
      font-weight: 800;
      font-size: 14px;
      margin:0;
    }
    .caption-sub{
      margin: 3px 0 0;
      font-size: 12px;
      color: rgba(20,33,27,.62);
      font-weight: 600;
    }


    .floaters{
      position:absolute;
      inset:0;
      pointer-events:none;
    }
    .floater{
      position:absolute;
      width: 56px; height:56px;
      border-radius: 18px;
      display:grid; place-items:center;
      background: rgba(251,248,241,.65);
      border: 1px solid rgba(255,255,255,.35);
      box-shadow: 0 18px 35px rgba(0,0,0,.12);
      color: var(--forest);
      backdrop-filter: blur(10px);
      animation: drift 8s ease-in-out infinite;
    }
    .floater:nth-child(1){ top: 14%; left: 8%; animation-delay: 0s; }
    .floater:nth-child(2){ top: 38%; left: 2%; animation-delay: 1.2s; }
    .floater:nth-child(3){ top: 10%; right: 10%; animation-delay: 2.1s; }
    .floater:nth-child(4){ bottom: 18%; right: 12%; animation-delay: 3.1s; }
    @keyframes drift{
      0%,100%{ transform: translateY(0) translateX(0) rotate(0deg); }
      50%{ transform: translateY(-12px) translateX(6px) rotate(2deg); }
    }


    .reveal{
      opacity:0;
      transform: translateY(16px);
      transition: opacity .6s ease, transform .6s ease;
    }
    .reveal.in{
      opacity:1;
      transform: translateY(0);
    }

   
    .about-grid{
      display:grid;
      grid-template-columns: 1fr 1.1fr;
      gap: 34px;
      align-items:center;
    }
    .about-image{
      border-radius: var(--radius);
      overflow:hidden;
      border: 1px solid rgba(18,71,52,.12);
      box-shadow: var(--shadow2);
      min-height: 420px;
      background:
        linear-gradient(135deg, rgba(18,71,52,.22), rgba(107,122,58,.10)),
        url('https://images.unsplash.com/photo-1565688534245-05d6b5be184a?auto=format&fit=crop&w=1400&q=70') center/cover no-repeat;
      position:relative;
    }
    .about-image::after{
      content:"";
      position:absolute; inset:0;
      background: linear-gradient(180deg, rgba(18,71,52,.25), rgba(18,71,52,.45));
    }
    .about-stats{
      display:grid;
      grid-template-columns: repeat(3, minmax(0,1fr));
      gap: 12px;
      margin-top: 18px;
    }
    .stat{
      background: rgba(255,255,255,.72);
      border:1px solid rgba(18,71,52,.12);
      border-radius: 16px;
      padding: 12px 12px;
      box-shadow: 0 10px 24px rgba(18,71,52,.08);
    }
    .stat strong{
      display:block;
      font-family: var(--hfont);
      font-size: 18px;
      color: rgba(20,33,27,.9);
    }
    .stat span{
      display:block;
      font-size: 12px;
      font-weight: 700;
      color: rgba(20,33,27,.60);
      margin-top: 4px;
    }

    .icon-list{
      display:grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 12px;
      margin-top: 18px;
    }
    .icon-item{
      display:flex; gap: 12px; align-items:flex-start;
      padding: 14px 14px;
      border-radius: 16px;
      background: rgba(255,255,255,.62);
      border: 1px solid rgba(18,71,52,.12);
      box-shadow: 0 10px 24px rgba(18,71,52,.08);
      transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
    }
    .icon-item:hover{
      transform: translateY(-2px);
      background: rgba(255,255,255,.85);
      box-shadow: 0 14px 30px rgba(18,71,52,.12);
    }
    .icon-chip{
      width: 42px; height:42px; border-radius: 14px;
      background: rgba(107,122,58,.12);
      border:1px solid rgba(107,122,58,.22);
      color: var(--forest);
      display:grid; place-items:center;
      flex: 0 0 auto;
    }
    .icon-item h4{
      font-size: 16px;
      margin: 0 0 4px;
    }
    .icon-item p{ font-size: 13px; margin:0; }

  
    .grid-3{
      display:grid;
      grid-template-columns: repeat(3, minmax(0,1fr));
      gap: 16px;
    }
    .grid-2{
      display:grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 16px;
    }
    .card{
      background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.60));
      border: 1px solid rgba(18,71,52,.12);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: 0 12px 30px rgba(18,71,52,.10);
      backdrop-filter: blur(10px);
      transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
      position:relative;
      overflow:hidden;
    }
    .card::before{
      content:"";
      position:absolute;
      inset:-120px -120px auto auto;
      width: 220px; height: 220px;
      background: radial-gradient(circle at 30% 30%, rgba(107,122,58,.18), transparent 58%);
      transform: rotate(25deg);
      pointer-events:none;
    }
    .card:hover{
      transform: translateY(-4px);
      box-shadow: 0 18px 44px rgba(18,71,52,.14);
      background: rgba(255,255,255,.88);
    }
    .card .icon{
      width: 52px; height: 52px;
      border-radius: 18px;
      background: linear-gradient(135deg, rgba(18,71,52,.16), rgba(107,122,58,.12));
      border: 1px solid rgba(18,71,52,.12);
      display:grid; place-items:center;
      color: var(--forest);
      margin-bottom: 12px;
      transition: transform .18s ease;
    }
    .card:hover .icon{ transform: translateY(-2px) rotate(-2deg); }
    .card h3{
      font-size: 18px;
      margin-bottom: 6px;
    }
    .card p{ font-size: 14px; }

  
    .why{
      background:
        linear-gradient(180deg, rgba(239,230,214,.55), rgba(251,248,241,.70));
      border-top: 1px solid rgba(18,71,52,.08);
      border-bottom: 1px solid rgba(18,71,52,.08);
    }
    .counters{
      display:grid;
      grid-template-columns: repeat(4, minmax(0,1fr));
      gap: 14px;
      margin-top: 18px;
    }
    .counter{
      border-radius: 18px;
      padding: 16px 16px;
      background: rgba(255,255,255,.68);
      border: 1px solid rgba(18,71,52,.12);
      box-shadow: 0 12px 30px rgba(18,71,52,.10);
      display:flex; align-items:center; gap: 12px;
    }
    .counter .dot{
      width: 44px; height:44px; border-radius: 16px;
      background: rgba(18,71,52,.10);
      border: 1px solid rgba(18,71,52,.14);
      display:grid; place-items:center;
      color: var(--forest);
      flex:0 0 auto;
    }
    .counter strong{
      font-family: var(--hfont);
      font-size: 20px;
      display:block;
      color: rgba(20,33,27,.92);
      line-height:1.1;
    }
    .counter span{
      font-size: 12px;
      font-weight: 700;
      color: rgba(20,33,27,.62);
      display:block;
      margin-top: 4px;
    }

   
    .feature-strip{
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 18px;
      align-items: start;
    }
    .feature-panel{
      border-radius: var(--radius);
      border: 1px solid rgba(18,71,52,.12);
      background: linear-gradient(135deg, rgba(18,71,52,.08), rgba(107,122,58,.08));
      padding: 18px;
      box-shadow: 0 12px 30px rgba(18,71,52,.10);
    }
    .feature-panel p{ margin-top: 10px; }

    .chips{
      display:flex; flex-wrap:wrap; gap:10px; margin-top: 14px;
    }
    .chip{
      display:inline-flex; align-items:center; gap:8px;
      padding: 10px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,.72);
      border: 1px solid rgba(18,71,52,.12);
      font-weight: 800;
      font-size: 13px;
      color: rgba(20,33,27,.82);
      transition: transform .18s ease, background .18s ease;
    }
    .chip:hover{ transform: translateY(-2px); background: rgba(255,255,255,.92); }
    .chip i{ color: var(--forest); }

   
    .testimonials{
      background:
        radial-gradient(900px 520px at 10% 10%, rgba(107,122,58,.18), transparent 60%),
        radial-gradient(900px 520px at 95% 15%, rgba(18,71,52,.16), transparent 58%),
        linear-gradient(180deg, rgba(251,248,241,.85), #fff);
    }
    .carousel{
      position:relative;
      border-radius: var(--radius);
      border:1px solid rgba(18,71,52,.12);
      background: rgba(255,255,255,.70);
      box-shadow: var(--shadow);
      overflow:hidden;
    }
    .track{
      display:flex;
      transition: transform .55s cubic-bezier(.2,.7,.2,1);
      will-change: transform;
    }
    .slide{
      min-width: 100%;
      padding: 22px;
      display:grid;
      grid-template-columns: 1fr;
      gap: 14px;
    }
    .t-card{
      border-radius: 18px;
      border: 1px solid rgba(18,71,52,.12);
      background: rgba(255,255,255,.82);
      box-shadow: 0 12px 30px rgba(18,71,52,.10);
      padding: 18px;
      display:flex;
      gap: 14px;
      align-items:flex-start;
    }
    .avatar{
      width: 56px; height:56px;
      border-radius: 18px;
      border: 1px solid rgba(18,71,52,.12);
      background: linear-gradient(135deg, rgba(18,71,52,.14), rgba(107,122,58,.14));
      flex:0 0 auto;
      overflow:hidden;
    }
    .avatar img{ width:100%; height:100%; object-fit:cover; display:block; }
    .t-card h4{ font-size: 16px; margin:0; }
    .stars{ color: #b48a2a; font-size: 12px; margin-top: 6px; }
    .quote{ margin-top: 8px; color: rgba(20,33,27,.68); font-weight: 600; font-size: 14px; }

    .carousel-controls{
      display:flex; justify-content:space-between; align-items:center;
      gap: 10px;
      padding: 12px 14px;
      border-top: 1px solid rgba(18,71,52,.10);
      background: rgba(255,255,255,.55);
    }
    .dots{ display:flex; gap: 8px; }
    .dotbtn{
      width: 9px; height: 9px; border-radius: 99px;
      border: 1px solid rgba(18,71,52,.22);
      background: rgba(18,71,52,.12);
      cursor:pointer;
      transition: transform .18s ease, background .18s ease, width .18s ease;
    }
    .dotbtn[aria-current="true"]{
      width: 26px;
      background: rgba(18,71,52,.55);
    }
    .arrow{
      width: 44px; height:44px;
      border-radius: 14px;
      border: 1px solid rgba(18,71,52,.14);
      background: rgba(255,255,255,.72);
      cursor:pointer;
      transition: transform .18s ease, background .18s ease;
    }
    .arrow:hover{ transform: translateY(-2px); background: rgba(255,255,255,.92); }

  
    .contact-grid{
      display:grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 18px;
      align-items:start;
    }
    form{
      display:grid;
      gap: 12px;
    }
    .field{
      display:grid;
      gap: 6px;
    }
    label{
      font-weight: 800;
      font-size: 13px;
      color: rgba(20,33,27,.82);
    }
    input, textarea{
      width:100%;
      padding: 12px 12px;
      border-radius: 14px;
      border: 1px solid rgba(18,71,52,.18);
      background: rgba(255,255,255,.76);
      font: inherit;
      transition: box-shadow .18s ease, background .18s ease, border-color .18s ease;
    }
    textarea{ min-height: 120px; resize: vertical; }
    input:focus, textarea:focus{
      outline:none;
      border-color: rgba(107,122,58,.50);
      box-shadow: 0 0 0 4px rgba(107,122,58,.18);
      background: rgba(255,255,255,.92);
    }

    .success{
      display:none;
      padding: 12px 14px;
      border-radius: 14px;
      background: rgba(107,122,58,.12);
      border: 1px solid rgba(107,122,58,.25);
      color: rgba(20,33,27,.9);
      font-weight: 800;
      animation: pop .35s ease;
    }
    .success.show{ display:block; }
    @keyframes pop{
      from{ opacity:0; transform: translateY(10px); }
      to{ opacity:1; transform: translateY(0); }
    }

    .contact-card{
      border-radius: var(--radius);
      border: 1px solid rgba(18,71,52,.12);
      background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.58));
      box-shadow: 0 12px 30px rgba(18,71,52,.10);
      padding: 18px;
      position:sticky;
      top: calc(var(--header-h) + 16px);
    }
    .contact-item{
      display:flex; gap: 12px; align-items:flex-start;
      padding: 12px 0;
      border-bottom: 1px dashed rgba(18,71,52,.14);
    }
    .contact-item:last-child{ border-bottom:0; }
    .contact-item i{
      width: 38px; height:38px;
      border-radius: 14px;
      display:grid; place-items:center;
      background: rgba(18,71,52,.10);
      border: 1px solid rgba(18,71,52,.12);
      color: var(--forest);
      flex:0 0 auto;
      margin-top: 2px;
    }
    .map{
      margin-top: 12px;
      border-radius: 16px;
      border: 1px solid rgba(18,71,52,.12);
      background:
        linear-gradient(135deg, rgba(18,71,52,.10), rgba(107,122,58,.10)),
        radial-gradient(700px 200px at 20% 20%, rgba(255,255,255,.55), transparent 60%);
      min-height: 160px;
      display:grid;
      place-items:center;
      color: rgba(20,33,27,.70);
      font-weight: 900;
      letter-spacing: .04em;
      text-transform: uppercase;
      font-size: 12px;
    }


    footer{
      background: rgba(18,71,52,.92);
      color: rgba(255,255,255,.88);
      padding: 56px 0 22px;
      border-top: 1px solid rgba(255,255,255,.10);
    }
    .footer-grid{
      display:grid;
      grid-template-columns: 1.2fr 1fr 1fr 1fr;
      gap: 16px;
      align-items:start;
      margin-bottom: 22px;
    }
    .footer-brand{
      display:flex; gap: 12px; align-items:flex-start;
    }
    .footer-brand .brand-mark{ box-shadow:none; }
    footer p{ color: rgba(255,255,255,.74); }
    .footer-col h4{
      font-family: var(--hfont);
      margin-bottom: 12px;
      font-size: 16px;
      color: rgba(255,255,255,.95);
    }
    .footer-links{
      list-style:none; padding:0; margin:0;
      display:grid; gap: 10px;
    }
    .footer-links a{
      color: rgba(255,255,255,.78);
      text-decoration:none;
      font-weight: 700;
      transition: transform .18s ease, color .18s ease;
      display:inline-flex;
      align-items:center;
      gap: 8px;
    }
    .footer-links a:hover{
      color: #fff;
      transform: translateX(3px);
    }
    .social{
      display:flex; gap: 10px; margin-top: 12px;
    }
    .social a{
      width: 42px; height:42px;
      border-radius: 14px;
      display:grid; place-items:center;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.08);
      color: rgba(255,255,255,.92);
      text-decoration:none;
      transition: transform .18s ease, background .18s ease;
    }
    .social a:hover{ transform: translateY(-2px); background: rgba(255,255,255,.14); }
    .footer-bottom{
      border-top: 1px solid rgba(255,255,255,.12);
      padding-top: 14px;
      display:flex;
      justify-content:space-between;
      align-items:center;
      gap: 12px;
      flex-wrap: wrap;
      color: rgba(255,255,255,.72);
      font-weight: 700;
      font-size: 13px;
    }
    .legal-links{
      display:flex; gap: 14px; flex-wrap:wrap;
    }
    .legal-links button{
      background: transparent;
      border:0;
      color: rgba(255,255,255,.78);
      font-weight: 900;
      cursor:pointer;
      padding: 8px 10px;
      border-radius: 12px;
      transition: background .18s ease, transform .18s ease, color .18s ease;
    }
    .legal-links button:hover{
      background: rgba(255,255,255,.10);
      transform: translateY(-1px);
      color: #fff;
    }

    .modal-overlay{
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,.55);
      display:none;
      place-items:center;
      padding: 18px;
      z-index: 80;
      animation: fade .18s ease;
    }
    .modal-overlay.open{ display:grid; }
    @keyframes fade{ from{ opacity:0; } to{ opacity:1; } }

    .modal{
      width: min(720px, 100%);
      border-radius: 20px;
      border: 1px solid rgba(18,71,52,.14);
      background: rgba(251,248,241,.95);
      box-shadow: 0 30px 80px rgba(0,0,0,.30);
      overflow:hidden;
      transform: translateY(8px);
      animation: rise .22s ease forwards;
    }
    @keyframes rise{ to{ transform: translateY(0); } }
    .modal-header{
      padding: 14px 16px;
      display:flex; align-items:center; justify-content:space-between;
      gap: 10px;
      border-bottom: 1px solid rgba(18,71,52,.10);
      background: linear-gradient(135deg, rgba(18,71,52,.08), rgba(107,122,58,.08));
    }
    .modal-title{
      display:flex; align-items:center; gap: 10px;
      color: rgba(20,33,27,.92);
    }
    .modal-title h3{ font-size: 18px; }
    .modal-close{
      width: 44px; height:44px;
      border-radius: 14px;
      border: 1px solid rgba(18,71,52,.14);
      background: rgba(255,255,255,.72);
      cursor:pointer;
      transition: transform .18s ease, background .18s ease;
    }
    .modal-close:hover{ transform: translateY(-2px); background: rgba(255,255,255,.92); }
    .modal-body{
      padding: 16px;
    }
    .scrollbox{
      max-height: 320px;
      overflow:auto;
      border-radius: 16px;
      border: 1px solid rgba(18,71,52,.12);
      background: rgba(255,255,255,.72);
      padding: 14px;
      color: rgba(20,33,27,.74);
    }
    .scrollbox h4{ font-size: 16px; margin: 0 0 8px; }
    .scrollbox p{ margin: 0 0 10px; color: rgba(20,33,27,.68); }

    .checkline{
      display:flex; align-items:flex-start; gap: 10px;
      padding: 8px 2px;
      color: rgba(20,33,27,.75);
      font-weight: 700;
      font-size: 13px;
    }
    .checkline input{ width: 18px; height:18px; margin-top: 2px; }

  
    .to-top{
      position: fixed;
      right: 16px;
      bottom: 16px;
      width: 46px; height:46px;
      border-radius: 16px;
      border: 1px solid rgba(18,71,52,.18);
      background: rgba(251,248,241,.88);
      box-shadow: 0 14px 35px rgba(18,71,52,.16);
      display:grid; place-items:center;
      cursor:pointer;
      opacity:0; pointer-events:none;
      transform: translateY(8px);
      transition: opacity .18s ease, transform .18s ease, background .18s ease;
      z-index: 70;
    }
    .to-top.show{ opacity:1; pointer-events:auto; transform: translateY(0); }
    .to-top:hover{ background: rgba(255,255,255,.96); transform: translateY(-2px); }

   
    @media (max-width: 980px){
      .hero-grid{ grid-template-columns: 1fr; }
      .hero-visual{ min-height: 420px; }
      .about-grid{ grid-template-columns: 1fr; }
      .feature-strip{ grid-template-columns: 1fr; }
      .contact-grid{ grid-template-columns: 1fr; }
      .contact-card{ position: static; }
      .counters{ grid-template-columns: repeat(2, minmax(0,1fr)); }
      .grid-3{ grid-template-columns: repeat(2, minmax(0,1fr)); }
      .footer-grid{ grid-template-columns: 1.2fr 1fr; }
    }

    @media (max-width: 720px){
      nav{ display:none; }
      .mobile-toggle{ display:inline-grid; place-items:center; }
      .grid-3{ grid-template-columns: 1fr; }
      .grid-2{ grid-template-columns: 1fr; }
      .icon-list{ grid-template-columns: 1fr; }
      .about-stats{ grid-template-columns: 1fr; }
      .hero{ padding-top: 22px; }
      .hero-visual{ min-height: 360px; }
      .section{ padding: 66px 0; }
    }

  
    @media (prefers-reduced-motion: reduce){
      html{ scroll-behavior:auto; }
      .reveal, .track, .floater, .btn, .card, .icon-item, .arrow, .dotbtn, .to-top { transition:none!important; animation:none!important; }
    }
  