/* =====================================================================
   OVHStyle — Design System (Kimsufi-like) for WHMCS
   Layered on top of the "Six" theme (Bootstrap 3). Loaded automatically
   by includes/head.tpl via {assetExists file="custom.css"}.
   --------------------------------------------------------------------- */

/* ----- Fonts ----- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ----- Design tokens ----- */
:root{
  --c-navy:        #000e9c;
  --c-navy-deep:   #00074d;
  --c-blue:        #0050d7;
  --c-blue-dark:   #003fad;
  --c-blue-bright: #1d8cf8;
  --c-blue-tint:   #e8f0fe;
  --c-ink:         #0b1b3a;
  --c-text:        #5a6472;
  --c-muted:       #8893a4;
  --c-line:        #e6e9f0;
  --c-bg:          #ffffff;
  --c-bg-soft:     #f5f6fa;
  --c-success:     #1aa260;
  --c-danger:      #e0245e;
  --radius:        8px;
  --radius-lg:     14px;
  --radius-pill:   999px;
  --shadow-sm:     0 1px 2px rgba(11,27,58,.06);
  --shadow-md:     0 6px 24px rgba(11,27,58,.10);
  --shadow-lg:     0 16px 48px rgba(11,27,58,.16);
  --container:     1200px;
  --ease:          cubic-bezier(.4,0,.2,1);
}

/* ----- Base ----- */
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:var(--c-text);
  background:var(--c-bg);
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,.h1,.h2,.h3,.h4{
  font-family:inherit;
  color:var(--c-navy);
  font-weight:700;
  letter-spacing:-.01em;
}
a{color:var(--c-blue);}
a:hover,a:focus{color:var(--c-blue-dark);text-decoration:none;}
.container{max-width:var(--container);}

/* Widen page container above Bootstrap 3 default for big tables */
@media (min-width:1200px){.container{width:var(--container);}}

/* =====================================================================
   1. TOP BAR (#header)  — utility row: language, login, cart, logo
   ===================================================================== */
#header{
  background:var(--c-bg);
  border-bottom:1px solid var(--c-line);
  padding:14px 0 10px;
}
#header .logo.logo-text{
  font-size:26px;font-weight:800;color:var(--c-navy);
  letter-spacing:-.02em;
}
#header .logo img{max-height:42px;width:auto;}
#header .top-nav{margin:0 0 6px;}
#header .top-nav > li > a{color:var(--c-text);font-weight:600;font-size:13px;}
#header .top-nav > li > a:hover{color:var(--c-blue);}
#header .top-nav .primary-action .btn{
  background:var(--c-blue);color:#fff;border:0;border-radius:var(--radius);
  padding:7px 16px;font-weight:600;box-shadow:var(--shadow-sm);
}
#header .top-nav .primary-action .btn:hover{background:var(--c-blue-dark);}
#header .btn-logged-in-admin{background:var(--c-navy);color:#fff;}

/* =====================================================================
   2. MAIN MENU (#main-menu / .navbar-main) + custom mega-menus
   ===================================================================== */
#main-menu{position:sticky;top:0;z-index:1030;transition:box-shadow .2s var(--ease);}
#main-menu.is-scrolled{box-shadow:0 4px 18px rgba(11,27,58,.10);}

/* Full-bleed helper: lets homepage bands span the full viewport width even
   though homepage.tpl renders inside Six's .container .main-content column. */
.ovh-home-full{margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);}
.ovh-home-full .ovh-section > .ovh-section-head,
.ovh-home-full .ovh-section > .text-center{padding-left:15px;padding-right:15px;}
.navbar-main{
  background:var(--c-bg);
  border:0;
  border-bottom:1px solid var(--c-line);
  border-radius:0;
  margin:0;
  box-shadow:var(--shadow-sm);
  min-height:58px;
}
.navbar-main .navbar-nav > li > a{
  color:var(--c-ink);
  font-weight:600;
  font-size:15px;
  padding:18px 16px;
  transition:color .15s var(--ease);
}
.navbar-main .navbar-nav > li > a:hover,
.navbar-main .navbar-nav > li.open > a,
.navbar-main .navbar-nav > li.active > a{
  color:var(--c-blue);background:transparent;
}
.navbar-main .dropdown-menu{
  border:0;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  padding:8px;margin-top:6px;
}
.navbar-main .dropdown-menu > li > a{
  color:var(--c-ink);font-weight:500;border-radius:var(--radius);padding:9px 14px;
}
.navbar-main .dropdown-menu > li > a:hover{background:var(--c-blue-tint);color:var(--c-blue);}
.navbar-main .caret{opacity:.6;}

/* The brand toggle for mobile */
.navbar-main .navbar-toggle{border-color:var(--c-line);margin-top:12px;}
.navbar-main .navbar-toggle .icon-bar{background:var(--c-navy);}

/* ---- Kimsufi mega-menu strip (static, injected in header.tpl) ---- */
.ovh-mega{
  background:var(--c-bg);
  border-bottom:1px solid var(--c-line);
  display:none;
}
.ovh-mega.is-open{display:block;animation:ovhFade .18s var(--ease);}
.ovh-mega-inner{
  max-width:var(--container);margin:0 auto;padding:28px 15px 34px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:26px 32px;
}
.ovh-mega-2col{grid-template-columns:1.4fr 1fr;}
.ovh-mega-group-title{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-muted);margin:0 0 14px;
}
.ovh-mega-item{display:block;margin-bottom:16px;}
.ovh-mega-item .t{display:block;font-size:17px;font-weight:700;color:var(--c-navy);}
.ovh-mega-item .d{display:block;font-size:13px;color:var(--c-text);margin:2px 0;}
.ovh-mega-item .p{display:block;font-size:13px;font-weight:700;color:var(--c-blue);}
.ovh-mega-item:hover .t{color:var(--c-blue);}
.ovh-mega-loc{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;}
.ovh-mega-loc .flag{font-size:22px;line-height:1;}
.ovh-mega-loc .n{font-weight:700;color:var(--c-navy);display:block;font-size:15px;}
.ovh-mega-loc .r{font-size:12px;color:var(--c-muted);}
.ovh-mega-more{font-weight:700;color:var(--c-blue);display:inline-block;margin-top:6px;}
.ovh-mega-item .c{display:block;font-size:12px;color:var(--c-muted);margin-top:2px;}
.ovh-mega-ranges-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px 20px;}
.ovh-mega-types-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 20px;}
@media (max-width:880px){
  .ovh-mega-ranges-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

/* Mega-menu trigger buttons (added to navbar) */
.ovh-mega-tabs{display:flex;gap:6px;align-items:center;}
.ovh-mega-tab{
  background:transparent;border:0;color:var(--c-ink);font-weight:600;font-size:15px;
  padding:18px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
}
.ovh-mega-tab .caret{transition:transform .2s var(--ease);}
.ovh-mega-tab.is-active{color:var(--c-blue);}
.ovh-mega-tab.is-active .caret{transform:rotate(180deg);}

/* =====================================================================
   3. HERO (home + section heros)
   ===================================================================== */
.ovh-hero{
  background:linear-gradient(120deg,var(--c-navy) 0%,var(--c-navy-deep) 70%);
  color:#fff;position:relative;overflow:hidden;
}
.ovh-hero-inner{
  max-width:var(--container);margin:0 auto;padding:64px 15px 72px;
  display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:30px;
}
.ovh-hero h1{color:#fff;font-size:40px;line-height:1.12;font-weight:800;margin:0 0 16px;}
.ovh-hero p{color:rgba(255,255,255,.82);font-size:18px;max-width:520px;margin:0 0 26px;}
.ovh-hero .ovh-btn{font-size:16px;padding:13px 26px;}
.ovh-hero-art{display:flex;justify-content:center;}
.ovh-hero-art svg{width:100%;max-width:420px;height:auto;}
/* Override Six's default home banner just in case */
#home-banner{background:transparent;padding:0;}

/* =====================================================================
   4. BUTTONS (map Bootstrap .btn-primary etc.)
   ===================================================================== */
.ovh-btn,
.btn-primary,
.btn.search,
.btn.transfer{
  background:var(--c-blue);
  border:0;color:#fff;font-weight:600;
  border-radius:var(--radius);
  padding:10px 20px;
  box-shadow:var(--shadow-sm);
  transition:background .15s var(--ease),transform .15s var(--ease),box-shadow .15s var(--ease);
}
.ovh-btn:hover,.btn-primary:hover,.btn-primary:focus,
.ovh-btn:focus{background:var(--c-blue-dark);color:#fff;box-shadow:var(--shadow-md);}
.ovh-btn-pill{border-radius:var(--radius-pill);}
.ovh-btn-ghost{
  background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5);box-shadow:none;
}
.ovh-btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff;}
.btn-default{
  background:#fff;border:1px solid var(--c-line);color:var(--c-ink);border-radius:var(--radius);font-weight:600;
}
.btn-default:hover{background:var(--c-bg-soft);border-color:var(--c-blue);color:var(--c-blue);}
.label-info,.badge{background:var(--c-blue);}

/* =====================================================================
   5. SECTIONS / CARDS for the homepage
   ===================================================================== */
.ovh-section{padding:64px 0;}
.ovh-section.soft{background:var(--c-bg-soft);}
.ovh-section-head{text-align:center;max-width:720px;margin:0 auto 44px;}
.ovh-section-head h2{font-size:30px;margin:0 0 10px;}
.ovh-section-head p{font-size:16px;color:var(--c-text);}

.ovh-cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
  max-width:var(--container);margin:0 auto;padding:0 15px;
}
.ovh-cards.cols-3{grid-template-columns:repeat(3,1fr);}
.ovh-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  padding:26px 22px;transition:transform .18s var(--ease),box-shadow .18s var(--ease);
}
.ovh-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.ovh-card .ic{
  width:56px;height:56px;border-radius:12px;background:var(--c-blue-tint);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--c-blue);
}
.ovh-card .ic svg{width:30px;height:30px;}
.ovh-card h3{font-size:18px;margin:0 0 8px;}
.ovh-card p{font-size:14px;color:var(--c-text);margin:0 0 16px;}
.ovh-card .ovh-btn{display:inline-block;}

/* =====================================================================
   6. FAQ accordion
   ===================================================================== */
.ovh-faq{max-width:860px;margin:0 auto;padding:0 15px;}
.ovh-faq-item{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;}
.ovh-faq-q{
  width:100%;text-align:left;background:none;border:0;padding:18px 22px;
  font-weight:700;color:var(--c-navy);font-size:16px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.ovh-faq-q .pm{color:var(--c-blue);font-size:20px;transition:transform .2s var(--ease);flex:none;}
.ovh-faq-item.is-open .ovh-faq-q .pm{transform:rotate(45deg);}
.ovh-faq-a{max-height:0;overflow:hidden;transition:max-height .25s var(--ease);}
.ovh-faq-a-inner{padding:0 22px 20px;color:var(--c-text);}
.ovh-faq-item.is-open .ovh-faq-a{max-height:400px;}

/* =====================================================================
   7. PANELS / TABLES / FORMS — restyle Six client area
   ===================================================================== */
#main-body{background:var(--c-bg);padding:36px 0 60px;}
.panel{border:1px solid var(--c-line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);}
.panel-heading{
  background:var(--c-bg-soft);border-bottom:1px solid var(--c-line);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;font-weight:700;color:var(--c-navy);
}
.panel-primary > .panel-heading{background:var(--c-navy);border-color:var(--c-navy);color:#fff;}
.panel-title{font-weight:700;}
.table > thead > tr > th{
  border-bottom:1px solid var(--c-line);color:var(--c-muted);
  text-transform:uppercase;font-size:12px;letter-spacing:.03em;background:var(--c-bg-soft);
}
.table > tbody > tr > td{border-top:1px solid var(--c-line);vertical-align:middle;}
.table-hover > tbody > tr:hover{background:var(--c-blue-tint);}
.form-control{
  border:1px solid var(--c-line);border-radius:var(--radius);box-shadow:none;height:42px;
}
.form-control:focus{border-color:var(--c-blue);box-shadow:0 0 0 3px rgba(0,80,215,.12);}
.input-group-lg .form-control{height:52px;}
.well,.alert{border-radius:var(--radius);}
.alert-info{background:var(--c-blue-tint);border-color:#cfe0fb;color:var(--c-navy-deep);}

/* Page header / breadcrumb */
#main-body .page-header{border-bottom:1px solid var(--c-line);}
.breadcrumb{background:transparent;padding-left:0;}

/* Sidebar */
.sidebar .panel{box-shadow:none;}
.sidebar .list-group-item.active,
.sidebar .list-group-item.active:hover{background:var(--c-blue);border-color:var(--c-blue);}

/* Home shortcuts (Six) — make them feel like cards */
.home-shortcuts{background:var(--c-bg-soft);padding:28px 0;border-bottom:1px solid var(--c-line);}
.home-shortcuts ul li a{color:var(--c-ink);}
.home-shortcuts ul li a:hover{color:var(--c-blue);}
.home-shortcuts i{color:var(--c-blue);}

/* =====================================================================
   8. FOOTER (#footer) — navy Kimsufi-style
   ===================================================================== */
#footer{
  background:linear-gradient(180deg,var(--c-blue) 0%,var(--c-blue-dark) 100%);
  color:rgba(255,255,255,.75);
  padding:0;margin:0;
}
.ovh-footer-top{
  max-width:var(--container);margin:0 auto;padding:54px 15px 40px;
  display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:30px;
}
.ovh-footer-brand .logo{font-size:24px;font-weight:800;color:#fff;display:inline-block;margin-bottom:14px;}
.ovh-footer-brand p{font-size:13px;color:rgba(255,255,255,.6);max-width:230px;}
.ovh-footer-col h4{color:#fff;font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 16px;}
.ovh-footer-col ul{list-style:none;padding:0;margin:0;}
.ovh-footer-col ul li{margin-bottom:10px;}
.ovh-footer-col ul li a{color:rgba(255,255,255,.7);font-size:14px;}
.ovh-footer-col ul li a:hover{color:#fff;}
.ovh-footer-social{display:flex;gap:10px;margin-top:18px;}
.ovh-footer-social a{
  width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;color:#fff;
}
.ovh-footer-social a:hover{background:rgba(255,255,255,.28);}
.ovh-footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  max-width:var(--container);margin:0 auto;padding:18px 15px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;
}
.ovh-footer-bottom a{color:rgba(255,255,255,.7);}
.ovh-footer-bottom a:hover{color:#fff;}
.ovh-footer-legal{display:flex;gap:18px;flex-wrap:wrap;}
#footer .back-to-top{
  position:fixed;right:24px;bottom:24px;width:44px;height:44px;border-radius:50%;
  background:var(--c-blue);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);z-index:1000;
}
#footer .back-to-top:hover{background:var(--c-blue-dark);}

/* =====================================================================
   9. VITRINE / ORDER FORM product descriptions (.ovhdc-* contract)
   These classes come from the module HTML — only styling here.
   ===================================================================== */
.ovhdc-plan-desc{text-align:left;color:var(--c-text);font-size:14px;}
.ovhdc-spec-line{display:flex;gap:8px;padding:3px 0;border-bottom:1px dashed var(--c-line);}
.ovhdc-spec-line:last-child{border-bottom:0;}
.ovhdc-spec-label{color:var(--c-muted);min-width:120px;font-weight:600;}
.ovhdc-spec-value{color:var(--c-ink);font-weight:600;}

/* =====================================================================
   10. Animations / utilities
   ===================================================================== */
@keyframes ovhFade{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}
.ovh-fade-up{animation:ovhFade .4s var(--ease) both;}

/* =====================================================================
   11. Responsive
   ===================================================================== */
@media (max-width:991px){
  .ovh-mega-inner{grid-template-columns:repeat(2,1fr);}
  .ovh-hero-inner{grid-template-columns:1fr;text-align:center;}
  .ovh-hero-art{order:-1;}
  .ovh-hero p{margin-left:auto;margin-right:auto;}
  .ovh-cards{grid-template-columns:repeat(2,1fr);}
  .ovh-footer-top{grid-template-columns:1fr 1fr;}
}
@media (max-width:767px){
  .ovh-hero h1{font-size:30px;}
  .ovh-section{padding:44px 0;}
  .ovh-cards,.ovh-cards.cols-3{grid-template-columns:1fr;}
  .ovh-mega-inner{grid-template-columns:1fr;}
  .ovh-footer-top{grid-template-columns:1fr;}
  .navbar-main .ovh-mega-tabs{flex-direction:column;align-items:stretch;}
  .ovh-mega-tab{padding:12px 14px;justify-content:space-between;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;}
}
