@font-face {
  font-family: 'Google Sans';
  src: url('../assets/GoogleSans-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Google Sans';
  src: url('../assets/GoogleSans-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Google Sans';
  src: url('../assets/GoogleSans-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root{  
      --bg:#00121f;  
      --surface:#0b1220;  
      --card:#0f1930;  
      --text:#eef2ff;  
      --muted:#a7b0c0;  
      --brand:#1e8cff;  
      --brand2:#00d4ff;  
      --border:rgba(255,255,255,.10);  
      --shadow: 0 14px 40px rgba(0,0,0,.35);  
      --radius:18px;  
      --max:1100px;  
    }  
  
    *{box-sizing:border-box}  
    html{scroll-behavior:smooth}  
    body{  
      margin:0;  
      font-family: 'Google Sans', Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;  
      background: radial-gradient(900px 500px at 80% 20%, rgba(30,140,255,.16), transparent 60%),  
                  radial-gradient(700px 450px at 15% 40%, rgba(0,212,255,.12), transparent 55%),  
                  var(--bg);  
      color:var(--text);  
    }  
    a{color:inherit;text-decoration:none}  
    img{max-width:100%;height:auto;display:block}  
    .container{max-width:var(--max); margin:auto; padding:0 18px}  
  
    /* TOPBAR */
    .topbar{  
      position:sticky; top:0; z-index:1000;
      background: rgba(11,18,32,.85);  
      backdrop-filter: blur(10px);  
      border-bottom:1px solid var(--border);  
    }  
    .topbar-inner{  
      display:flex; align-items:center; justify-content:space-between;  
      padding:12px 0;  
      gap:16px;  
    }  
    .topbar-actions{
      display:flex; align-items:center; gap:10px;
    }  
    .brand{  
      display:flex; align-items:center; gap:12px;  
      min-width: 165px;  
    }  
    .logo{  
      height:50px; width:auto;     
    }  
    .brand-name{  
      display:flex; flex-direction:column; line-height:1.1;  
      font-weight:800;  
      letter-spacing:.2px;  
    }  
    .brand-name small{  
      font-weight:600;  
      color:var(--muted);  
      letter-spacing:.25px;  
      margin-top:3px;  
    }  
  
    .nav{  
      display:flex; align-items:center; gap:14px;  
    }  
    .nav a{  
      color:var(--muted);  
      font-weight:650;  
      font-size:14px;  
      padding:10px 10px;  
      border-radius:12px;  
      transition:.2s ease;  
      display:inline-flex;  
      align-items:center;  
      gap:6px;  
    }  
    .nav a img{  
      width:16px;  
      height:16px;  
      display:inline-block;  
      filter: brightness(0) saturate(100%) invert(100%);  
    }  
    .nav a:hover img{  
      filter: brightness(0) saturate(100%) invert(100%);  
    }  
    .nav a:hover{  
      color:var(--text);  
      background: rgba(255,255,255,.06);  
    }  
  
    .btn{  
      display:inline-flex; align-items:center; justify-content:center;  
      gap:10px;  
      padding:12px 14px;  
      border-radius:14px;  
      border:1px solid var(--border);  
      font-weight:750;  
      letter-spacing:.2px;  
      transition:.2s ease;  
      cursor:pointer;  
      user-select:none;  
      white-space:nowrap;  
    }  
    .btn-primary{  
      background: linear-gradient(135deg, var(--brand), var(--brand2));  
      color:#00121f;  
      border:0;  
      box-shadow: 0 14px 34px rgba(30,140,255,.25);  
    }  
    .btn-primary:hover{ transform: translateY(-1px) }  
    .btn-ghost{  
      background: rgba(255,255,255,.04);  
      color: var(--text);  
    }  
    .btn-ghost:hover{ background: rgba(255,255,255,.08) }  
  
    .hamburger{  
      display:none;  
      width:44px; height:44px;  
      border-radius:14px;  
      border:1px solid var(--border);  
      background: rgba(255,255,255,.04);  
      color:var(--text);  
      font-size:18px;  
      align-items:center; justify-content:center;  
    }  
  
    /* HERO */  
    .hero{  
      padding:52px 0 26px;  
    }  
    .hero-grid{    
      align-items:stretch;  
    }  
    .hero-card{
      background: rgba(15,25,48,.65);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding:26px;
      overflow:hidden;
      position:relative;
    }
    /* Smaller header appointment button */
    header.topbar .btn{ padding:12px 8px; font-size:12px; gap:8px; border-radius:10px }

    /* rotating background inside hero card */
    .hero-card .hero-bg{
      position:absolute; inset:0; z-index:0; overflow:hidden; border-radius:inherit;
    }
    .hero-card .hero-bg img{
      width:100%; height:100%; object-fit:cover; display:block; transition:opacity .5s ease; opacity:1;
    }
    .hero-card .hero-bg::after{
      content:""; position:absolute; inset:0; background:linear-gradient(rgba(2,6,12,.48), rgba(2,6,12,.48)); z-index:1; pointer-events:none; border-radius:inherit;
    }
    /* ensure hero card content sits above the background */
    .hero-card > *{ position:relative; z-index:2 }
    .pill{  
      display:inline-flex;  
      padding:8px 12px;  
      border-radius:999px;  
      border:1px solid var(--border);  
      background: rgba(255,255,255,.04);  
      color: var(--muted);  
      font-weight:700;  
      font-size:13px;  
      margin-bottom:14px;  
    }  
    h1{  
      margin:0 0 12px;  
      font-size:42px;  
      letter-spacing:-.6px;  
      line-height:1.1;  
    }  
    .lead{  
      margin:0 0 18px;  
      color:var(--muted);  
      font-size:15.5px;  
      line-height:1.65;  
    }
    .lead-intro{
      margin:0;
    }  
    .hero-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:8px }  
    .hero-actions-mt{ margin-top:16px; }
    .hero-bg-img{
      width:100%; height:100%; object-fit:cover; display:block;
    }  
  
    .hero-side{  
      background: rgba(11,18,32,.55);  
      border:1px solid var(--border);  
      border-radius: var(--radius);  
      box-shadow: var(--shadow);  
      padding:22px;  
      display:flex;  
      flex-direction:column;  
      gap:14px;  
    }  
    .hero-side .kicker{  
      color:var(--muted);  
      font-weight:700;  
      line-height:1.5;  
    }  
    .hero-side .big{  
      font-size:18px;  
      font-weight:850;  
      letter-spacing:-.2px;  
    }  
    .hero-visual{  
      margin-top:auto;  
      border-radius: 16px;  
      border:1px solid var(--border);  
      overflow:hidden;  
      background:  
        radial-gradient(650px 260px at 30% 30%, rgba(30,140,255,.28), transparent 60%),  
        radial-gradient(700px 260px at 80% 70%, rgba(0,212,255,.20), transparent 60%),  
        rgba(255,255,255,.03);  
      height: 240px;  
      display:flex;  
      align-items:flex-end;  
      justify-content:center;  
      padding:16px;  
      color: rgba(238,242,255,.85);  
      text-align:center;  
      font-weight:750;  
      line-height:1.35;  
    }  
  
    /* SECTION */  
    section{ padding:46px 0 }  
    .section-head{  
      display:flex;  
      justify-content:space-between;  
      align-items:flex-end;  
      gap:16px;  
      margin-bottom:18px;  
    }  
    .section-title h2{  
      margin:0;  
      font-size:28px;  
      letter-spacing:-.3px;  
    }  
    .section-title p{  
      margin:8px 0 0;  
      color:var(--muted);  
      line-height:1.6;  
      max-width:720px;  
      font-size:14.8px;  
    }  
  
    /* SERVICES */  
    .grid{  
      display:grid;  
      grid-template-columns: repeat(3, 1fr);  
      gap:16px;  
    }  
    .card{  
      border:1px solid var(--border);  
      background: rgba(15,25,48,.55);  
      border-radius: 18px;  
      box-shadow: 0 12px 28px rgba(0,0,0,.28);  
      overflow:hidden;  
      transition:.2s ease;  
      display: grid;  
      grid-template-rows: 2fr 1fr;  
      height: 300px;  
    }  
    .card:hover{ transform: translateY(-2px); background: rgba(15,25,48,.72) }  
    .card .thumb{  
      background:  
        radial-gradient(600px 220px at 30% 30%, rgba(30,140,255,.28), transparent 62%),  
        radial-gradient(600px 220px at 80% 70%, rgba(0,212,255,.18), transparent 62%),  
        rgba(255,255,255,.03);  
      border-bottom:1px solid var(--border);  
      overflow: hidden;  
    }
    .card-thumb-img{
      width:100%; height:100%; object-fit:cover;
    }  
    .card .body{ 
      padding:12px;  
      display: flex;  
      flex-direction: column;  
      gap: 6px;  
      overflow: hidden;  
    }  
    .card .title-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }
    .card h3{ margin:0; font-size:15px; letter-spacing:-.2px }  
    .card p{ margin:0; color:var(--muted); font-size:13px; line-height:1.5 }  
    .card .more{  
      display:inline-flex; align-items:center; gap:6px;  
      color: rgba(238,242,255,.90);  
      font-weight:700;  
      font-size:12px;  
      padding:8px 10px;  
      border-radius: 10px;  
      background: rgba(255,255,255,.05);  
      border:1px solid var(--border);  
    }
    .card .more img {
      width: 14px;
      height: 14px;
      filter: brightness(0) saturate(100%) invert(100%);
    }  
  
    /* INTRO */  
    .intro{  
      display:grid;  
      grid-template-columns: 1fr 1.1fr;  
      gap:18px;  
      align-items:stretch;  
    }  
    .mosaic{  
      border:1px solid var(--border);  
      border-radius: var(--radius);  
      background: rgba(255,255,255,.03);  
      box-shadow: var(--shadow);  
      padding:14px;  
      display:grid;  
      grid-template-columns: 1fr 1fr;  
      gap:12px;  
      min-height: 320px;  
    }  
    .mosaic .box{ 
      border-radius: 16px;  
      border:1px solid var(--border);  
      background:  
        radial-gradient(500px 220px at 30% 30%, rgba(30,140,255,.26), transparent 60%),  
        rgba(255,255,255,.03);  
      min-height: 140px;  
    }
    .mosaic-img{
      width:100%; height:100%; object-fit:cover; border-radius:16px;
    }  
    .mosaic .box.tall{ grid-column: span 2; min-height: 130px }  
  
    .intro-card{  
      border:1px solid var(--border);  
      border-radius: var(--radius);  
      background: rgba(15,25,48,.55);  
      box-shadow: var(--shadow);  
      padding:22px;  
    }  
    .about-list{  
      margin:20px 0;  
      display:grid;  
      gap:10px;  
      color:var(--muted);  
    }  
    .about-list h3{  
      margin:0;  
      font-size:16px;  
      color:#eef2ff;  
      font-weight:700;  
    }  
    .about-list p{  
      margin:0;  
      line-height:1.6;  
      font-size:14.4px;  
    }  
    .about-list ul, .about-list ol{  
      margin:8px 0 0 18px;  
      padding:0;  
    }  
    .about-list li{  
      margin:4px 0;  
      font-size:14px;  
      line-height:1.6;  
    }  
    .bullets{  
      margin:14px 0 0;  
      display:grid;  
      gap:10px;  
    }  
    .bullet{  
      display:flex; gap:12px;  
      padding:12px;  
      border-radius: 16px;  
      border:1px solid var(--border);  
      background: rgba(255,255,255,.04);  
    }  
    .dot{  
      width:12px; height:12px; border-radius: 999px;  
      background: linear-gradient(135deg, var(--brand), var(--brand2));  
      margin-top:4px;  
      flex:0 0 12px;  
    }  
    .bullet b{ display:block; margin-bottom:2px }  
    .bullet span{ color:var(--muted); font-size:14px; line-height:1.55 }  
  
    /* TEAM */  
    .team-grid{  
      display:grid;  
      grid-template-columns: repeat(4, 1fr);  
      gap:16px;  
    }  
    .member{  
      border:1px solid var(--border);  
      border-radius: 18px;  
      background: rgba(15,25,48,.55);  
      overflow:hidden;  
      box-shadow: 0 12px 28px rgba(0,0,0,.28);  
    }  
    .member .photo{  
      height:160px;  
      background:  
        radial-gradient(550px 220px at 30% 30%, rgba(30,140,255,.26), transparent 62%),  
        radial-gradient(550px 220px at 80% 70%, rgba(0,212,255,.16), transparent 62%),  
        rgba(255,255,255,.03);  
      border-bottom:1px solid var(--border);  
    }  
    .team-photo{
      width:100%; height:100%; object-fit:cover;
    }  
    .member .info{ padding:14px }  
    .member .name{ font-weight:850; margin:0 0 4px }  
    .member .role{ margin:0; color:var(--muted); font-size:13.5px }  
  
    /* PROCESS */  
    .process{  
      display:grid;  
      grid-template-columns: repeat(4, 1fr);  
      gap:14px;  
    }  
    .step{  
      border:1px solid var(--border);  
      border-radius: 18px;  
      background: rgba(15,25,48,.55);  
      padding:16px;  
      box-shadow: 0 12px 28px rgba(0,0,0,.28);  
    }  
    .step .num{  
      display:inline-flex;  
      width:38px; height:38px;  
      border-radius: 14px;  
      align-items:center; justify-content:center;  
      background: rgba(255,255,255,.05);  
      border:1px solid var(--border);  
      font-weight:900;  
      margin-bottom:10px;  
    }  
    .step h4{ margin:0 0 6px; font-size:15.5px }  
    .step p{ margin:0; color:var(--muted); font-size:13.8px; line-height:1.6 }  
  
    /* CONTACT */  
    #contact, #contact * {  
      font-family: 'Google Sans', Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;  
    }  
    .contact{  
      display:grid;  
      grid-template-columns: 1.1fr .9fr;  
      gap:18px;  
      align-items:start;  
    }  
    .contact-card{  
      border:1px solid var(--border);  
      border-radius: var(--radius);  
      background: rgba(15,25,48,.55);  
      box-shadow: var(--shadow);  
      padding:22px;  
    }  
    form{ display:grid; gap:12px }  
    .row{ display:grid; grid-template-columns: 1fr 1fr; gap:12px }  
    label{ font-size:13px; color:var(--muted); font-weight:700 }  
    input, select, textarea{  
      width:100%;  
      padding:12px 12px;  
      border-radius: 14px;  
      border:1px solid var(--border);  
      background: rgba(255,255,255,.03);  
      color: var(--text);  
      outline:none;  
      font-size:14.5px;  
    }  
    textarea{ min-height:110px; resize:vertical }  
    input::placeholder, textarea::placeholder{ color: rgba(167,176,192,.75) }  
  
    .contact-side{  
      border:1px solid var(--border);  
      border-radius: var(--radius);  
      background: rgba(11,18,32,.55);  
      box-shadow: var(--shadow);  
      padding:22px;  
      display:grid;  
      gap:12px;  
    }  
    .contact-side-heading{  
      border-bottom:1px solid var(--border);  
      padding-bottom:10px;  
      margin-bottom:10px;  
    }  
    .contact-side-heading h3{  
      margin:0 0 4px;  
      color:#eef2ff;  
      font-size:17px;  
    }  
    .contact-side-heading p{  
      margin:0;  
      color:var(--muted);  
      font-size:13.8px;  
      line-height:1.5;  
    }  
    .contact-matrix{  
      display:grid;  
      grid-template-columns: repeat(3, 1fr);  
      gap:10px;  
      margin-bottom:18px;  
    }  
    .contact-matrix-item{  
      border:1px solid var(--border);  
      border-radius: 14px;  
      background: rgba(255,255,255,.03);  
      padding:10px;  
      text-align:center;  
    }  
    .contact-matrix-item .label{  
      margin:0;  
      color:var(--muted);  
      font-size:12px;  
      text-transform: uppercase;  
      letter-spacing:0.8px;  
    }  
    .contact-matrix-item .value{  
      margin:4px 0 0;  
      color:#eef2ff;  
      font-weight:700;  
      font-size:14px;  
    }  
    .info-box{  
      border:1px solid var(--border);  
      border-radius: 18px;  
      background: rgba(255,255,255,.04);  
      padding:14px;  
    }  
    .info-box b{  
      display:block;  
      margin-bottom:4px;  
      color:#eef2ff;  
      font-size:14px;  
    }  
    .info-box span{  
      color:var(--muted);  
      line-height:1.5;  
      font-size:14px;  
    }  
    .info-box a{  
      color:var(--brand);  
      font-weight:700;  
    }  
    .info-box b{ display:block; margin-bottom:4px }  
    .info-box span{ color:var(--muted); line-height:1.55 }
    
    /* FOOTER */  
    footer{  
      border-top:1px solid var(--border);  
      background: rgba(11,18,32,.90);  
      padding:42px 0 18px;  
      margin-top:26px;  
    }  
    .footer-grid{  
      display:grid;  
      grid-template-columns: repeat(4, minmax(180px, 1fr));  
      gap:16px;  
      align-items:start;  
      padding:0px 0;  
    }  
    .footer-card{  
      background: rgba(11,18,32,.70);  
      border-radius: var(--radius);  
      padding:18px;  
    }  
    .footer-about-card{  
      display:flex;  
      flex-direction:column;  
      gap:12px;  
    }  
    .footer-logo{  
      display:flex;  
      align-items:center;  
      gap:10px;  
      margin-bottom:6px;  
    }  
    .footer-logo span{  
      font-weight:900;  
      font-size:18px;  
      color:#eef2ff;  
    }  
    .footer-title{  
      font-weight:800;  
      margin:0 0 10px;  
      letter-spacing:-.2px;  
      color:#eef2ff;  
      font-size:15px;  
    }  
    .footer-text{  
      margin:0 0 16px;  
      color:var(--muted);  
      line-height:1.6;  
      font-size:14.5px;  
    }  
    .footer-anchors{  
      display:flex;  
      gap:8px;  
      flex-wrap:wrap;  
    }  
    .btn-secondary{  
      border:1px solid var(--border);  
      color:var(--text);  
      background: rgba(255,255,255,.05);  
    }  
    .footer-link-list, .contact-details{  
      list-style:none;  
      padding:0;  
      margin:0;  
      display:grid;  
      gap:8px;  
    }  
    .footer-link-list li a{  
      color:var(--muted);  
      text-decoration:none;  
      font-size:14px;  
    }  
    .footer-link-list li a:hover{  
      color:var(--text);  
    }  
    .contact-details li{  
      color:var(--muted);  
      font-size:14px;  
      line-height:1.6;  
    }  
    .contact-details a{  
      color:var(--brand);  
      text-decoration:none;  
    }  
    .social-icons{  
      display:flex;  
      gap:10px;  
      margin-top:10px;  
    }  
    .social-icons a{  
      display:inline-flex;  
      align-items:center;  
      justify-content:center;  
      width:34px;  
      height:34px;  
      border-radius:8px;  
      border:1px solid var(--border);  
      background: rgba(255,255,255,.04);  
    }  
    .footer-text{  
      margin:0;  
      color:var(--muted);  
      line-height:1.65;  
      font-size:14.5px;  
    }  
    .footer-links{  
      display:grid;  
      gap:10px;  
      margin-top:10px;  
    }  
    .footer-links a{  
      color:var(--muted);  
      padding:8px 10px;  
      border-radius: 12px;  
      background: rgba(255,255,255,.02);  
      border:1px solid rgba(255,255,255,.05);  
      transition:.2s ease;  
    }  
    .footer-links a:hover{ color:var(--text); background: rgba(255,255,255,.06) }  
    /* Professional footer additions */
    .footer-logo{ display:flex; gap:12px; align-items:center }
    .footer-logo img{ height:44px; width:auto; border-radius:8px }
    .footer-about{ color:var(--muted); line-height:1.6 }
    .footer .social-icons{ display:flex; gap:10px; margin-top:8px }
    .social-icons a{ display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:8px; background:rgba(255,255,255,.03); color:var(--text); text-decoration:none }
    .contact-list{ color:var(--muted); line-height:1.6 }
    .footer-cta{ margin-top:12px }
  
    .footer-bottom{  
      margin-top:18px;  
      padding-top:14px;  
      border-top:1px solid var(--border);  
      display:flex;  
      justify-content:space-between;  
      align-items:center;  
      flex-wrap:wrap;  
      gap:10px;  
      color:var(--muted);  
      font-size:13.5px;  
    }  
    .footer-legal-links{  
      display:flex;  
      align-items:center;  
      gap:14px;  
      flex-wrap:wrap;  
    }  
    .footer-legal-links a{  
      color:var(--muted);  
      text-decoration:none;  
      font-size:13.5px;  
    }  
    .footer-legal-links a:hover{  
      color:var(--text);  
    }  
  
    /* RESPONSIVE */  
    @media (max-width: 980px){
      .container{ padding:0 14px }
      .topbar-inner{ padding:10px 0 }
      .brand{ min-width:140px }
      .logo{ height:50px }
      .hero-grid{ grid-template-columns: 1fr }
      .grid{ grid-template-columns: repeat(2, 1fr) }
      .intro{ grid-template-columns: 1fr }
      .team-grid{ grid-template-columns: repeat(2, 1fr) }
      .process{ grid-template-columns: repeat(2, 1fr) }
      .contact{ grid-template-columns: 1fr }
      .footer-grid{ grid-template-columns: 1fr 1fr }
    }
    @media (max-width: 680px){
      .logo{ height:50px }

      h1{ font-size:30px }
      .hero{ padding:32px 0 16px; }
      section{ padding:32px 0; }
      .hero-card{ padding:18px }
      .hero-visual{ height:180px; padding:12px }
      .grid{ grid-template-columns: 1fr }
      .team-grid{ grid-template-columns: 1fr }
      .process{ grid-template-columns: 1fr }
      .nav{ display:none }
      .hamburger{ display:inline-flex }
      .nav.mobile{
        display:grid;
        position:absolute;
        top:64px;
        right:12px;
        left:12px;
        background: rgba(11,18,32,.98);
        border:1px solid var(--border);
        border-radius: 14px;
        padding:8px;
        box-shadow: var(--shadow);
      }
      .nav.mobile a{ padding:10px 12px; font-size:15px }
      .hero-actions a{ flex:1; min-width:0; justify-content:center }
      .footer-grid{ grid-template-columns: 1fr 1fr }
      .footer-bottom{ flex-direction:column; gap:6px; align-items:center; text-align:center }
    }
    @media (max-width: 480px){
      .brand{ min-width:120px; flex-shrink:0; }
      .logo{ height:50px }
      .topbar-inner{ gap:6px; padding:8px 0 }
      header.topbar .btn{ padding:8px 4px; font-size:11px; gap:4px; border-radius:12px }
      .hamburger{ width:36px; height:36px; }
      h1{ font-size:24px }
      .hero-visual{ height:140px }
      .pill{ font-size:12px; padding:6px 10px }
      .footer-grid{ grid-template-columns: 1fr }
    }