/* =========================
   Ayoub — Portfolio Styles
   ========================= */

/* === Base / Theme === */
:root{
  --bg:#0b0d12;         /* page background (dark) */
  --surface:#0b0d12;
  --panel:#121627;      /* cards / panels */
  --line:#23283a;       /* borders */
  --text:#e6e9ef;       /* main text */
  --muted:#98a2b3;      /* secondary text */
  --brand:#ed1c24;      /* red accent */
  --accent:#4cc9f0;     /* cyan accent */
  --ok:#2ecc71;         /* success green */
  --ring:rgba(237,28,36,.35); /* focus ring */
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(237,28,36,.07), transparent 60%),
    radial-gradient(900px 500px at 120% 10%, rgba(76,201,240,.06), transparent 60%),
    var(--bg);
  color:var(--text);
  font:16px/1.6 Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
a{color:var(--accent);text-decoration:none}

.container{max-width:1100px;margin:auto;padding:24px}

/* === Header === */
.site-header{
  position:sticky; top:0; z-index:50;
  background:linear-gradient(180deg, rgba(11,13,18,.92), rgba(11,13,18,0));
  backdrop-filter:saturate(1.1) blur(12px);
  border-bottom:1px solid #1a1f2e;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px;color:var(--text)}
.logo{
  width:36px;height:36px;border-radius:50%;
  background:conic-gradient(from 210deg, var(--brand), #b4161c 40%, #ff3b3f 70%);
  box-shadow:0 0 0 2px #ffffff0d inset, 0 0 34px var(--ring);
}
.site-logo{width:36px;height:36px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 2px #ffffff0d inset, 0 0 34px var(--ring)}
.links{display:flex;align-items:center;gap:14px}
.links a{color:var(--text)}
.btn{
  border:1px solid #2a3042;
  background:linear-gradient(180deg,#171a26,#0f1320);
  color:var(--text);
  padding:8px 14px;border-radius:12px;cursor:pointer
}
.btn:hover{box-shadow:0 0 0 2px var(--ring)}
.btn.primary{background:linear-gradient(180deg,#ed1c24,#c5151b);border-color:#ed1c24}
.btn.ghost{background:transparent}
.mobile-only{display:none}
.mobile-menu{
  display:flex;flex-direction:column;gap:10px;
  padding:14px 24px;border-top:1px solid #1a1f2e;
  background:linear-gradient(180deg,#0b0d12,#0b0d1200)
}
.mobile-menu a{color:var(--text);padding:8px 0}

/* === Hero === */
.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:center}
.hero-copy{position:relative;z-index:1}
.hero h1{font-size:clamp(30px,4vw,46px);line-height:1.1;margin:.2em 0 .4em;font-weight:800;color:var(--text)}
.hero p{color:var(--muted);margin:0 0 14px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.badge.verified{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border:1px solid #1f2741;border-radius:999px;
  background:#0e1424;color:#e6e9ef;font-weight:600
}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(46,204,113,.18)}
.accent{color:var(--accent)}
.hero-art{position:relative;z-index:0;height:280px}
.orb{position:absolute;filter:blur(18px);border-radius:999px;opacity:.75}
.orb-red{
  background:radial-gradient(circle at 30% 30%, #ff4d59, #c5151b 60%, transparent 70%);
  width:260px;height:260px;top:-10px;left:10px
}
.orb-cyan{
  background:radial-gradient(circle at 70% 70%, #7fe3ff, #1487a0 60%, transparent 70%);
  width:220px;height:220px;bottom:-10px;right:-10px
}
.splash{
  position:absolute;right:10px;bottom:10px;left:120px;
  border:1px solid var(--line);background:var(--panel);
  border-radius:16px;padding:12px;box-shadow:0 10px 40px #00000040;color:var(--text)
}
.pill{
  display:inline-flex;gap:8px;align-items:center;
  padding:6px 10px;border:1px solid #1f2741;border-radius:999px;
  background:#0e1424;color:#e6e9ef;font-size:12px;margin-bottom:10px
}
.splash-body{display:flex;align-items:center;justify-content:space-between}
.splash-title{font-weight:700}
.splash-sub{color:var(--muted);font-size:14px}
.splash-stats{display:flex;gap:14px}
.splash-stats strong{font-size:18px;display:block}
.splash-stats span{font-size:12px;color:var(--muted)}

/* === Sections / Controls === */
.section{padding:28px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}
.controls{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.input{
  background:#ffffff;border:1px solid #fefeff;border-radius:12px;
  color:var(--text);padding:10px 12px;min-width:240px
}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  border:1px solid #2a3042;background:#0f1320;color:#cbd5e1;
  padding:6px 10px;border-radius:999px;cursor:pointer
}
.chip.active,.chip:hover{box-shadow:0 0 0 2px var(--ring)}
.panel{
  border:1px solid var(--line);background:var(--panel);
  border-radius:16px;padding:18px
}
.muted{color:var(--muted)}

/* === Grid / Cards === */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:14px
}
.card{
  border:1px solid var(--line);
  background:var(--panel);
  border-radius:20px;
  padding:16px;
  display:flex;flex-direction:column;gap:10px;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease
}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #00000033;border-color:#2e3650}
.card .title{font-weight:800;color:var(--text);font-size:18px}
.meta{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:12px;border:1px solid #2a3042;border-radius:999px;padding:4px 8px;color:#cbd5e1;background:transparent}
.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.action{font-size:14px}

/* === Card Thumbnails (img or auto initials) === */
.thumb{
  width:100%;height:120px;border-radius:12px;background:#0f1320;display:block;
  object-fit:contain;
}
.thumb.placeholder{
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:28px;letter-spacing:.5px;
  color:#ffffff;text-transform:uppercase;
}

/* === Contact === */
.grid.two{grid-template-columns:1fr 1fr}
.contact-list{display:grid;gap:10px}
.contact-item{
  display:flex;gap:10px;align-items:center;
  border:1px solid var(--line);background:var(--panel);
  border-radius:12px;padding:10px
}
.icon{font-size:18px}
.field{display:grid;gap:6px;margin-bottom:10px}
.field input,.field textarea{
  background:#0f1320;border:1px solid #2a3042;border-radius:12px;color:var(--text);padding:10px 12px
}
.row{display:flex;gap:12px;align-items:center}

/* === Footer === */
.site-footer{border-top:1px solid #1a1f2e;margin-top:24px}
.foot{display:flex;align-items:center;justify-content:space-between}
.top{border:1px solid #2a3042;border-radius:999px;padding:6px 10px;background:#0f1320}

/* === Responsive === */
@media (max-width:960px){
  .hero{grid-template-columns:1fr}
  .hero-art{height:220px}
  .grid.two{grid-template-columns:1fr}
  .mobile-only{display:inline-flex}
}
@media (max-width:640px){
  .controls{flex-direction:column;align-items:stretch}
  .input{min-width:unset;width:100%}
}

/* === Light Theme (auto) === */
@media (prefers-color-scheme: light){
  :root{
    --bg:#f6f7fb; --surface:#ffffff; --panel:#ffffff; --text:#0b0d12;
    --muted:#4b5563; --line:#e5e7eb;
  }
  .logo{box-shadow:none}
  .btn{background:#0f1320;color:#e6e9ef;border-color:#0f1320}
  .btn.ghost{background:transparent;color:var(--text);border-color:#d1d5db}
  .card,.contact-item{background:#fff;border-color:#e5e7eb}
  .tag,.chip{background:#f3f4f6;border-color:#e5e7eb;color:#0b0d12}
  .field input,.field textarea{background:#fff;border-color:#e5e7eb;color:#0b0d12}
  .splash{background:#ffffff;border-color:#e5e7eb;color:#0b0d12}
  .badge.verified,.pill{background:#0e1424;border-color:#1f2741;color:#e6e9ef}
}

/* === Manual Theme Toggle Support === */
:root[data-theme="light"]{
  --bg:#f6f7fb; --surface:#ffffff; --panel:#ffffff; --text:#0b0d12;
  --muted:#4b5563; --line:#e5e7eb;
}

/* ✅ Buttons */
.btn {
  display: inline-block;
  padding: 0.7rem 1.4rem;
  border-radius: 8px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}

/* Primary button (red) */
.btn.primary {
  background: #ed1c24;
  color: #fff;
}

.btn.primary:hover {
  background: #c4141b;
  transform: translateY(-2px);
}

/* Secondary button (light gray instead of black) */
.btn {
  background: #4c61e8;
  color: #333;
}

.btn:hover {
  background: #9491cf;
  transform: translateY(-2px);
}


/* ✅ Make all payment icons resize automatically */
.payment-icon {
  max-width: 100px;   /* sets a maximum width */
  max-height: 40px;   /* sets a maximum height */
  object-fit: contain; /* keeps proportions without distortion */
  display: block;
  margin: 0 auto; /* center the icon */
}
.payment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); 
  gap: 15px;
  align-items: center;
  justify-items: center;
  margin-top: 10px;
}

.payment-grid img {
  max-width: 80px;   /* keeps logos resized */
  max-height: 40px;  /* keeps height consistent */
  object-fit: contain;
  transition: transform 0.2s ease;
}

.payment-grid img:hover {
  transform: scale(1.1);
}
/* Top Interac logo (centered) */
.payment-top {
  display: flex;
  justify-content: center;
  margin-bottom: 15px;
}

.payment-top img {
  max-width: 90px;
  max-height: 45px;
  object-fit: contain;
}

/* 2 per line grid */
.payment-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  align-items: center;
  justify-items: center;
}

.payment-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
}

.payment-item img {
  max-width: 80px;
  max-height: 40px;

  object-fit: contain;
}

.payment-item span {
  font-size: 14px;
  font-weight: 600;
  color: #333;
}
/* Card thumbnails (logos) */
.thumb {
  width: 100%;
  height: 120px;
  border-radius: 12px;
  background: #f9f9f9; /* fallback background */
  object-fit: contain; /* keep proportions */
  display: block;
  padding: 8px; /* avoids logos touching edges */
}