/* ============================================================
   GCT Grand Agadir - Portal skin based on Civica template
   ============================================================ */
:root{
    --primary-color:#082B61;
    --secondary-color:#F4F8FC;
    --bg-color:#FFFFFF;
    --text-color:#5D6F86;
    --accent-color:#0B4EA2;
    --accent-secondary-color:#F6A313;
    --gct-sky:#19A6D2;
    --gct-green:#16A34A;
    --gct-red:#DC2626;
    --gct-ink:#071B3B;
    --gct-soft:#EAF3FF;
    --gct-border:rgba(8,43,97,.12);
    --gct-shadow:0 22px 70px rgba(8,43,97,.11);
    --gct-shadow-sm:0 12px 34px rgba(8,43,97,.09);
}

html{scroll-behavior:smooth;}
body.gct-portal{
    background:#fff;
    color:var(--text-color);
}
body.gct-portal.no-scroll{overflow:hidden;}

body.gct-portal .preloader #loading-icon img{max-width:74px;}
body.gct-portal .preloader{background:#fff;}

/* Header */
body.gct-portal header.main-header.gct-main-header{
    position:sticky;
    top:0;
    left:auto;
    right:auto;
    z-index:999;
    border-bottom:0;
    background:#fff;
    box-shadow:0 12px 35px rgba(8,43,97,.07);
}
body.gct-portal .gct-topbar{
    background:linear-gradient(90deg,#061f48,#082b61 45%,#0b4ea2);
    color:#dbeafe;
    font-size:13px;
    min-height:40px;
    display:flex;
    align-items:center;
    border-bottom:1px solid rgba(255,255,255,.09);
}
.gct-topbar .container{display:flex;justify-content:space-between;align-items:center;gap:20px;}
.gct-topbar__left,.gct-topbar__right{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.gct-topbar a{color:#fff;text-decoration:none;transition:.25s ease;}
.gct-topbar a:hover{color:var(--accent-secondary-color);}
.gct-topbar i{color:var(--accent-secondary-color);margin-right:6px;}
.gct-lang{display:flex;align-items:center;background:rgba(255,255,255,.08);padding:4px;border-radius:100px;gap:2px;}
.gct-lang a{font-size:12px;padding:4px 10px;border-radius:100px;line-height:1;color:#dbeafe;}
.gct-lang a.active,.gct-lang a:hover{background:#fff;color:var(--primary-color);}
body.gct-portal header.main-header .header-sticky,
body.gct-portal header.main-header .header-sticky.active{
    position:relative !important;
    top:auto !important;
    left:auto;
    right:auto;
    transform:none !important;
    background:#fff;
    border-bottom:0;
}
body.gct-portal .navbar{padding:14px 0;}
body.gct-portal .navbar-brand img{width:238px;max-height:66px;object-fit:contain;}
body.gct-portal .main-menu .nav-menu-wrapper{text-align:right;margin:0 18px;}
body.gct-portal .main-menu ul li{margin:0 3px;}
body.gct-portal .main-menu ul li a{
    color:#1d3355;
    font-weight:700;
    font-size:14px;
    border-radius:999px;
    padding:11px 12px !important;
    text-transform:none;
}
body.gct-portal .main-menu ul li a:hover,
body.gct-portal .main-menu ul li a:focus,
body.gct-portal .main-menu ul li a.active{color:#fff;background:var(--accent-color);}
body.gct-portal .main-menu ul li.submenu > a:after{margin-left:7px;font-size:12px;}
body.gct-portal .main-menu ul ul{
    background:#fff;
    box-shadow:var(--gct-shadow-sm);
    border:1px solid var(--gct-border);
    width:260px;
    border-radius:18px;
    padding:10px !important;
}
body.gct-portal .main-menu ul ul li a{
    color:#254061;
    border-radius:12px;
    padding:10px 14px !important;
}
body.gct-portal .main-menu ul ul li a:hover{padding:10px 14px !important;color:#fff;background:var(--accent-color);}
body.gct-portal .header-btn{display:flex;align-items:center;gap:10px;}
body.gct-portal .gct-icon-btn{
    width:46px;height:46px;border:1px solid var(--gct-border);border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--primary-color);
    transition:.25s ease;box-shadow:0 8px 18px rgba(8,43,97,.06);
}
body.gct-portal .gct-icon-btn:hover{background:var(--accent-secondary-color);color:#071B3B;transform:translateY(-2px);}
body.gct-portal .btn-default{
    border-radius:999px;
    padding:15px 22px;
    font-weight:800;
    letter-spacing:-.01em;
    background:linear-gradient(135deg,var(--accent-color),#0E6BCA);
}
/* body.gct-portal .btn-default:before{background:var(--accent-secondary-color);}
body.gct-portal .btn-default.btn-highlighted:hover{color:var(--primary-color);}
body.gct-portal .btn-default.btn-highlighted:hover:before{background:var(--accent-secondary-color);}
body.gct-portal .btn-default.btn-secondary-gct{background:var(--accent-secondary-color);color:var(--primary-color);}
body.gct-portal .btn-default.btn-secondary-gct:before{background:#fff;} */

/* Search overlay */
.gct-search-overlay{position:fixed;inset:0;background:rgba(7,27,59,.68);backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:center;padding-top:150px;z-index:1200;}
.gct-search-overlay.is-open{display:flex;}
.gct-search-box{width:min(760px,92vw);background:#fff;border-radius:28px;padding:20px;box-shadow:0 30px 90px rgba(0,0,0,.25);}
.gct-search-box form{display:flex;gap:10px;}
.gct-search-box input{height:58px;border:1px solid var(--gct-border);border-radius:18px;padding:0 18px;flex:1;color:var(--primary-color);font-weight:700;outline:none;}
.gct-search-box button{border:0;border-radius:18px;background:var(--accent-color);color:#fff;padding:0 22px;font-weight:800;}
.gct-search-close{position:absolute;top:40px;right:40px;width:48px;height:48px;border:0;border-radius:50%;background:#fff;color:var(--primary-color);font-size:20px;}

/* Generic sections */
.gct-section{padding:100px 0;position:relative;overflow:hidden;}
.gct-section--soft{background:linear-gradient(180deg,#f7fbff,#fff);}
.gct-section--blue{background:linear-gradient(135deg,#061f48,#0b4ea2);color:#fff;}
.gct-section .section-title h2{letter-spacing:-.04em;}
.gct-kicker{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:#EAF3FF;color:var(--accent-color);border-radius:999px;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;}
.gct-kicker:before{content:"";width:9px;height:9px;border-radius:50%;background:var(--accent-secondary-color);box-shadow:0 0 0 5px rgba(246,163,19,.16);}
.gct-muted{color:var(--text-color);}
.gct-white-muted{color:rgba(255,255,255,.75);}
.gct-card{background:#fff;border:1px solid var(--gct-border);border-radius:28px;box-shadow:var(--gct-shadow-sm);transition:.3s ease;}
.gct-card:hover{transform:translateY(-6px);box-shadow:var(--gct-shadow);}
.gct-mini-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent-color);font-weight:900;text-decoration:none;}
.gct-mini-link i{transition:.25s ease;}
.gct-mini-link:hover i{transform:translateX(4px);}

/* Hero */
.gct-hero{
    min-height:720px;
    display:flex;
    align-items:center;
    padding:95px 0 90px;
    background:
        radial-gradient(circle at 74% 15%, rgba(25,166,210,.28), transparent 28%),
        radial-gradient(circle at 18% 12%, rgba(246,163,19,.18), transparent 24%),
        linear-gradient(135deg,#061B3E 0%,#082B61 46%,#0B4EA2 100%);
    position:relative;
    overflow:hidden;
    color:#fff;
}
.gct-hero:before{content:"";position:absolute;inset:auto -7% -22% -8%;height:320px;background:rgba(255,255,255,.08);border-radius:50% 50% 0 0;transform:rotate(-3deg);}
.gct-hero:after{content:"";position:absolute;right:4%;top:12%;width:420px;height:420px;border:1px solid rgba(255,255,255,.12);border-radius:50%;}
.gct-hero .container{position:relative;z-index:1;}
.gct-hero h1{font-size:clamp(44px,6vw,78px);line-height:.96;letter-spacing:-.06em;color:#fff;margin-bottom:22px;}
.gct-hero p{font-size:18px;line-height:1.7;max-width:660px;color:rgba(255,255,255,.82);}
.gct-hero-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:30px;}
.gct-hero-trust{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-top:30px;}
.gct-trust-item{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:9px 14px;color:#fff;font-weight:800;font-size:13px;}
.gct-trust-item i{color:var(--accent-secondary-color);}
.gct-journey-panel{background:#fff;color:var(--primary-color);border-radius:34px;padding:22px;box-shadow:0 30px 100px rgba(0,0,0,.28);position:relative;}
.gct-journey-panel:before{content:"";position:absolute;right:28px;top:-18px;width:72px;height:72px;border-radius:24px;background:var(--accent-secondary-color);opacity:.96;z-index:-1;transform:rotate(12deg);}
.gct-panel-title{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;}
.gct-panel-title h3{font-size:24px;margin:0;color:var(--primary-color);letter-spacing:-.03em;}
.gct-panel-title span{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:16px;background:#EAF3FF;color:var(--accent-color);}
.gct-route-form{display:grid;gap:12px;}
.gct-input-group{position:relative;}
.gct-input-group i{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--accent-color);z-index:1;}
.gct-input-group input,.gct-input-group select,.gct-input-group textarea{
    width:100%;height:56px;border:1px solid var(--gct-border);background:#F8FBFF;border-radius:18px;padding:0 16px 0 48px;font-weight:700;color:#123;outline:none;transition:.25s ease;
}
.gct-input-group textarea{height:160px;padding-top:18px;resize:vertical;}
.gct-input-group input:focus,.gct-input-group select:focus,.gct-input-group textarea:focus{border-color:#0B4EA2;box-shadow:0 0 0 4px rgba(11,78,162,.08);background:#fff;}
.gct-route-form .btn-default{border:0;width:100%;margin-top:4px;}
.gct-route-result{display:none;margin-top:14px;border-radius:20px;background:#F0F7FF;padding:14px;color:#254061;font-weight:700;font-size:14px;}
.gct-route-result.is-visible{display:block;}
.gct-hero-map{margin-top:18px;border-radius:26px;background:#EEF6FF;overflow:hidden;border:1px solid var(--gct-border);}
.gct-hero-map img{width:100%;display:block;}

/* Access cards */
.gct-access-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.gct-access-card{padding:26px;min-height:185px;position:relative;overflow:hidden;}
.gct-access-card:before{content:"";position:absolute;right:-40px;bottom:-55px;width:140px;height:140px;background:rgba(25,166,210,.12);border-radius:50%;transition:.35s ease;}
.gct-access-card:hover:before{transform:scale(1.28);background:rgba(246,163,19,.18);}
.gct-access-card .icon-box{width:58px;height:58px;border-radius:20px;background:#EAF3FF;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px;}
.gct-access-card h3{font-size:20px;margin-bottom:10px;color:var(--primary-color);}
.gct-access-card p{font-size:14px;line-height:1.55;margin-bottom:0;}

/* News */
.gct-news-grid{display:grid;grid-template-columns:1.1fr .9fr .9fr;gap:22px;}
.gct-news-card{overflow:hidden;}
.gct-news-card .gct-news-img{height:230px;background:linear-gradient(135deg,#EAF3FF,#DDF0FF);position:relative;overflow:hidden;}
.gct-news-card .gct-news-img img{width:100%;height:100%;object-fit:cover;transition:.35s ease;}
.gct-news-card:hover .gct-news-img img{transform:scale(1.06);}
.gct-news-card .gct-news-body{padding:24px;}
.gct-news-date{display:inline-flex;align-items:center;gap:8px;color:var(--accent-color);font-size:13px;font-weight:900;margin-bottom:10px;}
.gct-news-card h3{font-size:22px;color:var(--primary-color);line-height:1.2;margin-bottom:12px;}
.gct-news-card.featured .gct-news-img{height:340px;}

/* Indicators */
.gct-indicators{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.gct-indicator{padding:28px;border-radius:28px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);}
.gct-indicator .num{font-size:46px;font-weight:900;letter-spacing:-.05em;color:#fff;line-height:1;}
.gct-indicator .label{color:rgba(255,255,255,.76);font-weight:700;margin-top:8px;}
.gct-indicator i{color:var(--accent-secondary-color);font-size:28px;margin-bottom:18px;}

/* Inner hero */
.gct-page-hero{padding:86px 0;background:linear-gradient(135deg,#061f48,#0b4ea2);position:relative;overflow:hidden;color:#fff;}
.gct-page-hero:after{content:"";position:absolute;right:-100px;top:-170px;width:470px;height:470px;border-radius:50%;background:rgba(25,166,210,.22);}
.gct-page-hero .container{position:relative;z-index:1;}
.gct-breadcrumb{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:rgba(255,255,255,.78);font-weight:800;margin-bottom:18px;}
.gct-breadcrumb a{color:#fff;text-decoration:none;}
.gct-breadcrumb i{font-size:10px;color:var(--accent-secondary-color);}
.gct-page-hero h1{font-size:clamp(38px,5vw,64px);line-height:1;letter-spacing:-.055em;color:#fff;margin-bottom:16px;}
.gct-page-hero p{color:rgba(255,255,255,.8);font-size:18px;max-width:720px;line-height:1.65;margin:0;}

/* Se deplacer */
.gct-map-card{padding:16px;overflow:hidden;}
.gct-map-card img{width:100%;border-radius:24px;display:block;}
.gct-filter-box{padding:24px;position:sticky;top:132px;}
.gct-filter-box h3{color:var(--primary-color);font-size:22px;margin-bottom:18px;}
.gct-checkbox-list{display:grid;gap:10px;margin-bottom:18px;}
.gct-checkbox{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#F8FBFF;border-radius:12px;color:#334;font-weight:700;font-size:14px;}
.gct-checkbox input{accent-color:var(--accent-color);}
.gct-itinerary-list{display:grid;gap:14px;}
.gct-itinerary-card{display:flex;align-items:center;gap:16px;padding:18px;border-radius:22px;background:#fff;border:1px solid var(--gct-border);box-shadow:0 8px 24px rgba(8,43,97,.05);}
.gct-itinerary-icon{width:54px;height:54px;border-radius:18px;background:#EAF3FF;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:22px;flex:0 0 auto;}
.gct-itinerary-card h4{font-size:18px;color:var(--primary-color);margin:0 0 4px;}
.gct-itinerary-card p{margin:0;font-size:14px;}
.gct-itinerary-card .time{margin-left:auto;font-weight:900;color:var(--accent-secondary-color);white-space:nowrap;}

/* Traffic */
.gct-alert-list{display:grid;gap:14px;}
.gct-alert{display:flex;align-items:flex-start;gap:16px;padding:18px;border-radius:22px;background:#fff;border:1px solid var(--gct-border);box-shadow:0 8px 24px rgba(8,43,97,.05);}
.gct-alert-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.gct-alert.danger .gct-alert-icon{background:#FEE2E2;color:var(--gct-red);}
.gct-alert.warning .gct-alert-icon{background:#FEF3C7;color:#B45309;}
.gct-alert.info .gct-alert-icon{background:#DBEAFE;color:var(--accent-color);}
.gct-alert h4{font-size:18px;color:var(--primary-color);margin:0 0 5px;}
.gct-alert p{margin:0;font-size:14px;line-height:1.5;}
.gct-legend{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;}
.gct-legend span{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--gct-border);border-radius:16px;padding:12px;font-weight:800;color:#334;font-size:13px;}
.gct-dot{width:11px;height:11px;border-radius:50%;display:inline-block;}
.gct-dot.normal{background:var(--gct-green);}.gct-dot.slow{background:var(--accent-secondary-color);}.gct-dot.blocked{background:var(--gct-red);}

/* Services */
.gct-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.gct-service-card{padding:28px;min-height:230px;display:flex;flex-direction:column;align-items:flex-start;}
.gct-service-card .icon-box{width:66px;height:66px;border-radius:22px;background:#EAF3FF;color:var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:20px;}
.gct-service-card h3{font-size:21px;color:var(--primary-color);line-height:1.25;margin-bottom:12px;}
.gct-service-card p{font-size:14px;line-height:1.6;margin-bottom:20px;}
.gct-service-card .gct-mini-link{margin-top:auto;}
.gct-why-box{padding:32px;border-radius:30px;background:linear-gradient(135deg,#EAF3FF,#FFFFFF);border:1px solid var(--gct-border);}
.gct-check-list{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.gct-check-list li{display:flex;gap:12px;align-items:flex-start;color:#254061;font-weight:700;}
.gct-check-list i{color:var(--gct-green);margin-top:4px;}

/* Sustainable */
.gct-engagement-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.gct-engagement-card{text-align:center;padding:28px 18px;}
.gct-engagement-card .icon-box{margin:0 auto 18px;width:62px;height:62px;border-radius:22px;background:#ECFDF5;color:var(--gct-green);display:flex;align-items:center;justify-content:center;font-size:26px;}
.gct-engagement-card h3{font-size:18px;color:var(--primary-color);margin-bottom:8px;}
.gct-project-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.gct-project-card{padding:20px;}
.gct-project-card .visual{height:150px;border-radius:22px;background:linear-gradient(135deg,#DDF0FF,#EAF3FF);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--accent-color);font-size:42px;}
.gct-project-card h3{font-size:20px;color:var(--primary-color);}

/* Reclamation */
.gct-form-card{padding:30px;}
.gct-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.gct-form-grid .full{grid-column:1/-1;}
.gct-file-field{height:58px;border:1px dashed rgba(8,43,97,.24);border-radius:18px;background:#F8FBFF;display:flex;align-items:center;padding:0 18px;gap:12px;color:#254061;font-weight:800;}
.gct-form-note{font-size:13px;color:#6b7280;margin-top:10px;}
.gct-success-message{display:none;margin-top:16px;padding:14px 16px;border-radius:16px;background:#ECFDF5;color:#166534;font-weight:800;}
.gct-success-message.is-visible{display:block;}
.gct-contact-card{padding:24px;display:flex;gap:14px;align-items:flex-start;}
.gct-contact-card .icon-box{width:48px;height:48px;border-radius:16px;background:#EAF3FF;color:var(--accent-color);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.gct-contact-card h3{font-size:18px;color:var(--primary-color);margin:0 0 4px;}
.gct-contact-card p{margin:0;font-size:14px;}

/* Partners */
.gct-partners{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.gct-partner{height:86px;border-radius:22px;background:#fff;border:1px solid var(--gct-border);display:flex;align-items:center;justify-content:center;color:#254061;font-weight:900;text-align:center;padding:12px;box-shadow:0 8px 24px rgba(8,43,97,.05);}

/* Footer */
body.gct-portal footer.main-footer{background:#061f48 url('../images/footer-bg-image-metal.jpg') center/cover no-repeat;position:relative;overflow:hidden;}
body.gct-portal footer.main-footer:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,31,72,.96),rgba(8,43,97,.93));}
body.gct-portal footer.main-footer .container{position:relative;z-index:1;}
.gct-footer{padding:80px 0 28px;color:#fff;}
.gct-footer-top{display:grid;grid-template-columns:1.2fr .8fr .8fr 1fr;gap:34px;margin-bottom:50px;}
.gct-footer-logo{width:230px;margin-bottom:18px;}
.gct-footer h3{font-size:19px;color:#fff;margin-bottom:18px;}
.gct-footer p{color:rgba(255,255,255,.72);line-height:1.7;}
.gct-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.gct-footer a{color:rgba(255,255,255,.78);text-decoration:none;font-weight:700;transition:.25s ease;}
.gct-footer a:hover{color:var(--accent-secondary-color);padding-left:4px;}
.gct-footer-contact{
    margin-top:14px!important;
    padding-top:16px!important;
    border-top:1px solid rgba(255,255,255,.14);
    gap:12px!important;
}
.gct-footer-contact li{
    display:flex;
    align-items:flex-start;
    gap:12px;
    color:rgba(255,255,255,.78);
    font-weight:650;
    line-height:1.45;
}
.gct-footer-contact i{
    width:24px;
    height:24px;
    margin-top:1px;
    border-radius:8px;
    background:rgba(246,163,19,.14);
    color:var(--accent-secondary-color);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex:0 0 24px;
    font-size:13px;
}
.gct-footer-contact span{min-width:0;}
.gct-footer-bottom{display:flex;justify-content:space-between;gap:20px;align-items:center;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;color:rgba(255,255,255,.68);font-size:14px;}
.gct-social{display:flex!important;grid-template-columns:none!important;gap:8px!important;}
.gct-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;padding:0!important;}
.gct-social a:hover{background:var(--accent-secondary-color);color:#071B3B;}

/* Chatbot */
.gct-chatbot{position:fixed;right:22px;bottom:22px;z-index:1000;}
.gct-chatbot button{width:66px;height:66px;border:0;border-radius:50%;background:linear-gradient(135deg,var(--accent-secondary-color),#FFCB4C);color:var(--primary-color);box-shadow:0 18px 50px rgba(246,163,19,.38);font-size:26px;display:flex;align-items:center;justify-content:center;}
.gct-chatbot span{position:absolute;right:72px;top:14px;white-space:nowrap;background:#fff;color:var(--primary-color);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900;box-shadow:0 8px 24px rgba(8,43,97,.12);}

@media (max-width:1199px){
    body.gct-portal .main-menu ul li a{font-size:13px;padding:10px 8px!important;}
    body.gct-portal .navbar-brand img{width:210px;}
    .gct-access-grid,.gct-engagement-grid,.gct-indicators{grid-template-columns:repeat(2,1fr);}
    .gct-services-grid,.gct-project-row,.gct-news-grid{grid-template-columns:repeat(2,1fr);}
    .gct-footer-top{grid-template-columns:1fr 1fr;}
}

@media (max-width:991px){
    body.gct-portal .gct-topbar{display:none;}
    body.gct-portal .navbar{padding:12px 0;}
    body.gct-portal .navbar-brand img{width:205px;}
    body.gct-portal .header-btn{display:none;}
    body.gct-portal .responsive-menu{display:block;}
    body.gct-portal .navbar-toggle{display:block;}
    body.gct-portal .slicknav_menu{background:#fff;box-shadow:var(--gct-shadow-sm);border-radius:0 0 24px 24px;left:0;top:100%;}
    body.gct-portal .slicknav_nav li a{color:#1d3355!important;font-weight:800;border-radius:12px;margin:3px 10px;}
    body.gct-portal .slicknav_nav li a:hover{background:#EAF3FF;color:var(--accent-color)!important;}
    body.gct-portal .slicknav_btn{background:var(--accent-color);}
    body.gct-portal .slicknav_icon .slicknav_icon-bar{background:#fff;}
    .gct-hero{min-height:auto;padding:70px 0;}
    .gct-journey-panel{margin-top:34px;}
    .gct-filter-box{position:relative;top:auto;margin-bottom:20px;}
    .gct-page-hero{padding:62px 0;}
}

@media (max-width:767px){
    .gct-section{padding:68px 0;}
    .gct-hero h1,.gct-page-hero h1{letter-spacing:-.04em;}
    .gct-hero p,.gct-page-hero p{font-size:16px;}
    .gct-access-grid,.gct-engagement-grid,.gct-indicators,.gct-services-grid,.gct-project-row,.gct-news-grid,.gct-partners{grid-template-columns:1fr;}
    .gct-news-card.featured .gct-news-img,.gct-news-card .gct-news-img{height:230px;}
    .gct-form-grid{grid-template-columns:1fr;}
    .gct-form-grid .full{grid-column:auto;}
    .gct-legend{grid-template-columns:1fr;}
    .gct-itinerary-card{align-items:flex-start;}
    .gct-itinerary-card .time{margin-left:0;}
    .gct-footer-top{grid-template-columns:1fr;gap:26px;}
    .gct-footer-bottom{flex-direction:column;text-align:center;}
    .gct-chatbot span{display:none;}
    .gct-chatbot button{width:58px;height:58px;}
}

@media (max-width:575px){
    body.gct-portal .navbar-brand img{width:180px;}
    .gct-hero{padding:55px 0;}
    .gct-journey-panel,.gct-card,.gct-form-card{border-radius:24px;}
    .gct-journey-panel{padding:18px;}
    .gct-hero-actions .btn-default{width:100%;justify-content:center;text-align:center;}
    .gct-panel-title h3{font-size:21px;}
    .gct-search-box form{flex-direction:column;}
    .gct-search-box button{height:52px;}
}


/* ============================================================
   V2 FIX - isolated header, real Agadir maps, safer responsive
   ============================================================ */
body.gct-portal{
    font-family:'Inter Tight', Arial, sans-serif;
    overflow-x:hidden;
}
body.gct-portal.gct-menu-open{overflow:hidden;}
body.gct-portal a{text-decoration:none;}

/* Hide possible legacy mobile menu generated by the template */
body.gct-portal .responsive-menu,
body.gct-portal .navbar-toggle,
body.gct-portal .slicknav_menu{display:none !important;}

/* New isolated header */
.gct-site-header{
    position:sticky;
    top:0;
    z-index:1000;
    width:100%;
    background:#fff;
    box-shadow:0 18px 44px rgba(8,43,97,.10);
}
.gct-top-strip{
    background:linear-gradient(90deg,#061f48 0%,#082b61 48%,#0b4ea2 100%);
    color:#dbeafe;
    font-size:13px;
    line-height:1.2;
}
.gct-top-strip .container{
    min-height:38px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
}
.gct-top-strip__left,
.gct-top-strip__right{
    display:flex;
    align-items:center;
    gap:16px;
    flex-wrap:wrap;
}
.gct-top-strip a,
.gct-top-strip span{color:#eef6ff;}
.gct-top-strip i{color:var(--accent-secondary-color);margin-right:6px;}
.gct-alert-link{
    font-weight:800;
    padding:7px 12px;
    border-radius:999px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
}
.gct-alert-link:hover{color:var(--accent-secondary-color);}
.gct-navbar-wrap{
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(14px);
}
.gct-navbar{
    min-height:86px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
}
.gct-brand{
    display:flex;
    align-items:center;
    gap:12px;
    flex:0 0 auto;
    min-width:250px;
    color:var(--primary-color);
}
.gct-brand img{
    width:150px;
    max-height:64px;
    object-fit:contain;
    display:block;
}
.gct-brand-copy{display:flex;flex-direction:column;line-height:1.08;}
.gct-brand-copy strong{font-size:15px;color:var(--primary-color);letter-spacing:-.02em;}
.gct-brand-copy small{font-size:12px;color:#5d6f86;font-weight:800;margin-top:3px;}
.gct-desktop-nav{flex:1;display:flex;justify-content:center;min-width:0;}
.gct-desktop-nav ul{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:3px;
    padding:0;
    margin:0;
    list-style:none;
    flex-wrap:nowrap;
}
.gct-desktop-nav li{position:relative;}
.gct-desktop-nav a{
    display:inline-flex;
    align-items:center;
    gap:7px;
    color:#1d3355;
    font-weight:850;
    font-size:14px;
    line-height:1;
    padding:12px 10px;
    border-radius:999px;
    transition:all .22s ease;
    white-space:nowrap;
}
.gct-desktop-nav a:hover,
.gct-desktop-nav a.active,
.gct-desktop-nav .gct-has-dropdown:hover > a{
    background:linear-gradient(135deg,var(--accent-color),#0e6bca);
    color:#fff;
    box-shadow:0 10px 22px rgba(11,78,162,.20);
}
.gct-desktop-nav a i{font-size:11px;transition:transform .22s ease;}
.gct-desktop-nav .gct-has-dropdown:hover > a i{transform:rotate(180deg);}
/* FIX GCT dropdown menu */
.gct-has-dropdown {
    position: relative;
}

/* invisible bridge to avoid hover cut between button and dropdown */
.gct-has-dropdown::after {
    content: "";
    position: absolute;
    left: 0;
    top: 100%;
    width: 100%;
    height: 18px;
    background: transparent;
}

.gct-dropdown {
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    min-width: 245px;
    padding: 12px;
    border-radius: 22px;
    background: #ffffff;
    border: 1px solid rgba(25, 68, 63, 0.12);
    box-shadow: 0 18px 45px rgba(6, 32, 67, 0.18);
    opacity: 0;
    visibility: hidden;
    transform: translateY(12px);
    transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
    z-index: 99999;

    display: flex;
    flex-direction: column;
    gap: 6px;
}

.gct-dropdown::before {
    content: "";
    position: absolute;
    left: 28px;
    top: -8px;
    width: 16px;
    height: 16px;
    background: #ffffff;
    border-left: 1px solid rgba(25, 68, 63, 0.12);
    border-top: 1px solid rgba(25, 68, 63, 0.12);
    transform: rotate(45deg);
    z-index: 0;
}

.gct-has-dropdown:hover .gct-dropdown,
.gct-has-dropdown:focus-within .gct-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* IMPORTANT: reset inherited nav button styles */
.gct-site-header .gct-dropdown > a,
.gct-dropdown > a {
    position: relative;
    z-index: 1;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start !important;

    padding: 12px 15px !important;
    border-radius: 14px !important;

    background: transparent !important;
    color: #17365f !important;
    box-shadow: none !important;
    border: 0 !important;

    font-size: 15px;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;

    transform: none !important;
    transition: background .2s ease, color .2s ease, padding-left .2s ease;
}

.gct-site-header .gct-dropdown > a::before,
.gct-site-header .gct-dropdown > a::after,
.gct-dropdown > a::before,
.gct-dropdown > a::after {
    display: none !important;
}

.gct-site-header .gct-dropdown > a:hover,
.gct-dropdown > a:hover {
    background: linear-gradient(135deg, #0f63bd, #1678d5) !important;
    color: #ffffff !important;
    padding-left: 18px !important;
}
.gct-dropdown a:hover{background:#eaf3ff;color:var(--accent-color);box-shadow:none;}
.gct-header-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto;}
.gct-header-search,
.gct-mobile-toggle{
    width:46px;
    height:46px;
    border:1px solid var(--gct-border);
    border-radius:50%;
    background:#fff;
    color:var(--primary-color);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    transition:.22s ease;
    box-shadow:0 8px 20px rgba(8,43,97,.06);
}
.gct-header-search:hover,
.gct-mobile-toggle:hover{background:var(--accent-secondary-color);color:var(--primary-color);transform:translateY(-2px);}
.gct-header-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    min-height:46px;
    padding:0 18px;
    border-radius:999px;
    font-weight:900;
    color:#fff;
    background:linear-gradient(135deg,var(--accent-color),#0e6bca);
    box-shadow:0 12px 26px rgba(11,78,162,.22);
    transition:.22s ease;
    white-space:nowrap;
}
.gct-header-cta:hover{color:var(--primary-color);background:var(--accent-secondary-color);transform:translateY(-2px);}
.gct-mobile-toggle{display:none;flex-direction:column;gap:4px;}
.gct-mobile-toggle span{width:20px;height:2px;background:currentColor;border-radius:5px;}
.gct-mobile-backdrop{
    position:fixed;
    inset:0;
    background:rgba(7,27,59,.58);
    opacity:0;
    visibility:hidden;
    z-index:1200;
    transition:.25s ease;
}
.gct-mobile-panel{
    position:fixed;
    top:0;
    right:0;
    height:100dvh;
    width:min(420px,92vw);
    background:#fff;
    z-index:1201;
    transform:translateX(105%);
    transition:.28s ease;
    display:flex;
    flex-direction:column;
    box-shadow:-30px 0 70px rgba(8,43,97,.18);
    border-radius:28px 0 0 28px;
    overflow:hidden;
}
body.gct-menu-open .gct-mobile-backdrop{opacity:1;visibility:visible;}
body.gct-menu-open .gct-mobile-panel{transform:translateX(0);}
.gct-mobile-panel__head{
    padding:20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    border-bottom:1px solid var(--gct-border);
    background:linear-gradient(180deg,#f8fbff,#fff);
}
.gct-mobile-panel__head img{width:145px;max-height:70px;object-fit:contain;}
.gct-mobile-panel__head button{
    width:44px;
    height:44px;
    border:0;
    border-radius:50%;
    background:#eaf3ff;
    color:var(--primary-color);
    font-size:18px;
}
.gct-mobile-nav{padding:18px;overflow:auto;display:grid;gap:10px;}
.gct-mobile-nav > a,
.gct-mobile-nav summary{
    min-height:50px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    color:#18365f;
    background:#f8fbff;
    border:1px solid var(--gct-border);
    border-radius:16px;
    padding:0 16px;
    font-weight:900;
    cursor:pointer;
}
.gct-mobile-nav > a.active,
.gct-mobile-nav > a:hover,
.gct-mobile-nav summary:hover{background:var(--accent-color);color:#fff;}
.gct-mobile-nav details{display:grid;gap:8px;}
.gct-mobile-nav details[open] summary{background:var(--accent-color);color:#fff;}
.gct-mobile-nav details a{
    display:flex;
    min-height:44px;
    align-items:center;
    padding:0 18px 0 28px;
    margin-top:8px;
    border-radius:14px;
    background:#fff7e7;
    color:#714707;
    font-weight:850;
}
.gct-mobile-panel__footer{margin-top:auto;padding:18px;border-top:1px solid var(--gct-border);background:#f8fbff;}
.gct-mobile-panel__footer .gct-header-cta{width:100%;}
.gct-mobile-panel__footer p{font-size:13px;color:#5d6f86;margin:14px 0 0;font-weight:750;}

/* Embedded map component */
.gct-real-map{
    position:relative;
    min-height:360px;
    border-radius:24px;
    overflow:hidden;
    background:#eaf3ff;
    isolation:isolate;
}
.gct-real-map iframe{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    border:0;
    filter:saturate(1.05) contrast(1.02);
}
.gct-real-map--hero{min-height:210px;border-radius:22px;}
.gct-real-map--large{min-height:475px;}
.gct-map-floating-card{
    position:absolute;
    left:14px;
    bottom:14px;
    width:min(330px,calc(100% - 28px));
    padding:13px 14px;
    border-radius:18px;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(12px);
    box-shadow:0 12px 34px rgba(8,43,97,.16);
    border:1px solid rgba(8,43,97,.10);
    display:grid;
    gap:3px;
    z-index:2;
}
.gct-map-floating-card strong{color:var(--primary-color);font-size:14px;line-height:1.2;}
.gct-map-floating-card strong i{color:var(--accent-secondary-color);margin-right:6px;}
.gct-map-floating-card span{color:#5d6f86;font-size:12px;font-weight:750;line-height:1.3;}
.gct-map-open{
    position:absolute;
    right:14px;
    top:14px;
    z-index:2;
    padding:9px 13px;
    border-radius:999px;
    background:var(--accent-color);
    color:#fff;
    font-size:12px;
    font-weight:900;
    box-shadow:0 10px 24px rgba(11,78,162,.20);
}
.gct-map-open:hover{background:var(--accent-secondary-color);color:var(--primary-color);}
.gct-hero-map{padding:0;border-radius:24px;background:transparent;border:0;box-shadow:none;}
.gct-map-card{padding:12px;}
.gct-map-card .gct-real-map{border-radius:20px;}

/* Layout fixes */
.gct-section{overflow:visible;}
.gct-section--blue{overflow:hidden;}
.gct-page-hero{padding-top:92px;padding-bottom:92px;}
.gct-hero{padding-top:86px;min-height:auto;}
.gct-card{will-change:transform;}
.gct-contact-map-section{padding-top:70px;}

@media (max-width:1399px){
    .gct-brand{min-width:210px;}
    .gct-brand-copy{display:none;}
    .gct-desktop-nav a{font-size:13px;padding:11px 8px;}
    .gct-header-cta{padding:0 14px;}
}
@media (max-width:1199px){
    .gct-desktop-nav{display:none;}
    .gct-mobile-toggle{display:inline-flex;}
    .gct-navbar{min-height:78px;}
    .gct-brand-copy{display:flex;}
    .gct-header-actions .gct-header-cta{display:none;}
}
@media (max-width:991px){
    .gct-top-strip .container{justify-content:center;text-align:center;}
    .gct-top-strip__left{display:none;}
    .gct-navbar{min-height:72px;}
    .gct-brand{min-width:auto;}
    .gct-brand img{width:104px;max-height:58px;}
    .gct-brand-copy strong{font-size:14px;}
    .gct-brand-copy small{font-size:11px;}
    .gct-hero{padding:62px 0 70px;}
    .gct-journey-panel{margin-top:34px;}
    .gct-real-map--large{min-height:390px;}
    .gct-filter-box{position:relative;top:auto;margin-bottom:24px;}
}
@media (max-width:767px){
    .gct-top-strip{display:none;}
    .gct-site-header{box-shadow:0 10px 28px rgba(8,43,97,.10);}
    .gct-navbar{min-height:68px;}
    .gct-brand img{width:96px;}
    .gct-brand-copy{display:none;}
    .gct-header-search,
    .gct-mobile-toggle{width:42px;height:42px;}
    .gct-page-hero{padding:58px 0;}
    .gct-hero h1{font-size:40px;line-height:1.02;}
    .gct-hero p{font-size:16px;}
    .gct-real-map--hero{min-height:190px;}
    .gct-real-map--large{min-height:330px;}
    .gct-map-floating-card{left:10px;bottom:10px;padding:11px 12px;}
    .gct-map-open{top:10px;right:10px;}
    .gct-search-box form{flex-direction:column;}
    .gct-search-box button{min-height:52px;}
}
@media (max-width:575px){
    .gct-mobile-panel{width:100vw;border-radius:0;}
    .gct-real-map{border-radius:18px;}
    .gct-map-card{padding:8px;}
    .gct-real-map--large{min-height:300px;}
    .gct-map-floating-card{
        position:relative;
        left:auto;
        bottom:auto;
        margin:10px;
        width:auto;
    }
    .gct-map-open{font-size:11px;padding:8px 10px;}
}
