/* ✅ Project page ONLY — does NOT override global .btn */

:root{
  --p-bg:#f5f5f7;
  --p-card:#ffffff;
  --p-text:#111827;
  --p-muted:#6b7280;
  --p-border:#e5e7eb;
  --p-accent:#c99a5b;
  --p-shadow: 0 18px 40px rgba(15,23,42,.10);
  --p-radius: 18px;
  --p-radius2: 24px;
}

.project-hero{padding: 56px 0 22px; background: var(--p-bg);}
.project-hero-inner{
  display:grid; grid-template-columns: 1.25fr .75fr;
  gap: 28px; align-items: stretch;
}

.project-chip{
  display:inline-flex; padding: 8px 12px; border-radius: 999px;
  border: 1px solid rgba(201,154,91,.35);
  background: rgba(255,255,255,.55);
  color: #7c5b2c; font-weight: 650; margin-bottom: 14px;
}
.project-h1{
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin: 0 0 14px;
}
.project-sub{color: var(--p-muted); font-size: 16px; max-width: 56ch; margin:0 0 22px}

.project-actions{display:flex; gap:12px; align-items:center; flex-wrap:wrap}

/* ✅ project buttons (won't touch .btn) */
.pbtn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(17,24,39,.12);
  background: rgba(255,255,255,.9);
  box-shadow: 0 8px 16px rgba(15,23,42,.06);
  cursor:pointer;
  font-weight: 650;
  text-decoration:none;
}
.pbtn:hover{transform: translateY(-1px)}
.pbtn-primary{background:#111827;color:#fff;border-color:#111827}
.pbtn-ghost{background: transparent; box-shadow:none}
.pbtn-small{padding:10px 12px}

.project-metrics{margin-top: 22px; display:flex; gap:18px; flex-wrap:wrap;}
.project-metric{
  background: rgba(255,255,255,.8);
  border:1px solid rgba(229,231,235,.9);
  border-radius: 16px;
  padding: 12px 14px;
  min-width: 140px;
}
.project-metric-num{font-size:18px; font-weight:800}
.project-metric-label{color: var(--p-muted); font-size: 13px; margin-top: 4px}

.project-hero-media{position:relative}
.project-hero-card{
  height: 100%;
  min-height: 240px;
  border-radius: var(--p-radius2);
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(229,231,235,.9);
  box-shadow: var(--p-shadow);
  padding: 18px;
  overflow:hidden;
  position:relative;
}
.project-hero-badge{
  position:absolute; top:16px; right:16px;
  background: rgba(17,24,39,.92);
  color:#fff;
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 12px;
}
.project-hero-title{font-weight:900; font-size:18px; margin-top: 34px}
.project-hero-meta{color: var(--p-muted); margin-top: 6px}
.project-hero-img{
  margin-top: 16px;
  height: 160px;
  border-radius: 18px;
  background:
    radial-gradient(120px 120px at 20% 20%, rgba(201,154,91,.45), transparent 60%),
    radial-gradient(180px 180px at 70% 40%, rgba(17,24,39,.18), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.9), rgba(245,245,247,.7));
  border: 1px solid rgba(229,231,235,.9);
}

/* Controls */
.project-controls{padding: 10px 0 10px; background: var(--p-bg);}
.project-controls-inner{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap: 18px; flex-wrap:wrap;
}
.project-controls-left h2{margin:0; font-size: 22px; letter-spacing:-.01em}
.project-controls-hint{margin:6px 0 0; color: var(--p-muted); font-size: 14px}
.project-controls-right{display:flex; gap: 10px; flex-wrap:wrap; align-items:center}

.project-field input, .project-field select{
  appearance:none;
  border: 1px solid rgba(229,231,235,.95);
  background: rgba(255,255,255,.85);
  border-radius: 14px;
  padding: 12px 12px;
  min-width: 220px;
  outline: none;
  color: var(--p-text);
}
.project-field select{min-width: 170px}

/* Grid */
.project-grid{
  padding: 16px 0 56px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.project-card{
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(229,231,235,.95);
  border-radius: var(--p-radius2);
  overflow:hidden;
  box-shadow: 0 12px 26px rgba(15,23,42,.08);
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease;
}
.project-card:hover{transform: translateY(-2px); box-shadow: 0 18px 42px rgba(15,23,42,.12);}
.project-thumb{
  height: 180px;
  background:
    radial-gradient(140px 140px at 20% 20%, rgba(201,154,91,.40), transparent 60%),
    radial-gradient(200px 200px at 70% 30%, rgba(17,24,39,.15), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.9), rgba(245,245,247,.65));
}
.project-card-body{padding: 14px 14px 16px}
.project-tags{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px}
.project-pill{
  display:inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(201,154,91,.12);
  border: 1px solid rgba(201,154,91,.22);
  color: #6b4a1d;
  font-size: 12px;
  font-weight: 650;
}
.project-pill-subtle{
  background: rgba(17,24,39,.06);
  border-color: rgba(17,24,39,.10);
  color: rgba(17,24,39,.75);
}
.project-title{margin:0; font-size: 16px; letter-spacing:-.01em; font-weight: 850}
.project-meta{margin-top:6px; color: var(--p-muted); font-size: 13px}
.project-foot{margin-top: 12px; display:flex; justify-content:space-between; align-items:center; font-size: 13px; color: rgba(17,24,39,.75);}
.project-more{font-weight:750; color:#111827}

/* Empty */
.project-empty{
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(229,231,235,.95);
  border-radius: var(--p-radius2);
  padding: 28px;
  text-align:center;
  margin-bottom: 56px;
  box-shadow: var(--p-shadow);
}
.project-empty p{color: var(--p-muted)}

/* CTA */
.project-cta{padding: 26px 0 56px; background: var(--p-bg);}
.project-cta-inner{
  display:flex; align-items:center; justify-content:space-between; gap: 18px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(229,231,235,.95);
  border-radius: var(--p-radius2);
  padding: 22px;
  box-shadow: var(--p-shadow);
}
.project-cta p{margin:0; color: var(--p-muted); max-width: 62ch}

/* Modal */
.project-modal{position:fixed; inset:0; display:none; z-index:100}
.project-modal[aria-hidden="false"]{display:block}
.project-modal-backdrop{
  position:absolute; inset:0;
  background: rgba(17,24,39,.40);
  backdrop-filter: blur(8px);
}
.project-modal-panel{
  position: relative;
  width: min(980px, calc(100% - 28px));
  margin: 28px auto;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(229,231,235,.95);
  border-radius: 28px;
  overflow:hidden;
  box-shadow: 0 30px 90px rgba(15,23,42,.26);
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  min-height: 520px;
}
.project-modal-close{
  position:absolute; top:14px; right:14px; z-index:2;
  width: 38px; height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(17,24,39,.12);
  background: rgba(255,255,255,.9);
  cursor:pointer;
}
.project-modal-media{
  background:
    radial-gradient(180px 180px at 20% 20%, rgba(201,154,91,.42), transparent 60%),
    radial-gradient(260px 260px at 70% 30%, rgba(17,24,39,.16), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.95), rgba(245,245,247,.70));
}
.project-modal-body{padding: 22px 22px 24px}
.project-modal-desc{color: var(--p-muted)}
.project-modal-kv{display:grid; grid-template-columns: 1fr 1fr; gap: 12px;}
.project-kv{
  background: rgba(17,24,39,.04);
  border: 1px solid rgba(17,24,39,.06);
  border-radius: 16px;
  padding: 12px;
}
.project-kv-label{font-size: 12px; color: rgba(17,24,39,.62); margin-bottom: 4px}
.project-kv-value{font-weight: 750}
.project-modal-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top: 16px}

@media (max-width: 980px){
  .project-hero-inner{grid-template-columns: 1fr;}
  .project-modal-panel{grid-template-columns: 1fr; min-height: 0}
  .project-modal-media{height: 260px}
  .project-grid{grid-template-columns: repeat(2, 1fr)}
}
@media (max-width: 560px){
  .project-grid{grid-template-columns: 1fr}
  .project-field input{min-width: 100%}
  .project-field select{min-width: 160px}
  .project-cta-inner{flex-direction:column; align-items:flex-start}
}
