/* ============================================================
   Diamond TechSoft — About Page Styles
   File: assets/css/about.css
   ============================================================ */

.stats-row { padding: 60px 0; border-bottom: 1px solid var(--border); }
.stat-box {
  text-align: center; padding: 24px;
  background: var(--blue-card); border: 1px solid var(--border);
  border-radius: 16px; transition: all .3s;
}
.stat-box:hover { border-color: rgba(0,212,255,.3); transform: translateY(-4px); }
.stat-box .stat-num { font-family: var(--font-head); font-size: 2.8rem; font-weight: 800; color: var(--text-heading); line-height: 1; }
.stat-box .stat-num span { color: var(--accent); }
.stat-box .stat-label { font-size: .8rem; color: var(--text-muted); margin-top: 6px; text-transform: uppercase; letter-spacing: 1px; }

.story-section { padding: 90px 0; }
.story-text h2 { font-family: var(--font-head); font-size: clamp(1.8rem,3vw,2.6rem); font-weight: 800; color: var(--text-heading); line-height: 1.2; letter-spacing: -1px; margin-bottom: 24px; }
.story-text h2 span { background: linear-gradient(90deg,var(--accent),var(--accent2)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.story-text p { font-size: .95rem; color: var(--text-muted); line-height: 1.85; margin-bottom: 20px; }
.story-card { background: var(--blue-card); border: 1px solid var(--border); border-radius: 20px; padding: 36px; height: 100%; }
.story-highlight { border-left: 2px solid var(--accent); padding-left: 20px; margin: 28px 0; font-size: 1.05rem; color: var(--text-heading); font-style: italic; line-height: 1.7; }
.story-mini-card { background: rgba(0,212,255,.06); border: 1px solid var(--border); border-radius: 14px; padding: 24px; text-align: center; }
.story-mini-card .sm-icon { font-size: 2rem; margin-bottom: 8px; }
.story-mini-card .sm-title { font-family: var(--font-head); font-size: .9rem; font-weight: 700; color: var(--text-heading); }
.story-mini-card .sm-sub { font-size: .75rem; color: var(--text-muted); margin-top: 4px; }
.industry-tag { background: var(--blue-dark); border: 1px solid var(--border); border-radius: 6px; padding: 4px 10px; font-size: .75rem; color: var(--text-muted); }

.mv-section { padding: 80px 0; background: linear-gradient(180deg,transparent,rgba(123,92,240,.04),transparent); }
.mv-card {
  background: var(--blue-card); border: 1px solid var(--border);
  border-radius: 20px; padding: 40px; height: 100%;
  transition: all .3s; position: relative; overflow: hidden;
}
.mv-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; transition: transform .3s; transform: scaleX(0); transform-origin: left; }
.mv-card.vision::before { background: linear-gradient(90deg,var(--accent),#00f0a0); }
.mv-card.mission::before { background: linear-gradient(90deg,var(--accent2),var(--accent)); }
.mv-card.values::before { background: linear-gradient(90deg,var(--accent-gold),#f97316); }
.mv-card:hover { border-color: rgba(0,212,255,.25); transform: translateY(-5px); }
.mv-card:hover::before { transform: scaleX(1); }
.mv-icon { font-size: 2.4rem; margin-bottom: 20px; display: block; }
.mv-card h3 { font-family: var(--font-head); font-size: 1.3rem; font-weight: 800; color: var(--text-heading); margin-bottom: 16px; }
.mv-card p { font-size: .88rem; color: var(--text-muted); line-height: 1.75; }
.mv-list { list-style: none; padding: 0; margin-top: 16px; }
.mv-list li { font-size: .85rem; color: var(--text-muted); padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,.04); display: flex; align-items: flex-start; gap: 10px; line-height: 1.5; }
.mv-list li::before { content: '◆'; color: var(--accent); font-size: .5rem; margin-top: 5px; flex-shrink: 0; }
.mv-list li:last-child { border-bottom: none; }

.team-section { padding: 80px 0; }
.team-card { background: var(--blue-card); border: 1px solid var(--border); border-radius: 18px; overflow: hidden; transition: all .35s; height: 100%; }
.team-card:hover { border-color: rgba(0,212,255,.3); transform: translateY(-6px); box-shadow: 0 20px 60px rgba(0,0,0,.4); }
.team-avatar { height: 200px; display: flex; align-items: center; justify-content: center; font-size: 4rem; position: relative; overflow: hidden; }
.team-avatar::after { content: ''; position: absolute; inset: 0; background: linear-gradient(0deg,var(--blue-card) 0%,transparent 60%); }
.team-info { padding: 24px; }
.team-name { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; color: var(--text-heading); margin-bottom: 4px; }
.team-role { font-size: .8rem; color: var(--accent); font-weight: 500; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.team-bio { font-size: .82rem; color: var(--text-muted); line-height: 1.6; }
.team-skills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.skill-tag { background: rgba(0,212,255,.07); border: 1px solid rgba(0,212,255,.15); border-radius: 6px; padding: 3px 10px; font-size: .7rem; color: var(--accent); font-weight: 500; }

.timeline-section { padding: 80px 0; border-top: 1px solid var(--border); }
.timeline { position: relative; padding-left: 40px; }
.timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 1px; background: linear-gradient(180deg,transparent,var(--accent),var(--accent2),transparent); opacity: .4; }
.tl-item { position: relative; margin-bottom: 40px; }
.tl-dot { position: absolute; left: -40px; top: 4px; width: 18px; height: 18px; border-radius: 50%; background: var(--blue-card); border: 2px solid var(--accent); display: flex; align-items: center; justify-content: center; }
.tl-dot::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.tl-year { font-family: var(--font-head); font-size: .8rem; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 6px; }
.tl-item h4 { font-family: var(--font-head); font-size: 1rem; font-weight: 700; color: var(--text-heading); margin-bottom: 6px; }
.tl-item p { font-size: .85rem; color: var(--text-muted); line-height: 1.65; }

.awards-section { padding: 60px 0; background: linear-gradient(180deg,transparent,rgba(0,212,255,.02),transparent); }
.award-card { background: var(--blue-card); border: 1px solid var(--border); border-radius: 14px; padding: 24px; text-align: center; transition: all .3s; }
.award-card:hover { border-color: rgba(245,197,66,.3); transform: translateY(-3px); }
.award-icon { font-size: 2rem; margin-bottom: 12px; }
.award-title { font-family: var(--font-head); font-size: .9rem; font-weight: 700; color: var(--text-heading); margin-bottom: 4px; }
.award-org { font-size: .75rem; color: var(--text-muted); }

/* ============================================================
   RESPONSIVE — about.css
   ============================================================ */


/* ============================================================
   RESPONSIVE — about.css
   ============================================================ */

/* ── Tablet (≤ 991px) ─────────────────────────────────────── */
@media (max-width: 991px) {
  .stats-row { padding: 48px 0; }
  .story-section,
  .mv-section,
  .team-section,
  .timeline-section,
  .awards-section { padding: 64px 0; }
  .story-card { margin-top: 28px; }
  .mv-card { padding: 28px; }
}

/* ── Mobile (≤ 767px) ─────────────────────────────────────── */
@media (max-width: 767px) {
  /* Stats row */
  .stat-box { padding: 18px; }
  .stat-box .stat-num { font-size: 2.2rem; }
  .stats-row { padding: 36px 0; }

  /* Story */
  .story-text h2 { font-size: clamp(1.6rem, 6vw, 2.2rem); }
  .story-card { padding: 24px; }
  .story-highlight { font-size: .95rem; }
  .story-mini-card { padding: 18px; }

  /* Mission / Vision / Values */
  .mv-card { padding: 24px; margin-bottom: 16px; }
  .mv-card h3 { font-size: 1.1rem; }

  /* Team */
  .team-avatar { height: 160px; font-size: 3rem; }
  .team-info { padding: 18px; }
  .team-name { font-size: 1rem; }
  .team-bio { font-size: .8rem; }

  /* Timeline */
  .timeline { padding-left: 28px; }
  .timeline::before { left: 4px; }
  .tl-dot { left: -28px; width: 14px; height: 14px; }
  .tl-dot::before { width: 4px; height: 4px; }
  .tl-item { margin-bottom: 28px; }
  .tl-item h4 { font-size: .92rem; }
  .tl-item p { font-size: .82rem; }

  /* Awards */
  .award-card { padding: 18px; }
  .award-icon { font-size: 1.6rem; }
  .award-title { font-size: .82rem; }

  /* Section spacing */
  .story-section,
  .mv-section,
  .team-section,
  .timeline-section,
  .awards-section { padding: 48px 0; }
}

/* ── Small Mobile (≤ 480px) ───────────────────────────────── */
@media (max-width: 480px) {
  .stat-box .stat-num { font-size: 1.9rem; }
  .stat-box { padding: 14px; }
}
