/* ═══════════════════════════════════════════════════════════════
   Design Corner 2.0 — components.css
   Buttons · Cards · Blobs · Tilt · Form · All UI pieces
   ═══════════════════════════════════════════════════════════════ */

/* ══════════════════════
   BUTTONS
══════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--ff);
  font-weight: 700;
  letter-spacing: .05em;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform .35s var(--ease-2), box-shadow .35s;
}
/* ripple */
.btn::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 0; height: 0;
  background: rgba(255,255,255,.15);
  border-radius: 50%;
  transform: translate(-50%,-50%);
  transition: width .5s var(--ease), height .5s var(--ease), opacity .5s;
  opacity: 0;
}
.btn:active::before { width: 200px; height: 200px; opacity: 1; }
.btn svg { transition: transform .35s var(--ease-2); flex-shrink: 0; }

/* Primary */
.btn--primary {
  background: var(--yellow);
  color: var(--black);
  font-size: .86rem;
  padding: .9rem 2rem;
}
.btn--primary:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 20px 60px rgba(252,214,0,.28), 0 4px 16px rgba(252,214,0,.15);
}
.btn--primary:hover svg { transform: translateX(4px); }

/* Ghost */
.btn--ghost {
  background: transparent;
  color: var(--muted);
  font-size: .82rem;
  padding: .9rem 1.8rem;
  border: 1px solid var(--border-2);
}
.btn--ghost:hover {
  color: var(--white);
  border-color: var(--muted-2);
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(0,0,0,.4);
}

/* Text */
.btn--text {
  background: none;
  color: var(--yellow);
  font-size: .78rem;
  padding: 0;
  font-weight: 600;
  letter-spacing: .06em;
  overflow: visible;
}
.btn--text:hover { opacity: .7; }
.btn--text:hover svg { transform: translateX(5px); }
.btn--text::before { display: none; }

/* Magnetic wrapper (JS-powered) */
.magnetic-wrap { display: inline-block; }

/* ══════════════════════
   BLOBS
══════════════════════ */
.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  will-change: transform;
  opacity: .7;
}
.blob--yellow {
  background: radial-gradient(circle, rgba(252,214,0,.18) 0%, rgba(252,180,0,.06) 60%, transparent 80%);
}
.blob--yellow-sm {
  background: radial-gradient(circle, rgba(252,214,0,.12) 0%, transparent 70%);
}

/* SVG morphing blob */
.blob-morph {
  position: absolute;
  pointer-events: none;
  will-change: transform;
}
.blob-morph path {
  animation: blob-anim 12s ease-in-out infinite alternate;
}
@keyframes blob-anim {
  0%   { d: path("M60,20 C80,5 100,15 110,35 C120,55 115,80 95,90 C75,100 45,95 30,75 C15,55 20,30 40,20 Z"); }
  33%  { d: path("M65,15 C88,8 108,20 112,45 C116,70 100,92 78,96 C56,100 32,88 22,65 C12,42 22,18 45,15 Z"); }
  66%  { d: path("M55,22 C78,5 105,18 114,42 C123,66 108,90 84,96 C60,102 35,90 25,68 C15,46 25,35 45,22 Z"); }
  100% { d: path("M60,20 C82,8 102,22 108,46 C114,70 98,94 74,98 C50,102 28,86 20,62 C12,38 22,28 42,18 Z"); }
}

/* ══════════════════════
   TILT CARDS
══════════════════════ */
.tilt-card {
  transform-style: preserve-3d;
  will-change: transform;
  transition: transform .08s linear, box-shadow .35s;
}
.tilt-card:hover { box-shadow: 0 30px 80px rgba(0,0,0,.6); }
.tilt-card .tilt-inner {
  transform-style: preserve-3d;
}
.tilt-card .tilt-shine {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.08) 0%, transparent 60%);
  pointer-events: none;
  transition: background .1s;
}

/* Card base */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  position: relative;
  overflow: hidden;
}
.card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(252,214,0,.3), transparent);
  opacity: 0;
  transition: opacity .4s;
}
.card:hover::after { opacity: 1; }

/* ══════════════════════
   CAPABILITY CARDS
══════════════════════ */
.cap-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
}

.cap-card {
  padding: 2.2rem;
  cursor: default;
  transition: border-color .4s, background .4s;
}
.cap-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--yellow), var(--yellow-2));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .55s var(--ease);
  border-radius: 2px 2px 0 0;
}
.cap-card:hover { background: #141414; border-color: var(--border-2); }
.cap-card:hover::before { transform: scaleX(1); }
.cap-card:hover .cap-icon { border-color: rgba(252,214,0,.35); background: rgba(252,214,0,.07); }
.cap-card:hover .cap-num-bg { opacity: .06; transform: scale(1.08); }

.cap-icon {
  width: 44px; height: 44px;
  border: 1px solid var(--border);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--yellow);
  margin-bottom: 1.6rem;
  transition: border-color .3s, background .3s;
  position: relative;
  z-index: 1;
}
.cap-num-bg {
  position: absolute;
  bottom: 1.5rem; right: 1.5rem;
  font-size: 5rem;
  font-weight: 800;
  color: var(--yellow);
  opacity: .03;
  line-height: 1;
  transition: opacity .4s, transform .4s var(--ease);
  pointer-events: none;
  letter-spacing: -.06em;
}
.cap-card h3 { font-size: .95rem; margin-bottom: .5rem; position: relative; z-index: 1; }
.cap-card p { font-size: .82rem; line-height: 1.75; position: relative; z-index: 1; }
.cap-card .cap-arrow {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  margin-top: 1.2rem;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .08em;
  color: var(--yellow);
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity .35s, transform .35s var(--ease);
  position: relative; z-index: 1;
}
.cap-card:hover .cap-arrow { opacity: 1; transform: translateX(0); }

/* ══════════════════════
   BLOG / POST CARDS
══════════════════════ */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; }

.post-card {
  padding: 2rem;
  display: flex; flex-direction: column;
  transition: border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s;
}
.post-card:hover {
  border-color: rgba(252,214,0,.18);
  transform: translateY(-8px) rotate(-.4deg);
  box-shadow: 0 28px 70px rgba(0,0,0,.5), 0 0 0 1px rgba(252,214,0,.06);
}

.post-tag {
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: .7rem;
}
.post-card h3 {
  font-size: .98rem;
  letter-spacing: -.02em;
  line-height: 1.35;
  margin-bottom: .65rem;
  flex: 1;
}
.post-card p { font-size: .8rem; line-height: 1.75; margin-bottom: 1.4rem; }

/* ══════════════════════
   CTA BAND
══════════════════════ */
.cta-band {
  position: relative;
  overflow: hidden;
  text-align: center;
  background: var(--black);
  border-top: 1px solid var(--border);
}
.cta-band .grid-bg {
  mask-image: radial-gradient(ellipse 55% 80% at 50% 50%, black, transparent 72%);
  opacity: .4;
}
.cta-band-inner { position: relative; z-index: 1; padding: 8rem 0; }
.cta-band h2 { margin-bottom: 1rem; }
.cta-band p  { font-size: .95rem; margin-bottom: 2.6rem; }

/* ══════════════════════
   FORM
══════════════════════ */
.contact-form {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 3rem;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { margin-bottom: 1.4rem; }
.form-group label {
  display: block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin-bottom: .5rem;
}
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  background: var(--card-2);
  border: 1px solid var(--border-2);
  border-radius: 4px;
  color: var(--white);
  font-size: .88rem;
  font-weight: 400;
  padding: .85rem 1.1rem;
  outline: none;
  resize: vertical;
  transition: border-color .3s, box-shadow .3s;
  -webkit-appearance: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--muted-2); }
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: rgba(252,214,0,.45);
  box-shadow: 0 0 0 3px rgba(252,214,0,.07);
}
.form-group textarea { min-height: 140px; }
.form-group select option { background: #1a1a1a; }

/* ══════════════════════
   ICON BOX
══════════════════════ */
.icon-box {
  width: 42px; height: 42px;
  border: 1px solid var(--border);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--yellow);
  flex-shrink: 0;
  transition: border-color .3s, background .3s;
}

/* ══════════════════════
   STEP / SHIFT
══════════════════════ */
.shift-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.shift-steps { display: flex; flex-direction: column; }
.shift-step {
  display: flex; gap: 1.4rem;
  padding: 1.8rem 0;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.shift-step:last-child { border-bottom: none; }
.step-n {
  font-size: .62rem; font-weight: 700; letter-spacing: .16em;
  color: var(--yellow); min-width: 26px; padding-top: .15rem;
}
.step-body h3 { font-size: .95rem; margin-bottom: .4rem; }
.step-body p  { font-size: .82rem; line-height: 1.75; }
.step-tag {
  display: inline-block;
  margin-top: .7rem;
  font-size: .62rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--yellow);
  border: 1px solid rgba(252,214,0,.22);
  border-radius: 100px; padding: .18rem .65rem;
}

/* ══════════════════════
   ABOUT PHILOSOPHY GRID
══════════════════════ */
.philo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
}
.philo-cell {
  background: var(--card);
  padding: 1.8rem;
  display: flex; flex-direction: column; gap: .5rem;
  transition: background .3s;
}
.philo-cell:hover { background: #151515; }
.philo-cell span { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-2); }
.philo-cell strong { font-size: 1.1rem; font-weight: 800; color: var(--white); letter-spacing: -.02em; }
.philo-cell.accent { background: rgba(252,214,0,.06); }
.philo-cell.accent span { color: rgba(252,214,0,.5); }
.philo-cell.accent strong { color: var(--yellow); }

/* ══════════════════════
   TEAM
══════════════════════ */
.team-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.3rem; }
.team-card {
  padding: 2.2rem;
  text-align: center;
}
.team-avatar {
  width: 68px; height: 68px;
  border-radius: 50%;
  background: var(--card-2);
  border: 1px solid var(--border-2);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.1rem;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--yellow);
  transition: border-color .3s, box-shadow .3s;
}
.team-card:hover .team-avatar {
  border-color: rgba(252,214,0,.35);
  box-shadow: 0 0 0 4px rgba(252,214,0,.08);
}
.team-card h3 { font-size: .9rem; margin-bottom: .25rem; }
.team-card span { font-size: .74rem; color: var(--muted); font-weight: 300; }

/* ══════════════════════
   BLOG SINGLE POST
══════════════════════ */
.post-layout { display: grid; grid-template-columns: 1fr 300px; gap: 5rem; align-items: start; }
.post-body { font-size: .94rem; font-weight: 300; line-height: 1.95; }
.post-body h2 { font-size: 1.5rem; margin: 2.5rem 0 .8rem; }
.post-body h3 { font-size: 1.1rem; margin: 1.8rem 0 .6rem; color: var(--off-white); }
.post-body p  { margin-bottom: 1.2rem; }
.post-body blockquote {
  border-left: 2px solid var(--yellow);
  padding: 1.1rem 1.5rem;
  margin: 2rem 0;
  background: rgba(252,214,0,.04);
  border-radius: 0 6px 6px 0;
  font-size: 1.05rem;
  color: var(--off-white);
  font-weight: 400;
  font-style: italic;
  line-height: 1.7;
}
.sidebar-box {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1.8rem;
  margin-bottom: 1.4rem;
}
.sidebar-box h4 { margin-bottom: 1rem; }
.sidebar-box p { font-size: .8rem; line-height: 1.75; }
.toc-list { display: flex; flex-direction: column; gap: .55rem; }
.toc-list a { font-size: .8rem; color: var(--muted); transition: color .2s; }
.toc-list a:hover { color: var(--yellow); }
.post-sidebar { position: sticky; top: 6rem; }

/* Contact layout */
.contact-layout { display: grid; grid-template-columns: 1fr 1.5fr; gap: 5rem; align-items: start; }
.contact-details { display: flex; flex-direction: column; gap: 1.2rem; margin-top: 2rem; }
.contact-detail { display: flex; gap: 1rem; align-items: flex-start; }
.contact-detail-text span { font-size: .66rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted-2); display: block; margin-bottom: .2rem; }
.contact-detail-text p { font-size: .84rem; font-weight: 400; color: var(--text); margin: 0; }

/* Blog list */
.blog-list-item {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 2.5rem; padding: 2.5rem 0;
  border-bottom: 1px solid var(--border);
  align-items: center;
  transition: none;
}
.blog-list-item:first-child { border-top: 1px solid var(--border); }
.blog-list-item:hover .blog-list-title { color: var(--yellow); }
.blog-list-num { font-size: .66rem; font-weight: 700; letter-spacing: .12em; color: var(--muted-2); min-width: 26px; }
.blog-list-title { font-size: 1.02rem; font-weight: 700; color: var(--white); letter-spacing: -.02em; margin-bottom: .4rem; transition: color .25s; }
.blog-list-excerpt { font-size: .81rem; color: var(--muted); max-width: 540px; line-height: 1.7; }
.blog-list-meta { display: flex; flex-direction: column; align-items: flex-end; gap: .5rem; }
.blog-cat { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--yellow); }
.blog-date { font-size: .72rem; color: var(--muted-2); white-space: nowrap; }

/* ══════════════════════
   RESPONSIVE COMPONENTS
══════════════════════ */
@media (max-width: 960px) {
  .cap-cards-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .shift-grid { grid-template-columns: 1fr; gap: 3rem; }
  .post-layout { grid-template-columns: 1fr; }
  .post-sidebar { display: none; }
  .contact-layout { grid-template-columns: 1fr; gap: 3rem; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .blog-list-item { grid-template-columns: 1fr; gap: .5rem; }
  .blog-list-num, .blog-list-meta { display: none; }
  .philo-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .team-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .contact-form { padding: 2rem; }
}
