/* ============================================================
   MarocJobSeek Gov — main stylesheet
   Professional government-style, light + dark mode.
   ============================================================ */

/* ---------- Reset (lite) ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:"Inter","Marianne","Segoe UI",Roboto,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.65;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent-hover);text-decoration:underline}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4,h5{font-family:"Marianne","Inter",system-ui,sans-serif;color:var(--heading);font-weight:700;line-height:1.25;margin:0 0 .6em}
h1{font-size:clamp(1.9rem,3.5vw,2.6rem)}
h2{font-size:clamp(1.5rem,2.6vw,2rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
ul,ol{padding-left:1.4em}

/* ---------- Tokens: LIGHT (default) ---------- */
:root,
:root[data-theme="light"]{
  --bg:#f6f7f9;
  --surface:#ffffff;
  --surface-2:#f1f3f6;
  --text:#1a2230;
  --text-soft:#52607a;
  --heading:#0b1a2b;
  --border:#dfe3eb;
  --border-strong:#c3cad6;

  --accent:#0b3d2e;          /* deep Moroccan green */
  --accent-hover:#0e5240;
  --accent-soft:#e6f0eb;
  --red:#c1272d;             /* Moroccan red */
  --red-soft:#fbe6e7;

  --shadow:0 1px 2px rgba(11,26,43,.04),0 2px 8px rgba(11,26,43,.04);
  --shadow-md:0 4px 16px rgba(11,26,43,.08);
  --radius:8px;
  --radius-lg:14px;
  --container:1200px;
}

/* ---------- Tokens: DARK ---------- */
:root[data-theme="dark"]{
  --bg:#0c1118;
  --surface:#141b25;
  --surface-2:#1a222e;
  --text:#e6ebf2;
  --text-soft:#9aa6b8;
  --heading:#ffffff;
  --border:#222b39;
  --border-strong:#2e3a4d;

  --accent:#5dd3a8;
  --accent-hover:#7ee0bb;
  --accent-soft:rgba(93,211,168,.12);
  --red:#ff6b6f;
  --red-soft:rgba(255,107,111,.12);

  --shadow:0 1px 2px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.3);
  --shadow-md:0 6px 20px rgba(0,0,0,.5);
}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
.mjs-main{min-height:60vh}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;background:var(--accent);color:#fff;padding:.6em 1em;border-radius:6px;z-index:9999}

/* ---------- Topbar ---------- */
.mjs-topbar{background:var(--accent);color:#fff;font-size:.85rem;border-bottom:3px solid var(--red)}
.topbar-inner{display:flex;align-items:center;gap:14px;min-height:36px;flex-wrap:wrap}
.topbar-flag{font-size:1.1rem}
.topbar-text{opacity:.95}
.topbar-spacer{flex:1}
.mjs-theme-toggle{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2);padding:4px 10px;border-radius:999px;font-size:.8rem}
.mjs-theme-toggle:hover{background:rgba(255,255,255,.2)}
:root[data-theme="light"] .theme-dark,
:root[data-theme="dark"] .theme-light{display:none}

/* ---------- Header ---------- */
.mjs-header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(8px)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 20px}
.mjs-brand{display:flex;align-items:center;gap:12px;color:var(--heading);font-weight:700}
.mjs-brand:hover{text-decoration:none}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;font-weight:800;letter-spacing:.5px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-size:1.05rem;font-weight:800}
.brand-tag{font-size:.78rem;color:var(--text-soft);font-weight:500}
.custom-logo{max-height:48px;width:auto}

/* Nav */
.mjs-menu{list-style:none;display:flex;align-items:center;gap:4px;margin:0;padding:0}
.mjs-menu li{position:relative}
.mjs-menu a{display:block;padding:10px 14px;color:var(--text);font-weight:500;border-radius:6px;font-size:.95rem}
.mjs-menu a:hover{background:var(--surface-2);color:var(--accent);text-decoration:none}
.mjs-menu .current-menu-item>a,
.mjs-menu .current_page_item>a{color:var(--accent);background:var(--accent-soft)}
.mjs-menu .sub-menu{position:absolute;top:100%;left:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-md);min-width:220px;padding:6px;display:none;list-style:none;margin:0}
.mjs-menu li:hover>.sub-menu,
.mjs-menu li:focus-within>.sub-menu{display:block}

/* Burger */
.mjs-burger{display:none;background:transparent;border:1px solid var(--border);padding:8px;border-radius:6px}
.mjs-burger span{display:block;width:22px;height:2px;background:var(--text);margin:4px 0;transition:.2s}

@media (max-width: 900px){
  .mjs-burger{display:block}
  .mjs-menu{position:absolute;top:100%;right:20px;left:20px;flex-direction:column;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px;box-shadow:var(--shadow-md);display:none}
  .mjs-menu.is-open{display:flex}
  .mjs-menu .sub-menu{position:static;box-shadow:none;border:none;padding-left:14px}
  .header-inner{flex-wrap:wrap}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:8px;font-weight:600;font-size:.95rem;border:1px solid transparent;transition:.15s;text-decoration:none;cursor:pointer;line-height:1}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);color:#fff;text-decoration:none}
.btn-outline{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-outline:hover{background:var(--accent-soft);text-decoration:none}
.btn-ghost{background:var(--surface-2);color:var(--text)}
.btn-ghost:hover{background:var(--border);text-decoration:none}

/* ---------- Breadcrumbs ---------- */
.mjs-breadcrumbs{font-size:.85rem;color:var(--text-soft);padding:14px 0;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.mjs-breadcrumbs a{color:var(--text-soft)}
.mjs-breadcrumbs a:hover{color:var(--accent)}
.mjs-breadcrumbs .sep{opacity:.5}
.mjs-breadcrumbs [aria-current="page"]{color:var(--heading);font-weight:600}

/* ---------- Hero (homepage) ---------- */
.mjs-hero{background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%);border-bottom:1px solid var(--border);padding:64px 0 48px;position:relative;overflow:hidden}
.mjs-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 10%,var(--accent-soft) 0%,transparent 60%);pointer-events:none}
.hero-inner{position:relative;max-width:820px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--accent-soft);color:var(--accent);padding:6px 14px;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:16px}
.hero-title{margin:0 0 16px;font-size:clamp(2rem,4.5vw,3.4rem);font-weight:800;letter-spacing:-.02em}
.hero-sub{font-size:1.1rem;color:var(--text-soft);max-width:640px;margin:0 0 28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px}
.hero-stats{display:flex;flex-wrap:wrap;gap:32px;margin-top:36px;padding-top:24px;border-top:1px solid var(--border)}
.hero-stats .stat strong{display:block;font-size:1.6rem;color:var(--heading);font-weight:800}
.hero-stats .stat span{font-size:.85rem;color:var(--text-soft)}

/* Search bar */
.mjs-search{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;box-shadow:var(--shadow);display:flex;gap:8px;flex-wrap:wrap;margin-top:24px}
.mjs-search input,.mjs-search select{flex:1 1 180px;min-width:0;padding:12px 14px;border:none;background:transparent;color:var(--text);font:inherit;outline:none;border-radius:8px}
.mjs-search input:focus,.mjs-search select:focus{background:var(--surface-2)}
.mjs-search button{flex:0 0 auto}

/* ---------- Sections ---------- */
.section{padding:56px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.section-head h2{margin:0;font-size:1.7rem}
.section-head .sub{color:var(--text-soft);margin:6px 0 0}
.section-head .more{font-weight:600;font-size:.9rem}

/* ---------- 3 Spaces grid ---------- */
.spaces-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width: 900px){.spaces-grid{grid-template-columns:1fr}}
.space-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:.2s;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.space-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent);text-decoration:none}
.space-card .icon{width:48px;height:48px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px}
.space-card h3{margin:0 0 8px;color:var(--heading)}
.space-card p{color:var(--text-soft);margin:0 0 16px;font-size:.95rem}
.space-card .cta{margin-top:auto;color:var(--accent);font-weight:600;font-size:.9rem}

/* ---------- Cards (job/concours/conseil) ---------- */
.mjs-results-grid,
.mjs-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.mjs-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:.2s;display:flex;flex-direction:column;gap:12px;position:relative}
.mjs-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.mjs-card .card-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:4px;background:var(--accent-soft);color:var(--accent);align-self:flex-start}
.mjs-card .card-tag.is-concours{background:var(--red-soft);color:var(--red)}
.mjs-card .card-tag.is-conseil{background:#fff4d6;color:#8a6300}
:root[data-theme="dark"] .mjs-card .card-tag.is-conseil{background:rgba(255,196,0,.12);color:#ffcc4d}
.mjs-card h3{font-size:1.08rem;margin:0;line-height:1.35}
.mjs-card h3 a{color:var(--heading)}
.mjs-card h3 a:hover{color:var(--accent);text-decoration:none}
.mjs-card .excerpt{font-size:.9rem;color:var(--text-soft);margin:0}
.mjs-meta{display:flex;flex-wrap:wrap;gap:6px}
.mjs-pill{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;background:var(--surface-2);color:var(--text-soft);padding:4px 10px;border-radius:999px;border:1px solid var(--border)}
.mjs-pill .i{font-size:.85rem}
.mjs-card .card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:10px;border-top:1px dashed var(--border);font-size:.8rem;color:var(--text-soft)}

/* ---------- Archive page layout ---------- */
.archive-layout{display:grid;grid-template-columns:280px 1fr;gap:32px;padding:32px 0 64px}
@media (max-width: 900px){.archive-layout{grid-template-columns:1fr}}
.archive-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:sticky;top:90px;align-self:flex-start;height:fit-content}
.archive-sidebar h4{margin:0 0 10px;font-size:.9rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft)}
.archive-sidebar ul{list-style:none;padding:0;margin:0 0 18px}
.archive-sidebar li a{display:block;padding:6px 10px;border-radius:6px;font-size:.92rem;color:var(--text)}
.archive-sidebar li a:hover{background:var(--surface-2);color:var(--accent);text-decoration:none}
.archive-header{margin-bottom:24px}
.archive-header h1{margin:0 0 8px}
.archive-header p{color:var(--text-soft);margin:0}

/* Pagination */
.mjs-pagination{margin:32px 0;display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.mjs-pagination a,.mjs-pagination span{padding:8px 14px;border:1px solid var(--border);border-radius:6px;color:var(--text);background:var(--surface);font-weight:500;text-decoration:none}
.mjs-pagination a:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}
.mjs-pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---------- Single ---------- */
.single-wrap{max-width:820px;margin:0 auto;padding:24px 20px 64px}
.single-header{margin-bottom:24px}
.single-header h1{margin:0 0 16px}
.single-content{font-size:1.02rem;line-height:1.75}
.single-content h2{margin-top:1.6em}
.single-content blockquote{border-left:4px solid var(--accent);padding:8px 16px;color:var(--text-soft);margin:1.5em 0;background:var(--accent-soft);border-radius:0 8px 8px 0}
.single-cta{margin-top:32px;padding:24px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:12px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.single-cta strong{color:var(--heading);font-size:1.05rem}

/* ---------- Page (legal) ---------- */
.page-wrap{max-width:820px;margin:0 auto;padding:24px 20px 64px}
.page-wrap h1{font-size:2rem;border-bottom:3px solid var(--accent);padding-bottom:12px;display:inline-block}
.page-wrap h2{margin-top:1.8em;font-size:1.35rem;color:var(--heading)}
.page-wrap ul{padding-left:1.3em}
.page-wrap li{margin:.4em 0}

/* ---------- Footer ---------- */
.mjs-footer{background:var(--surface);border-top:1px solid var(--border);margin-top:60px;color:var(--text-soft);font-size:.92rem;line-height:1.6}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding:48px 20px}
@media (max-width: 900px){.footer-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width: 560px){.footer-grid{grid-template-columns:1fr}}
.footer-col h4{color:var(--heading);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 14px}
.footer-col ul,.footer-list{list-style:none;padding:0;margin:0}
.footer-col li{margin:6px 0}
.footer-col a{color:var(--text-soft);font-weight:500}
.footer-col a:hover{color:var(--accent);text-decoration:none}
.footer-brand .brand-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;color:var(--heading)}
.footer-desc{margin:0 0 16px;max-width:380px;word-break:normal;overflow-wrap:break-word}
.footer-social{display:flex;gap:10px;flex-wrap:wrap}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-soft);transition:.15s}
.footer-social a:hover{color:#fff;background:var(--accent);border-color:var(--accent)}
.footer-bottom{border-top:1px solid var(--border);background:var(--surface-2)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;flex-wrap:wrap;gap:8px;font-size:.85rem;color:var(--text-soft)}

/* ---------- Misc ---------- */
.mjs-empty{padding:40px;text-align:center;color:var(--text-soft);background:var(--surface);border:1px dashed var(--border);border-radius:12px}
.tax-cloud{display:flex;flex-wrap:wrap;gap:8px}
.tax-cloud a{padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:999px;color:var(--text);font-size:.88rem;font-weight:500}
.tax-cloud a:hover{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}
