:root{
      --bg:#f4f8ff;
      --surface:#ffffff;
      --surface-alt:#eef4ff;
      --text:#10213a;
      --muted:#425b7c;
      --primary:#1f4fa8;
      --primary-dark:#163b7e;
      --accent:#4f87ff;
      --border:#cddcf7;
      --success:#1f7a53;
      --radius:14px;
      --shadow:0 10px 30px rgba(16,33,58,.12);
      --max:1120px;
      --space-1:.5rem;
      --space-2:.75rem;
      --space-3:1rem;
      --space-4:1.5rem;
      --space-5:2rem;
      --space-6:3rem;
      --space-7:4rem;
      --font-serif: "Georgia", "Times New Roman", Times, serif;
      --font-sans: Inter, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    }

    *{box-sizing:border-box}
    html,body{margin:0;padding:0}
    body{
      font-family:var(--font-sans);
      color:var(--text);
      background:
        radial-gradient(1200px 500px at 0% -10%, rgba(79,135,255,.15), transparent 60%),
        radial-gradient(900px 500px at 100% 10%, rgba(31,79,168,.10), transparent 60%),
        var(--bg);
      line-height:1.55;
    }

    a{color:var(--primary); text-decoration:none}
    a:hover, a:focus{text-decoration:underline}
    img{max-width:100%; display:block; border-radius:12px}
    .container{width:min(var(--max), 92%); margin-inline:auto}
    .section{padding:var(--space-7) 0}
    .section-title{
      font-family:var(--font-serif);
      font-size:clamp(1.6rem, 2.8vw, 2.3rem);
      margin:0 0 var(--space-3);
      line-height:1.2;
      letter-spacing:.2px;
    }
    .section-lead{
      color:var(--muted);
      margin:0 0 var(--space-5);
      max-width:70ch;
    }

    header{
      position:sticky; top:0; z-index:30;
      background:rgba(244,248,255,.88);
      backdrop-filter: blur(8px);
      border-bottom:1px solid rgba(205,220,247,.8);
    }
    .nav{
      display:flex; align-items:center; justify-content:space-between;
      padding:.8rem 0;
      gap:var(--space-3);
    }
    .brand{
      font-family:var(--font-serif);
      font-size:1.2rem;
      color:var(--text);
      font-weight:700;
      letter-spacing:.2px;
    }
    .nav-links{
      display:flex; flex-wrap:wrap; gap:1rem; align-items:center;
      font-size:.95rem;
    }
    .btn{
      display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
      border-radius:999px; padding:.78rem 1.2rem; font-weight:700;
      border:1px solid transparent; transition:.2s ease;
      text-decoration:none;
      cursor:pointer;
    }
    .btn-primary{
      background:linear-gradient(135deg, var(--primary), var(--accent));
      color:#fff;
      box-shadow:0 8px 24px rgba(31,79,168,.28);
    }
    .btn-primary:hover,.btn-primary:focus{
      transform:translateY(-1px);
      text-decoration:none;
      background:linear-gradient(135deg, var(--primary-dark), var(--primary));
    }
    .btn-outline{
      background:#fff; color:var(--primary); border-color:var(--primary);
    }
    .btn-outline:hover,.btn-outline:focus{
      background:var(--surface-alt); text-decoration:none;
    }

    .hero{
      position:relative;
      padding:clamp(3rem, 8vw, 6rem) 0 var(--space-7);
      overflow:hidden;
    }
    .hero::before{
      content:"";
      position:absolute; inset:0;
      background:
        linear-gradient(120deg, rgba(31,79,168,.10), rgba(79,135,255,.08)),
        repeating-linear-gradient(45deg, rgba(31,79,168,.04) 0 8px, transparent 8px 16px);
      pointer-events:none;
    }
    .hero-grid{
      position:relative; z-index:1;
      display:grid; grid-template-columns:1.1fr .9fr; gap:var(--space-6); align-items:center;
    }
    .eyebrow{
      display:inline-block; margin-bottom:.8rem; font-size:.86rem; letter-spacing:.08em;
      text-transform:uppercase; font-weight:700; color:var(--primary-dark);
      background:rgba(31,79,168,.12); padding:.3rem .65rem; border-radius:999px;
    }
    h1{
      font-family:var(--font-serif);
      font-size:clamp(2rem, 5vw, 3.4rem);
      line-height:1.1; margin:0 0 1rem;
    }
    .hero p{
      margin:0 0 1.4rem; color:var(--muted); max-width:62ch;
      font-size:1.04rem;
    }
    .hero-cta{
      display:flex; flex-wrap:wrap; gap:.8rem;
      margin-bottom:1rem;
    }
    .hero-note{
      font-size:.92rem; color:var(--muted);
    }
    .hero-card{
      background:linear-gradient(180deg, #fff, #f8fbff);
      border:1px solid var(--border);
      border-radius:var(--radius);
      box-shadow:var(--shadow);
      padding:var(--space-4);
    }
    .hero-card h2{
      margin:.2rem 0 .5rem; font-family:var(--font-serif); font-size:1.3rem;
    }

    .grid-3{
      display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4);
    }
    .card{
      background:var(--surface);
      border:1px solid var(--border);
      border-radius:var(--radius);
      padding:var(--space-4);
      box-shadow:0 4px 14px rgba(16,33,58,.06);
    }
    .card h3{
      margin:.2rem 0 .5rem;
      font-size:1.1rem;
      font-family:var(--font-serif);
    }
    .card p{margin:0; color:var(--muted)}

    .about-wrap, .contact-wrap{
      display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6); align-items:start;
    }

    .trust{
      background:linear-gradient(180deg, #f0f6ff 0%, #ffffff 100%);
      border-top:1px solid var(--border);
      border-bottom:1px solid var(--border);
    }
    .trust-list{
      display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-3);
      padding:0; margin:0; list-style:none;
    }
    .trust-list li{
      background:#fff; border:1px solid var(--border); border-radius:10px;
      padding:.9rem 1rem;
      color:var(--text);
    }

    .pricing-box{
      background:linear-gradient(135deg, #ffffff, #edf4ff);
      border:1px solid var(--border);
      border-radius:var(--radius);
      padding:var(--space-5);
      box-shadow:var(--shadow);
    }
    .price{
      font-family:var(--font-serif);
      font-size:2rem;
      margin:.2rem 0 .6rem;
      color:var(--primary-dark);
    }

    .gallery-grid{
      display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-3);
    }
    .gallery-grid figure{
      margin:0; background:#fff; border:1px solid var(--border);
      border-radius:12px; overflow:hidden;
    }
    .gallery-grid figcaption{
      padding:.7rem .8rem; font-size:.9rem; color:var(--muted);
    }

    details{
      background:#fff; border:1px solid var(--border); border-radius:10px;
      padding:.8rem 1rem;
    }
    details+details{margin-top:.8rem}
    summary{
      cursor:pointer; font-weight:700; color:var(--text);
    }
    details p{margin:.7rem 0 0; color:var(--muted)}

    .contact{
      background:
        linear-gradient(120deg, rgba(31,79,168,.08), rgba(79,135,255,.07)),
        #f5f9ff;
      border-top:1px solid var(--border);
    }
    .contact-card{
      background:#fff;
      border:1px solid var(--border);
      border-radius:var(--radius);
      padding:var(--space-5);
      box-shadow:var(--shadow);
    }
    .contact-list{list-style:none; padding:0; margin:0}
    .contact-list li{margin:0 0 .65rem}
    .muted{color:var(--muted)}
    .sr-only{
      position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0;
    }

    footer{
      padding:1.4rem 0 2rem; font-size:.9rem; color:var(--muted);
    }

    @media (max-width:960px){
      .hero-grid,.about-wrap,.contact-wrap{grid-template-columns:1fr}
      .grid-3{grid-template-columns:1fr 1fr}
      .gallery-grid{grid-template-columns:1fr 1fr}
    }
    @media (max-width:640px){
      .nav{align-items:flex-start; flex-direction:column}
      .grid-3,.gallery-grid,.trust-list{grid-template-columns:1fr}
      .hero-cta .btn{width:100%}
    }