/*
Theme Name: Astra Child
Template: astra
Description: FarhadProject Magazine / Corporate Engineering layout (B/W, fast)
Version: 1.1.0
*/


/* Fonts */
@font-face{
  font-family: "IRANSans";
  src: url("./fonts/IRANSans-Edit.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face{
  font-family: "IRANSans";
  src: url("./fonts/IRANSansBold-Edit.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}


/* Base typography */
:root{
  --mag-max: 1440px;
  --radius: 18px;
  --radius-lg: 26px;

  /* Use fp-theme tokens if loaded */
  --bg: var(--fp-bg, #fff);
  --surface: var(--fp-surface, #fff);
  --text: var(--fp-text, #111);
  --muted: var(--fp-muted, #444);
  --border: var(--fp-border, #e6e6e6);

  --s1: var(--s1, 8px);
  --s2: var(--s2, 13px);
  --s3: var(--s3, 21px);
  --s4: var(--s4, 34px);
  --s5: var(--s5, 55px);
}

body{
  font-family: IRANSans, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
}

/* Prevent Astra header/menu color bugs */
.ast-primary-header-bar, .ast-header-break-point .ast-mobile-header-wrap{
  background: var(--bg);
}
.ast-builder-menu-1 .main-header-menu a,
.ast-builder-menu-1 .main-header-menu .menu-link{
  color: var(--text);
}
html[data-theme="dark"] .ast-builder-menu-1 .main-header-menu a,
html[data-theme="dark"] .ast-builder-menu-1 .main-header-menu .menu-link{
  color: var(--text);
}

/* Magazine wrapper */
.mag{
  padding: var(--s4) 0;
  margin: 0 auto !important;
}
.mag__container{
  max-width: var(--mag-max);
  margin: 0 auto;
  padding-left: max(var(--s3), env(safe-area-inset-left));
  padding-right: max(var(--s3), env(safe-area-inset-right));
}
.mag__mast{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: var(--s3);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--s4);
}
.mag__title{
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  margin: 0 0 var(--s1);
  letter-spacing: -0.2px;
  font-weight: 900;
}
.mag__tag{ margin:0; color: var(--muted); }
.mag__meta{ display:flex; gap: var(--s2); flex-wrap:wrap; }

.mag__chip{
  display:inline-flex;
  align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-weight: 800;
  font-size: 12px;
  color: var(--muted);
}

/* Section headings */
.mag__section{ margin: var(--s5) 0; }
.mag__section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: var(--s2);
  margin-bottom: var(--s3);
}
.mag__h1{
  font-size: clamp(1.5rem, 2.8vw, 2.15rem);
  margin:0;
  font-weight: 900;
}
.mag__h2{
  font-size: 1.25rem;
  margin:0;
  font-weight: 900;
}
.link{ color: var(--text); text-decoration: underline; text-underline-offset: 3px; }

/* Feature layout */
.mag__feature{
  display:grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--s4);
  align-items:start;
}
@media (max-width: 960px){
  .mag__feature{ grid-template-columns: 1fr; }
}

/* Grid */
.grid{ display:grid; gap: var(--s3); }
.grid--cards{ grid-template-columns: repeat(3, minmax(0,1fr)); }
@media (max-width: 980px){ .grid--cards{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 640px){ .grid--cards{ grid-template-columns: 1fr; } }

.grid--cols{ grid-template-columns: repeat(3, minmax(0,1fr)); }
@media (max-width: 980px){ .grid--cols{ grid-template-columns: 1fr; } }

/* Card */
.card{
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow:hidden;
  background: var(--surface);
}
.card__media{ display:block; aspect-ratio: 16/9; background: #f2f2f2; }
html[data-theme="dark"] .card__media{ background:#111; }
.card__img{
  width:100%; height:100%;
  object-fit: cover;
  display:block;
}
.card__ph{
  height:100%;
  display:flex; align-items:center; justify-content:center;
  color: var(--muted);
  font-weight: 800;
}
.card__body{ padding: var(--s3); }
.card__kicker{ font-size:12px; font-weight:900; color: var(--muted); margin-bottom: var(--s1); }
.card__title{ margin:0 0 var(--s2); font-weight: 900; line-height: 1.35; }
.card__title a{ color: var(--text); text-decoration:none; }
.card__title a:hover{ text-decoration: underline; text-underline-offset: 3px; }
.card__title--sm{ font-size: 1.05rem; }
.card__excerpt{ margin:0 0 var(--s2); color: var(--muted); }
.card__footer{ display:flex; gap: var(--s2); flex-wrap:wrap; }
.card__pill{
  display:inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
}

/* Feature card */
.card--feature .card__body{ padding: var(--s4); }
.card--feature .card__title{ font-size: 1.35rem; }

/* Panel */
.panel{
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--s3);
  background: var(--surface);
  display: block;
}
.panel__title{ margin:0 0 var(--s2); font-weight: 900; }
.muted{ color: var(--muted); margin:0; }

/* Lists */
.list{ list-style:none; padding:0; margin:0 0 var(--s3); display:flex; flex-direction:column; gap: var(--s2); }
.list__item{ display:flex; justify-content:space-between; gap: var(--s2); align-items:baseline; }
.list__link{ color: var(--text); text-decoration:none; font-weight: 900; }
.list__link:hover{ text-decoration: underline; }
.list__meta{ color: var(--muted); font-size: 12px; white-space:nowrap; }

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--text);
  color: var(--bg);
  font-weight: 900;
  text-decoration:none;
}
.btn--ghost{
  background: var(--surface);
  color: var(--text);
}
.btn:hover{ filter: brightness(0.98); }

/* Single project layout */
.proj__head{ display:grid; grid-template-columns: 1.2fr 1fr; gap: var(--s4); align-items: end; margin-bottom: var(--s4); }
@media (max-width: 960px){ .proj__head{ grid-template-columns: 1fr; } }
.proj__hero{ margin:0; border-radius: var(--radius-lg); overflow:hidden; border: 1px solid var(--border); }
.proj__img{ width:100%; height:auto; display:block; }
.proj__chips{ display:flex; gap: var(--s2); flex-wrap:wrap; margin-top: var(--s2); }

.proj__grid{ display:grid; grid-template-columns: 1.7fr .9fr; gap: var(--s4); align-items:start; }
@media (max-width: 960px){ .proj__grid{ grid-template-columns: 1fr; } }
.kv{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap: var(--s2); }
.kv li{ display:flex; justify-content:space-between; gap: var(--s2); }
.kv b{ font-weight: 900; color: var(--text); }
.kv span{ color: var(--muted); text-align:left; direction:ltr; }

/* Make Gutenberg content breathe */
.proj__content > *{ margin-bottom: var(--s4); }

/* Pagination */
.mag__pager{ margin-top: var(--s4); }

/* Accessibility */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; }
}
