/* =========================================================
   INTERNATIONAL EXCHANGE OF MOROCCO — exchangeagadir.com
   Thème : Rate-board  (Rouge / Noir / Blanc)
   Feuille de style unique, légère, sans framework.
   ========================================================= */

:root{
  --ink:#0b0b0d;          /* noir tableau */
  --ink-2:#141419;        /* noir cartes  */
  --line:#2a2a31;         /* filets tableau */
  --red:#e11d2a;          /* rouge marque */
  --red-2:#b30f1a;        /* rouge foncé  */
  --paper:#ffffff;
  --smoke:#f4f4f5;        /* gris très clair */
  --smoke-2:#ebebed;
  --muted:#6c6c75;
  --green:#1f9d4d;
  --board:#f6f6f7;        /* chiffres tableau */
  --shadow:0 18px 50px rgba(11,11,13,.16);
  --radius:16px;
  --maxw:1180px;
  --ff-display:"Oswald",system-ui,sans-serif;
  --ff-body:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
.yellow {
    color: #FFD700;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.section{padding:72px 0}
.eyebrow{
  font-family:var(--ff-display);
  font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  font-size:.78rem;color:var(--red);display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red)}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.05;letter-spacing:.01em}
.h-section{font-size:clamp(1.8rem,4vw,2.7rem);text-transform:uppercase;margin:14px 0 8px}
.lead{color:var(--muted);max-width:60ch}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--ff-display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  font-size:.95rem;padding:14px 26px;border-radius:50px;border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s;
  white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em;fill:currentColor;flex:0 0 auto}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-2);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}

/* ============== HEADER ============== */
.site-header{
  position:sticky;top:0;z-index:50;background:#fff;
  border-bottom:1px solid var(--smoke-2);
}
.topbar{background:var(--ink);color:#cfcfd4;font-size:.8rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-block:7px;flex-wrap:wrap}
.topbar .cards{display:flex;align-items:center;gap:.5rem;color:#d6d6db}
.topbar .cards b{color:var(--green);font-weight:700}
.lang{display:flex;gap:14px}
.lang a{display:inline-flex;align-items:center;gap:6px;color:#cfcfd4;font-weight:600;letter-spacing:.04em}
.lang a:hover{color:#fff}

.navbar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-block:14px}
.logo img{height:46px;width:auto}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  font-family:var(--ff-display);font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  font-size:.9rem;padding:10px 16px;border-radius:8px;color:var(--ink);position:relative;transition:color .2s;
}
.nav a::after{content:"";position:absolute;left:16px;right:16px;bottom:4px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .2s}
.nav a:hover{color:var(--red)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav a.active{color:var(--red)}
.nav-actions{display:flex;align-items:center;gap:10px}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;transition:.25s}

/* ============== HERO / RATE BOARD ============== */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 420px at 78% -10%,rgba(225,29,42,.30),transparent 60%),
    linear-gradient(180deg,#0b0b0d 0%,#121217 100%);
}
.hero::after{ /* fines lignes type tableau */
  content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:100% 46px;
}
.hero .wrap{position:relative;z-index:2;padding-block:84px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.4rem,6vw,4.4rem);text-transform:uppercase;letter-spacing:.01em;margin:18px 0}
.hero h1 .hl{color:var(--red)}
.hero p.lead{color:#c9c9d0;font-size:1.08rem;max-width:46ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* mini-tableau visuel */
.board{background:#0e0e12;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.board-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;background:linear-gradient(90deg,#16161c,#0e0e12);border-bottom:1px solid var(--line)}
.board-head .t{font-family:var(--ff-display);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.82rem;color:#e9e9ee}
.live{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;letter-spacing:.12em;color:#9a9aa3;text-transform:uppercase}
.live .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(31,157,77,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,157,77,.6)}70%{box-shadow:0 0 0 9px rgba(31,157,77,0)}100%{box-shadow:0 0 0 0 rgba(31,157,77,0)}}
.board-cols{display:grid;grid-template-columns:1fr auto;gap:10px;padding:10px 18px;border-bottom:1px solid var(--line);font-family:var(--ff-display);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#83838d}
.board-cols span:last-child{text-align:right}
.board-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:13px 18px;border-bottom:1px solid rgba(255,255,255,.05)}
.board-row:last-child{border-bottom:none}
.cur{display:flex;align-items:center;gap:12px}
.cur .code{font-family:var(--ff-display);font-weight:700;letter-spacing:.06em;font-size:1.05rem}
.cur .name{font-size:.74rem;color:#83838d;letter-spacing:.02em}
.cur .sym{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:#191920;color:var(--red);font-weight:700;font-size:1rem;border:1px solid var(--line)}
.tag{font-family:var(--ff-display);font-weight:600;letter-spacing:.06em;color:var(--board);text-align:right;font-size:.9rem}
.tag b{color:#fff}
.board-foot{padding:14px 18px;font-size:.78rem;color:#9a9aa3;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.board-foot a{color:#fff;font-weight:700;letter-spacing:.04em}
.board-foot a:hover{color:var(--red)}

/* ---------- Ticker devises ---------- */
.ticker{position:relative;z-index:2;background:var(--red);color:#fff;overflow:hidden;border-block:1px solid rgba(0,0,0,.15)}
.ticker .track{display:flex;width:max-content;animation:scroll 32s linear infinite}
.ticker .it{display:inline-flex;align-items:center;gap:10px;padding:12px 0;font-family:var(--ff-display);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.92rem;white-space:nowrap}
.ticker .it .s{opacity:.72}
.ticker .it::after{content:"●";font-size:.4rem;margin-inline:24px;opacity:.55}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============== STATS ============== */
.stats{background:var(--ink);color:#fff}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:linear-gradient(180deg,#15151b,#101015);border:1px solid var(--line);border-radius:var(--radius);padding:30px 22px;text-align:center;position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--red)}
.stat .num{font-family:var(--ff-display);font-weight:700;font-size:clamp(2.2rem,4vw,3rem);font-variant-numeric:tabular-nums;line-height:1}
.stat .lbl{margin-top:10px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#9a9aa3;font-family:var(--ff-display)}

/* ============== CARTES (vision / régl.) ============== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
.card{background:#fff;border:1px solid var(--smoke-2);border-radius:var(--radius);padding:30px 26px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s;position:relative}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{width:58px;height:58px;border-radius:14px;background:var(--red);display:grid;place-items:center;margin-bottom:18px}
.card .ic img{width:30px;height:30px;filter:brightness(0) invert(1)}
.card h3{font-size:1.25rem;text-transform:uppercase;margin-bottom:10px}
.card p{color:var(--muted);font-size:.96rem}
.card .req{margin-top:14px;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red);font-family:var(--ff-display);font-weight:600}
.card .docs{margin-top:8px;display:flex;flex-direction:column;gap:8px}
.card .docs li{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.95rem}
.card .docs img{width:20px;height:20px}

/* ============== GARANTIE ============== */
.guarantee{background:var(--smoke)}
.guarantee .panel{display:grid;grid-template-columns:1.05fr .95fr;border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.guarantee .left{background:var(--red);color:#fff;padding:48px 44px}
.guarantee .left h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.4rem);text-transform:uppercase;margin:14px 0 22px}
.guarantee .left .eyebrow{color:#fff}
.guarantee .left .eyebrow::before{background:#fff}
.glist{display:flex;flex-direction:column;gap:13px;margin-bottom:30px}
.glist li{display:flex;gap:12px;align-items:flex-start;font-weight:500}
.glist li svg{flex:0 0 auto;width:22px;height:22px;margin-top:2px;fill:#fff}
.guarantee .right{background:var(--ink);color:#fff;padding:48px 44px;display:flex;flex-direction:column;justify-content:center}
.guarantee .right h3{font-size:1.5rem;text-transform:uppercase;margin-bottom:8px}
.guarantee .right p{color:#b6b6bd;margin-bottom:24px}
.contact-rows{display:flex;flex-direction:column;gap:14px;margin-bottom:26px}
.contact-rows a{display:flex;align-items:center;gap:14px;font-family:var(--ff-display);font-weight:600;font-size:1.2rem;letter-spacing:.04em}
.contact-rows a:hover{color:var(--red)}
.contact-rows .pin{width:40px;height:40px;border-radius:10px;background:#191920;border:1px solid var(--line);display:grid;place-items:center;flex:0 0 auto}
.contact-rows .pin svg{width:18px;height:18px;fill:var(--red)}

/* ============== LIVE COURS (page cours) ============== */
.cours-board{background:var(--ink);color:#fff}
.cours-frame{background:#0e0e12;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);margin-top:30px}
.cours-frame .bar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--line);background:linear-gradient(90deg,#16161c,#0e0e12);gap:10px;flex-wrap:wrap}
.cours-frame .bar .t{font-family:var(--ff-display);letter-spacing:.16em;text-transform:uppercase;font-size:.85rem}
.cours-frame iframe{width:100%;border:0;display:block;background:#fff}
.iframe-desktop{height:760px}
.iframe-mobile{height:1180px;display:none}

/* ============== CONTACT / MAP ============== */
.contact{background:#fff}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.info-block{display:flex;flex-direction:column;gap:8px;margin-bottom:26px}
.info-block .k{font-family:var(--ff-display);letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;color:var(--red)}
.info-block .v{font-size:1.05rem;font-weight:600}
.hours{display:inline-flex;align-items:center;gap:10px;background:var(--smoke);border:1px solid var(--smoke-2);border-radius:50px;padding:10px 18px;font-family:var(--ff-display);letter-spacing:.06em;text-transform:uppercase;font-size:.9rem;font-weight:600}
.hours .dot{width:9px;height:9px;border-radius:50%;background:var(--green)}
.map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--smoke-2);box-shadow:var(--shadow);min-height:340px}
.map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

/* ---------- Formulaire ---------- */
.form-card{background:var(--ink);color:#fff;border-radius:22px;padding:38px 34px;box-shadow:var(--shadow)}
.form-card h3{font-size:1.6rem;text-transform:uppercase;margin-bottom:6px}
.form-card p{color:#b6b6bd;margin-bottom:22px;font-size:.95rem}
.field{margin-bottom:14px}
.field label{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#9a9aa3;margin-bottom:6px;font-family:var(--ff-display)}
.field input,.field textarea,.field select{
  width:100%;background:#15151b;border:1px solid var(--line);border-radius:12px;color:#fff;
  padding:13px 15px;font-size:.95rem;font-family:var(--ff-body);transition:border-color .2s,box-shadow .2s;
}
.field input::placeholder,.field textarea::placeholder{color:#6c6c75}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(225,29,42,.25)}
.field textarea{resize:vertical;min-height:96px}
.form-card .btn{width:100%;justify-content:center;margin-top:6px}
.form-msg{margin-top:12px;font-size:.9rem;display:none}
.form-msg.ok{color:#7ee2a3;display:block}
.form-msg.err{color:#ff8a92;display:block}

/* ---------- Page title (A PROPOS / COURS) ---------- */
.page-hero{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 80% -20%,rgba(225,29,42,.30),transparent 60%)}
.page-hero .wrap{position:relative;z-index:2;padding-block:64px;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);text-transform:uppercase;margin-top:14px}
.page-hero .eyebrow{justify-content:center}

/* ---------- A PROPOS ---------- */
.about .grid{display:grid;grid-template-columns:1fr 1fr;border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.about .copy{background:#fff;padding:48px 42px;display:flex;flex-direction:column;justify-content:center}
.about .copy h2{font-size:clamp(1.6rem,3vw,2.2rem);text-transform:uppercase;margin-bottom:18px}
.about .copy h2 .hl{color:var(--red)}
.about .copy p{color:var(--muted);margin-bottom:16px}
.about .copy .quote{border-left:4px solid var(--red);padding:6px 0 6px 18px;color:var(--ink);font-weight:600;font-style:italic}
.about .ph{min-height:480px;background-size:cover;background-position:50% 50%;position:relative}
.about .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(11,11,13,.25))}

/* ============== FOOTER ============== */
.site-footer{background:var(--ink);color:#9a9aa3;padding:46px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;padding-bottom:30px;border-bottom:1px solid var(--line)}
.site-footer .logo img{height:50px;margin-bottom:16px}
.site-footer p{font-size:.92rem;max-width:42ch}
.footer-col h4{color:#fff;font-size:1rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.footer-col a{display:block;padding:5px 0;color:#b6b6bd;font-size:.95rem}
.footer-col a:hover{color:var(--red)}
.copyright{padding-top:22px;text-align:center;font-size:.85rem;letter-spacing:.04em}

/* ============== BACK TO TOP ============== */
.back-top{
  position:fixed;right:20px;bottom:20px;width:52px;height:52px;border-radius:50%;
  background:var(--red);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transform:translateY(12px);transition:.25s;z-index:40;cursor:pointer;border:none;
}
.back-top.show{opacity:1;visibility:visible;transform:none}
.back-top:hover{background:var(--red-2)}
.back-top svg{width:20px;height:20px;fill:#fff}

/* ============== RESPONSIVE ============== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .stats .grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid{grid-template-columns:1fr 1fr}
  .guarantee .panel{grid-template-columns:1fr}
  .contact .grid{grid-template-columns:1fr}
  .about .grid{grid-template-columns:1fr}
  .about .ph{min-height:320px;order:-1}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav{
    position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;
    padding:12px;gap:4px;border-bottom:1px solid var(--smoke-2);box-shadow:var(--shadow);
    transform:translateY(-8px);opacity:0;pointer-events:none;transition:.2s;display:flex;
  }
  .nav:not(.open){display:none}
  .nav.open{transform:none;opacity:1;pointer-events:auto}
  .nav a{padding:14px 16px;border-radius:8px}
  .nav a::after{display:none}
  .hamburger{display:block}
  .nav-actions .btn .txt{display:none}
  .navbar{position:relative}
  .section{padding:54px 0}
  .cards-grid{grid-template-columns:1fr}
  .stats .grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .iframe-desktop{display:none}
  .iframe-mobile{display:block}
  .topbar .cards .long{display:none}
}
@media (max-width:420px){
  .stats .grid{grid-template-columns:1fr}
  .guarantee .left,.guarantee .right,.about .copy{padding:32px 22px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* =========================================================
   COURS EN DIRECT — tableau alimenté par /app/api.php
   ========================================================= */
.rates-board{max-width:780px;margin:30px auto 0}

/* Une ligne = devise (souple) + ACHAT + VENTE (largeur fixe, alignes a droite) */
.rrow{display:grid;grid-template-columns:minmax(0,1fr) 84px 84px;gap:14px;align-items:center;padding:13px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.rrow:last-child{border-bottom:none}
.rrow.head{font-family:var(--ff-display);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#83838d;border-bottom:1px solid var(--line);padding-block:11px}

.rrow .cur{display:flex;align-items:center;gap:12px;min-width:0}
.rrow .cur > div{min-width:0}
.rrow .cur .code{font-family:var(--ff-display);font-weight:700;letter-spacing:.04em;font-size:1.05rem;line-height:1.1;white-space:nowrap}
.rrow .cur .name{font-size:.74rem;color:#83838d;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.rrow .achat,.rrow .vente{font-family:var(--ff-display);font-weight:600;font-variant-numeric:tabular-nums;text-align:right;font-size:1.06rem;letter-spacing:.02em;white-space:nowrap}
.rrow.head .achat,.rrow.head .vente{font-size:.72rem;font-weight:600}
.rrow .achat{color:var(--green)}
.rrow .vente{color:#fff}

/* Tuile devise : taille fixe, ne retrecit jamais */
.rrow .sym{flex:0 0 36px;width:36px;height:36px}

.sk{height:14px;border-radius:6px;background:linear-gradient(90deg,#1b1b22,#2a2a33,#1b1b22);background-size:200% 100%;animation:sh 1.2s infinite}
.skeleton .achat .sk,.skeleton .vente .sk{margin-left:auto;width:54px}
.skeleton .cur .sk{width:90px}
@keyframes sh{to{background-position:-200% 0}}
.btn-refresh{background:none;border:1px solid var(--line);color:#fff;border-radius:50px;padding:8px 16px;font-family:var(--ff-display);letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.2s}
.btn-refresh:hover{border-color:var(--red);color:var(--red)}
.btn-refresh svg{width:15px;height:15px;fill:currentColor}
.btn-refresh.spin svg{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.rate-error{padding:26px 18px;color:#ff9aa1;text-align:center;font-size:.95rem;line-height:1.5}
.rate-error a{color:#fff;font-weight:700}
.rate-note{font-size:.78rem;color:#9a9aa3;letter-spacing:.02em}
@media (max-width:520px){
  .rrow{grid-template-columns:minmax(0,1fr) 66px 66px;gap:10px;padding:12px 14px}
  .rrow .sym{flex:0 0 30px;width:30px;height:30px}
  .rrow .cur .code{font-size:.98rem}
  .rrow .achat,.rrow .vente{font-size:.98rem}
  .rates-board{margin-top:22px}
}

/* ---- Drapeaux : image plein cadre ; le symbole n'apparait QUE si l'image manque ---- */
.sym.flagwrap{padding:0;overflow:hidden;background:#191920;position:relative}
.sym.flagwrap .flagimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:8px}
.sym.flagwrap .symfb{display:none;position:absolute;inset:0;place-items:center;color:var(--red);font-weight:700;font-size:1rem}
.sym.flagwrap.noimg .symfb{display:grid}