
    :root{
      --bg:#fbfaf7;
      --bg-soft:#f8f3e9;
      --surface:#ffffff;
      --surface-2:#fffdf8;
      --text:#1f1a14;
      --muted:#6d6254;
      --gold:#c79a3b;
      --gold-dark:#9b7222;
      --gold-soft:#f1d89d;
      --dark:#120d07;
      --line:rgba(199,154,59,.16);
      --shadow:0 14px 34px rgba(39,24,5,.08);
      --shadow-lg:0 24px 60px rgba(39,24,5,.15);
      --radius:22px;
      --radius-lg:30px;
      --header-h:80px;
      --container:1180px;
      --transition:.28s ease;
    }

    *{box-sizing:border-box}
    *::before,*::after{box-sizing:border-box}

    html{
      scroll-behavior:smooth;
      overflow-x:hidden;
    }

    body{
      margin:0;
      font-family:'Tajawal',sans-serif;
      background:
        radial-gradient(circle at top right, rgba(199,154,59,.06), transparent 20%),
        linear-gradient(180deg,#ffffff 0%, #fcfaf5 45%, #f7f1e6 100%);
      color:var(--text);
      direction:rtl;
      overflow-x:hidden;
      -webkit-font-smoothing:antialiased;
      text-rendering:optimizeLegibility;
    }

    img{
      max-width:100%;
      height:auto;
      display:block;
    }

    a{
      text-decoration:none;
      color:inherit;
    }

    button,input,textarea,select{
      font:inherit;
    }

    .container{
      width:min(100% - 32px, var(--container));
      margin-inline:auto;
    }

    .section{
      padding:84px 0;
      position:relative;
    }

    .soft{
      background:linear-gradient(180deg, rgba(255,255,255,.7) 0%, rgba(248,243,233,.85) 100%);
    }

    .section-head{
      text-align:center;
      margin-bottom:34px;
      max-width:820px;
      margin-inline:auto;
    }

    .section-head h2{
      margin:10px 0 12px;
      font-size:clamp(1.7rem, 3vw, 2.7rem);
      line-height:1.3;
      font-weight:900;
    }

    .section-head p{
      margin:0 auto;
      max-width:760px;
      color:var(--muted);
      line-height:1.9;
      font-size:1.05rem;
    }

    .eyebrow{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:9px 16px;
      border-radius:999px;
      background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,240,223,.96));
      border:1px solid rgba(199,154,59,.22);
      color:var(--gold-dark);
      font-weight:800;
      font-size:.95rem;
      box-shadow:var(--shadow);
    }

    .eyebrow::before{
      content:"";
      width:8px;
      height:8px;
      border-radius:50%;
      background:linear-gradient(180deg, var(--gold), var(--gold-soft));
      box-shadow:0 0 0 5px rgba(199,154,59,.12);
      flex-shrink:0;
    }

    .gold-line{
      width:100px;
      height:4px;
      border-radius:999px;
      margin:18px auto 0;
      background:linear-gradient(90deg, transparent, var(--gold), transparent);
    }

    h1,h2,h3,h4{
      margin:0 0 12px;
      line-height:1.3;
      color:var(--text);
    }

    h1{
      font-size:clamp(2rem,4.2vw,3.8rem);
      font-weight:900;
    }

    h3{
      font-size:1.18rem;
      font-weight:800;
    }

    p{
      margin:0 0 16px;
      color:var(--muted);
      line-height:1.9;
      font-size:1rem;
    }

    ul{
      list-style:none;
      margin:0;
      padding:0;
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:8px;
      padding:13px 20px;
      min-height:50px;
      border-radius:999px;
      font-weight:800;
      cursor:pointer;
      border:none;
      transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition);
      text-align:center;
      white-space:nowrap;
      max-width:100%;
    }

    .btn:hover{
      transform:translateY(-2px);
    }

    .btn-primary{
      color:#fff;
      background:linear-gradient(135deg, #b8872e 0%, #d8b467 52%, #8f6720 100%);
      box-shadow:0 14px 28px rgba(170,122,32,.23);
    }

    .btn-primary:hover{
      box-shadow:0 18px 34px rgba(170,122,32,.30);
    }

    .btn-outline{
      background:rgba(255,255,255,.86);
      color:var(--text);
      border:1px solid rgba(199,154,59,.22);
    }

    .btn-outline:hover{
      border-color:var(--gold);
      color:var(--gold-dark);
    }

    /* Header */
    .site-header{
      position:sticky;
      top:0;
      z-index:1100;
      background:rgba(255,255,255,.92);
      backdrop-filter:blur(12px);
      border-bottom:1px solid var(--line);
      box-shadow:0 8px 24px rgba(39,24,5,.04);
    }

    .nav-wrap{
      min-height:var(--header-h);
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:14px;
      padding:12px 0;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:12px;
      min-width:0;
      flex:1 1 auto;
    }

    .brand-logo{
      width:52px;
      height:52px;
      border-radius:16px;
      display:grid;
      place-items:center;
      flex-shrink:0;
      font-weight:900;
      color:#fff;
      background:linear-gradient(145deg,#fff6e0 0%, #d0a851 45%, #936a1c 100%);
      box-shadow:0 12px 28px rgba(166,118,29,.20);
      position:relative;
      overflow:hidden;
    }

    .brand-logo::before{
      content:"";
      position:absolute;
      inset:0;
      background:linear-gradient(135deg, rgba(255,255,255,.35), transparent 40%, transparent 70%, rgba(255,255,255,.18));
    }

    .brand-text{
      min-width:0;
      line-height:1.2;
    }

    .brand-text strong{
      display:block;
      font-size:1.04rem;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }

    .brand-text span{
      display:block;
      font-size:.9rem;
      color:var(--muted);
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }

    .nav{
      display:flex;
      align-items:center;
      gap:18px;
    }

    .nav a{
      position:relative;
      font-weight:700;
      padding:8px 4px;
      transition:color var(--transition);
    }

    .nav a::after{
      content:"";
      position:absolute;
      right:0;
      bottom:0;
      width:0;
      height:2px;
      border-radius:999px;
      background:linear-gradient(90deg,var(--gold),var(--gold-soft));
      transition:width var(--transition);
    }

    .nav a:hover{
      color:var(--gold-dark);
    }

    .nav a:hover::after{
      width:100%;
    }

    .nav-actions{
      display:flex;
      align-items:center;
      gap:10px;
      flex-shrink:0;
    }

    .menu-toggle{
      display:none;
      width:46px;
      height:46px;
      border-radius:14px;
      border:1px solid rgba(0,0,0,.08);
      background:#fff;
      cursor:pointer;
      align-items:center;
      justify-content:center;
      flex-direction:column;
      gap:5px;
      padding:0;
      box-shadow:var(--shadow);
      flex-shrink:0;
    }

    .menu-toggle span{
      width:22px;
      height:2px;
      border-radius:999px;
      background:var(--text);
      transition:var(--transition);
    }

    .menu-toggle.active span:nth-child(1){
      transform:translateY(7px) rotate(45deg);
    }

    .menu-toggle.active span:nth-child(2){
      opacity:0;
    }

    .menu-toggle.active span:nth-child(3){
      transform:translateY(-7px) rotate(-45deg);
    }

    .mobile-nav{
      display:none;
      position:fixed;
      top:calc(var(--header-h) + 8px);
      right:12px;
      left:12px;
      z-index:1200;
      background:rgba(255,255,255,.98);
      border:1px solid var(--line);
      border-radius:18px;
      box-shadow:0 24px 48px rgba(0,0,0,.10);
      padding:14px;
      max-height:calc(100svh - var(--header-h) - 24px);
      overflow:auto;
    }

    .mobile-nav.active{
      display:block;
    }

    .mobile-nav a{
      display:block;
      padding:12px 10px;
      border-radius:10px;
      font-weight:700;
    }

    .mobile-nav a:hover{
      background:#faf6ed;
    }

    .mobile-actions{
      display:flex;
      gap:8px;
      margin-top:12px;
    }

    .mobile-actions .btn{
      flex:1;
    }

    /* Hero */
    .hero{
      position:relative;
      min-height:calc(100vh - var(--header-h));
      min-height:calc(100svh - var(--header-h));
      display:flex;
      align-items:center;
      overflow:hidden;
      color:#fff;
      background:
        linear-gradient(90deg, rgba(22,17,11,.86) 0%, rgba(22,17,11,.68) 42%, rgba(22,17,11,.30) 100%),
        url('images/wavey-curtains-jeddah-makkah-hero.webp') center/cover no-repeat;
    }

    .hero::before{
      content:"";
      position:absolute;
      inset:0;
      background:
        radial-gradient(circle at 12% 12%, rgba(227,194,119,.22), transparent 20%),
        radial-gradient(circle at 88% 82%, rgba(227,194,119,.14), transparent 18%);
      pointer-events:none;
    }

    .hero::after{
      content:"";
      position:absolute;
      inset:auto 0 0;
      height:120px;
      background:linear-gradient(180deg, transparent, rgba(251,250,247,.97));
      pointer-events:none;
    }

    .hero-grid{
      position:relative;
      z-index:1;
      display:grid;
      grid-template-columns:1.08fr .92fr;
      gap:28px;
      align-items:center;
      padding:64px 0 44px;
    }

    .hero-content{
      min-width:0;
      max-width:720px;
    }

    .hero .eyebrow{
      color:#fff;
      background:rgba(255,255,255,.10);
      border-color:rgba(255,255,255,.18);
      box-shadow:none;
    }

    .hero h1{
      color:#fff;
      margin:14px 0 12px;
      line-height:1.24;
    }

    .hero-sub{
      font-size:1.1rem;
      font-weight:800;
      color:#f2d48a;
      margin-bottom:12px;
    }

    .hero-content p{
      color:rgba(255,255,255,.88);
      font-size:1.05rem;
      line-height:1.95;
      max-width:62ch;
      margin:0 0 18px;
    }

    .hero-actions{
      display:flex;
      flex-wrap:wrap;
      gap:12px;
      margin-bottom:18px;
    }

    .hero-actions .btn-outline{
      background:rgba(255,255,255,.08);
      color:#fff;
      border-color:rgba(255,255,255,.24);
    }

    .hero-actions .btn-outline:hover{
      border-color:rgba(255,255,255,.42);
      color:#fff;
    }

    .hero-points{
      display:grid;
      grid-template-columns:repeat(2, minmax(0,1fr));
      gap:10px;
      margin-top:16px;
    }

    .hero-point{
      background:rgba(255,255,255,.09);
      border:1px solid rgba(255,255,255,.12);
      border-radius:14px;
      padding:12px 14px;
      font-weight:700;
      line-height:1.75;
      min-width:0;
    }

    .hero-visual{
      min-width:0;
    }

    .hero-media{
      position:relative;
      overflow:hidden;
      border-radius:28px;
      border:1px solid rgba(255,255,255,.14);
      box-shadow:0 26px 60px rgba(0,0,0,.22);
      background:rgba(255,255,255,.08);
    }

    .hero-media img{
      width:100%;
      height:100%;
      object-fit:cover;
      aspect-ratio:4/5;
    }

    .hero-overlay{
      position:absolute;
      right:14px;
      left:14px;
      bottom:14px;
      background:rgba(18,13,7,.74);
      border:1px solid rgba(255,255,255,.12);
      backdrop-filter:blur(10px);
      border-radius:16px;
      padding:14px;
      color:#fff;
    }

    .hero-overlay strong{
      display:block;
      margin-bottom:4px;
      font-size:1.02rem;
    }

    .hero-overlay span{
      display:block;
      color:rgba(255,255,255,.84);
      line-height:1.7;
      font-size:.95rem;
    }

    .hero-badge{
      margin-top:14px;
      background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.06));
      border:1px solid rgba(255,255,255,.12);
      border-radius:18px;
      padding:14px;
      color:#fff;
      backdrop-filter:blur(10px);
      box-shadow:0 16px 36px rgba(0,0,0,.12);
    }

    .hero-badge strong{
      display:block;
      margin-bottom:4px;
    }

    .hero-badge span{
      color:rgba(255,255,255,.88);
      line-height:1.7;
    }

    /* Trust */
    .trust-bar{
      position:relative;
      z-index:3;
      margin-top:-26px;
      padding:0 0 12px;
    }

    .trust-grid{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:16px;
    }

    .trust-item{
      background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,250,240,.98));
      border:1px solid var(--line);
      border-radius:20px;
      box-shadow:var(--shadow);
      padding:18px;
      display:flex;
      gap:12px;
      align-items:flex-start;
      min-width:0;
    }

    .trust-icon{
      width:46px;
      height:46px;
      border-radius:14px;
      display:grid;
      place-items:center;
      background:linear-gradient(180deg,#fff4d7,#e7c77e);
      color:var(--gold-dark);
      font-weight:900;
      flex-shrink:0;
      box-shadow:var(--shadow);
    }

    .trust-item strong{
      display:block;
      margin-bottom:4px;
    }

    .trust-item span{
      color:var(--muted);
      line-height:1.7;
      font-size:.94rem;
      display:block;
    }

    /* Common cards */
    .card{
      background:linear-gradient(180deg, rgba(255,255,255,.99), rgba(255,252,245,.98));
      border:1px solid var(--line);
      border-radius:22px;
      box-shadow:var(--shadow);
      padding:26px;
      transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
      min-width:0;
    }

    .card:hover{
      transform:translateY(-6px);
      box-shadow:0 24px 46px rgba(39,24,5,.12);
      border-color:rgba(199,154,59,.30);
    }

    .card-icon{
      width:54px;
      height:54px;
      border-radius:16px;
      display:grid;
      place-items:center;
      background:linear-gradient(180deg,#fff3d6,#e9cb84);
      color:var(--gold-dark);
      font-weight:900;
      font-size:1.15rem;
      margin-bottom:14px;
      box-shadow:var(--shadow);
    }

    .card h3{
      margin:0 0 10px;
    }

    .card p{
      margin:0;
    }

    .check-list{
      display:grid;
      gap:10px;
      margin:18px 0 0;
      padding:0;
      list-style:none;
    }

    .check-list li{
      position:relative;
      padding-right:28px;
      line-height:1.8;
      color:var(--text);
    }

    .check-list li::before{
      content:"✓";
      position:absolute;
      right:0;
      top:0;
      color:var(--gold-dark);
      font-weight:900;
    }

    /* Layout helpers */
    .split{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:30px;
      align-items:center;
    }

    .grid-3{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
    }

    .grid-4{
      display:grid;
      grid-template-columns:repeat(2,1fr);
      gap:16px;
    }

    .option-grid{
      display:grid;
      grid-template-columns:repeat(2,1fr);
      gap:18px;
    }

    .local-grid,
    .contact-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
    }

    /* Showcase */
    .showcase{
      position:relative;
      display:grid;
      grid-template-columns:1fr .72fr;
      gap:12px;
      align-items:end;
      min-width:0;
    }

    .showcase-main,
    .showcase-sub{
      overflow:hidden;
      border-radius:24px;
      box-shadow:var(--shadow-lg);
      border:1px solid rgba(255,255,255,.6);
      background:linear-gradient(180deg,#fffaf0,#efe2c5);
    }

    .showcase-main img,
    .showcase-sub img{
      width:100%;
      height:100%;
      object-fit:cover;
    }

    .showcase-main img{
      aspect-ratio:4/5;
    }

    .showcase-sub img{
      aspect-ratio:3/4;
    }

    .showcase-chip{
      position:absolute;
      right:16px;
      left:16px;
      bottom:16px;
      background:rgba(255,255,255,.95);
      border:1px solid var(--line);
      border-radius:16px;
      padding:14px;
      box-shadow:var(--shadow);
      backdrop-filter:blur(10px);
    }

    .showcase-chip strong{
      display:block;
      margin-bottom:4px;
    }

    .showcase-chip span{
      color:var(--muted);
      line-height:1.7;
      font-size:.95rem;
      display:block;
    }

    /* Tags */
    .tag-row,
    .area-tags{
      display:flex;
      flex-wrap:wrap;
      gap:8px;
      margin-top:14px;
    }

    .tag{
      padding:8px 12px;
      border-radius:999px;
      background:#faf3e3;
      color:var(--gold-dark);
      font-weight:700;
      font-size:.9rem;
      border:1px solid rgba(199,154,59,.14);
    }

    /* Steps */
    .steps{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:18px;
    }

    .step{
      background:linear-gradient(180deg, rgba(255,255,255,.99), rgba(255,252,245,.98));
      border:1px solid var(--line);
      border-radius:20px;
      box-shadow:var(--shadow);
      padding:22px;
      min-width:0;
    }

    .step-number{
      width:52px;
      height:52px;
      border-radius:16px;
      display:grid;
      place-items:center;
      font-weight:900;
      font-size:1.15rem;
      color:#fff;
      background:linear-gradient(135deg,var(--gold-dark),#d8b467);
      margin-bottom:14px;
      box-shadow:0 12px 24px rgba(170,122,32,.24);
    }

    .step h3{
      margin:0 0 8px;
    }

    .step p{
      margin:0;
    }

    /* Gallery */
    .gallery-grid{
      display:grid;
      grid-template-columns:repeat(12,1fr);
      gap:18px;
    }

    .gallery-item{
      grid-column:span 4;
      position:relative;
      overflow:hidden;
      border-radius:24px;
      box-shadow:var(--shadow-lg);
      border:1px solid rgba(199,154,59,.18);
      min-width:0;
      background:linear-gradient(180deg,#fff8eb,#ead7aa);
    }

    .gallery-item.large{
      grid-column:span 8;
    }

    .gallery-item img{
      width:100%;
      height:100%;
      object-fit:cover;
      transition:transform .35s ease;
    }

    .gallery-item:hover img{
      transform:scale(1.04);
    }

    .gallery-caption{
      position:absolute;
      right:12px;
      left:12px;
      bottom:12px;
      background:rgba(18,13,7,.72);
      color:#fff;
      border-radius:14px;
      padding:12px;
      backdrop-filter:blur(10px);
    }

    .gallery-caption strong{
      display:block;
      margin-bottom:4px;
    }

    .gallery-caption span{
      display:block;
      color:rgba(255,255,255,.84);
      font-size:.92rem;
      line-height:1.6;
    }

    /* FAQ */
    .faq{
      display:grid;
      gap:14px;
      max-width:920px;
      margin-inline:auto;
    }

    .faq-item{
      background:#fff;
      border:1px solid var(--line);
      border-radius:16px;
      padding:0 18px;
      box-shadow:var(--shadow);
      overflow:hidden;
    }

    .faq-item summary{
      list-style:none;
      cursor:pointer;
      padding:18px 0;
      font-weight:800;
      position:relative;
      padding-left:28px;
    }

    .faq-item summary::-webkit-details-marker{
      display:none;
    }

    .faq-item summary::before{
      content:"+";
      position:absolute;
      left:0;
      top:50%;
      transform:translateY(-50%);
      color:var(--gold-dark);
      font-size:1.35rem;
      font-weight:900;
      transition:var(--transition);
    }

    .faq-item[open] summary::before{
      content:"−";
    }

    .faq-item p{
      margin:0;
      padding:0 0 18px;
      color:var(--muted);
      line-height:1.9;
    }

    /* CTA */
    .cta{
      background:
        radial-gradient(circle at top left, rgba(255,255,255,.08), transparent 26%),
        linear-gradient(135deg,#1a130b,#2a1d10 55%, #3b2a14 100%);
      color:#fff;
      border-radius:30px;
      padding:34px;
      box-shadow:0 24px 54px rgba(0,0,0,.16);
      overflow:hidden;
      position:relative;
    }

    .cta-grid{
      display:grid;
      grid-template-columns:1.2fr .8fr;
      gap:20px;
      align-items:center;
      position:relative;
      z-index:1;
    }

    .cta h2{
      color:#fff;
      margin:0 0 10px;
      font-size:clamp(1.6rem, 3vw, 2.2rem);
      line-height:1.3;
    }

    .cta p{
      color:rgba(255,255,255,.88);
      margin:0;
    }

    .cta-actions{
      display:flex;
      flex-wrap:wrap;
      gap:10px;
      justify-content:flex-start;
    }

    .cta .btn-outline{
      background:rgba(255,255,255,.08);
      color:#fff;
      border-color:rgba(255,255,255,.22);
    }

    .cta .btn-outline:hover{
      border-color:rgba(255,255,255,.38);
      color:#fff;
    }

    /* Contact */
    .contact-card{
      text-align:center;
    }

    .contact-card .card-icon{
      margin-inline:auto;
    }

    .contact-card p{
      margin-top:8px;
      font-size:1rem;
    }

    /* Footer */
    .site-footer{
      background:linear-gradient(180deg,#1d140a,#120d07);
      color:#fff;
      padding:64px 0 26px;
      margin-top:44px;
      position:relative;
      overflow:hidden;
    }

    .site-footer::before{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      background:radial-gradient(circle at top right, rgba(227,194,119,.12), transparent 22%);
    }

    .footer-grid{
      display:grid;
      grid-template-columns:1.3fr 1fr 1fr 1fr;
      gap:24px;
      position:relative;
      z-index:1;
    }

    .footer-brand h2,
    .footer-col h3{
      margin:0 0 14px;
      color:#fff;
    }

    .footer-brand p,
    .footer-links a,
    .footer-links p{
      color:rgba(255,255,255,.78);
      line-height:1.9;
      margin:0;
    }

    .footer-links{
      display:grid;
      gap:10px;
    }

    .footer-links a:hover{
      color:#fff;
    }

    .footer-bottom{
      border-top:1px solid rgba(255,255,255,.08);
      margin-top:24px;
      padding-top:18px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      flex-wrap:wrap;
      position:relative;
      z-index:1;
    }

    .footer-bottom p{
      margin:0;
      color:rgba(255,255,255,.65);
      line-height:1.7;
      font-size:.95rem;
    }

    /* Floating actions */
    .floating-actions{
      position:fixed;
      left:16px;
      bottom:16px;
      z-index:1001;
      display:flex;
      flex-direction:column;
      gap:10px;
    }

    .float-btn{
      width:56px;
      height:56px;
      border-radius:999px;
      display:grid;
      place-items:center;
      box-shadow:0 14px 26px rgba(0,0,0,.18);
      transition:transform var(--transition), box-shadow var(--transition);
    }

    .float-btn:hover{
      transform:translateY(-2px);
      box-shadow:0 18px 30px rgba(0,0,0,.22);
    }

    .float-btn svg{
      width:24px;
      height:24px;
      fill:#fff;
    }

    .float-whatsapp{
      background:#25D366;
    }

    .float-call{
      background:linear-gradient(135deg,#b8872e,#8d6821);
    }

    /* Reveal */
    .reveal{
      opacity:0;
      transform:translateY(20px);
      transition:opacity .6s ease, transform .6s ease;
    }

    .reveal.visible{
      opacity:1;
      transform:none;
    }

    /* Responsive */
    @media (max-width:1100px){
      .hero-grid,
      .split,
      .cta-grid{
        grid-template-columns:1fr;
      }

      .trust-grid{
        grid-template-columns:repeat(2,1fr);
      }

      .grid-3{
        grid-template-columns:1fr 1fr;
      }

      .steps{
        grid-template-columns:1fr 1fr;
      }

      .footer-grid{
        grid-template-columns:1fr 1fr;
      }

      .hero{
        min-height:auto;
        padding:22px 0 0;
      }
    }

    @media (max-width:920px){
      :root{
        --header-h:74px;
      }

      .nav{
        display:none;
      }

      .menu-toggle{
        display:flex;
      }

      .nav-actions .btn-outline,
      .nav-actions .btn-primary{
        display:none;
      }

      .hero{
        min-height:auto;
      }

      .hero-grid{
        grid-template-columns:1fr;
        gap:24px;
        padding:42px 0 34px;
      }

      .hero-points{
        grid-template-columns:1fr;
      }

      .option-grid,
      .local-grid,
      .contact-grid,
      .grid-4{
        grid-template-columns:1fr;
      }

      .gallery-item.large,
      .gallery-item{
        grid-column:span 12;
      }

      .showcase{
        grid-template-columns:1fr;
      }

      .showcase-chip{
        position:static;
        margin-top:12px;
      }
    }

    @media (max-width:640px){
      .section{
        padding:56px 0;
      }

      .container{
        width:min(100% - 24px, var(--container));
      }

      .brand{
        max-width:calc(100% - 58px);
      }

      .brand-logo{
        width:44px;
        height:44px;
        border-radius:12px;
      }

      .brand-text strong{
        font-size:.96rem;
      }

      .brand-text span{
        font-size:.82rem;
      }

      h1{
        font-size:clamp(1.8rem, 8vw, 2.4rem);
      }

      .hero{
        background-position:center;
      }

      .hero-content p,
      .section-head p,
      .card p,
      .step p,
      .faq-item p,
      .footer-brand p{
        font-size:.98rem;
      }

      .hero-actions,
      .cta-actions{
        flex-direction:column;
      }

      .hero-actions .btn,
      .cta-actions .btn,
      .mobile-actions .btn{
        width:100%;
      }

      .trust-grid,
      .grid-3,
      .steps,
      .footer-grid{
        grid-template-columns:1fr;
      }

      .cta{
        padding:26px 18px;
        border-radius:24px;
      }

      .footer-bottom{
        flex-direction:column;
        align-items:flex-start;
      }

      .floating-actions{
        left:12px;
        bottom:12px;
      }

      .float-btn{
        width:52px;
        height:52px;
      }
    }

    @media (max-width:420px){
      .eyebrow{
        font-size:.82rem;
        padding:8px 12px;
      }

      .section-head{
        margin-bottom:26px;
      }

      .card,
      .step{
        padding:22px;
      }

      .mobile-nav{
        right:10px;
        left:10px;
      }
    }
    .video-wrap {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: 24px;
  background: #000;
}

.video-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}


.hero-media img,
.hero-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.hero-media {
  width: 100%;
  overflow: hidden;
  border-radius: 24px;
}

.hero-visual,
.hero-content {
  min-width: 0;
}
