/* ============================================================================
   YazPlatform · ÖzgeçmişYaz (CV builder) styles

   The CV "paper" is always light (it is a printable document), independent of
   the site theme. Customization is driven by CSS custom properties set inline
   by cv-builder.js:  --cv-accent (accent color) · --cv-font (font stack).
   Density (sık/normal/ferah) and the 7 templates are plain modifier classes.
   ============================================================================ */

/* ---- Builder shell layout (form left, preview right) --------------------- */
/* MOBILE FIRST · single column, the PAGE scrolls naturally. The fixed-height,
   independently-scrolling two-column layout is applied ONLY on desktop below. */
.cvb {
  display: grid;
  grid-template-columns: 1fr;
}

.cvb__form {
  border-inline-end: 1px solid var(--border);
  background: var(--bg, var(--card-bg));
  display: flex;
  flex-direction: column;
  min-block-size: 0;
}
.cvb__scroll { padding: clamp(1rem, 3vw, 1.5rem); flex: 1; }
.cvb__foot {
  border-block-start: 1px solid var(--border);
  padding: 0.8rem clamp(1rem, 3vw, 1.5rem);
  display: flex;
  gap: 0.6rem;
  background: var(--card-bg);
  position: sticky;            /* keep PDF / AI actions reachable while scrolling */
  inset-block-end: 0;
  z-index: 5;
}
.cvb__foot .btn { flex: 1; }

.cvb__previewwrap {
  background:
    radial-gradient(60rem 40rem at 80% -10%, var(--accent-dim), transparent 60%),
    var(--surface, #e9e5dc);
  padding: clamp(1rem, 4vw, 2.5rem);
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

@media (min-width: 60em) {
  /* Desktop: two fixed-height columns, each scrolls independently. */
  .cvb {
    grid-template-columns: minmax(22rem, 27rem) minmax(0, 1fr);
    block-size: calc(100dvh - var(--header-h, 4.25rem));
    overflow: hidden;
  }
  .cvb__form { overflow: hidden; }
  .cvb__scroll { overflow-y: auto; }
  .cvb__previewwrap { overflow: auto; }
}
@media (prefers-color-scheme: dark) {
  .cvb__previewwrap { background: radial-gradient(60rem 40rem at 80% -10%, rgba(45,106,79,0.18), transparent 60%), #0c130e; }
}

/* ---- Form controls ------------------------------------------------------- */
.cvb-block { margin-block-end: 1.4rem; }
.cvb-block__title {
  font-family: var(--font-display);
  font-size: var(--step-0);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-block-end: 0.7rem;
  display: flex; align-items: center; gap: 0.5rem;
}
.cvb-grid { display: grid; gap: 0.7rem; }
@media (min-width: 26em) { .cvb-grid--2 { grid-template-columns: 1fr 1fr; } }
.cvb-field { display: grid; gap: 0.3rem; }
.cvb-field > label { font-size: var(--step--1); font-weight: 600; color: var(--text2); }
.cvb-field input, .cvb-field textarea, .cvb-field select {
  inline-size: 100%;
  font: inherit;
  font-size: var(--step--1);
  color: var(--text);
  background: var(--card-bg);
  border: 1px solid var(--border-s);
  border-radius: var(--r-m);
  padding: 0.6rem 0.7rem;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.cvb-field textarea { resize: vertical; min-block-size: 4.5rem; line-height: 1.5; }
.cvb-field input:focus-visible, .cvb-field textarea:focus-visible, .cvb-field select:focus-visible {
  outline: none;
  border-color: var(--accent-l);
  box-shadow: 0 0 0 3px var(--accent-dim);
}
.cvb-hint { font-size: var(--step--2); color: var(--muted); margin-block-start: 0.2rem; }

/* Repeatable entries (experience / education / projects) */
.cvb-entry {
  border: 1px solid var(--border);
  border-radius: var(--r-l);
  padding: 0.85rem;
  margin-block-end: 0.7rem;
  background: var(--card-bg);
  position: relative;
}
.cvb-entry__bar { display: flex; align-items: center; justify-content: space-between; margin-block-end: 0.5rem; }
.cvb-entry__no { font-size: var(--step--1); font-weight: 700; color: var(--accent-l); }
.cvb-entry__rm {
  display: inline-flex; align-items: center; gap: 0.25rem;
  font-size: var(--step--2); font-weight: 600; color: var(--muted);
  padding: 0.25rem 0.5rem; border-radius: var(--r-pill);
}
.cvb-entry__rm:hover { color: #c0492f; background: color-mix(in srgb, #c0492f 10%, transparent); }
.cvb-add {
  inline-size: 100%;
  display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem;
  padding: 0.6rem; border: 1px dashed var(--border); border-radius: var(--r-m);
  font-size: var(--step--1); font-weight: 600; color: var(--accent-l);
  background: transparent; transition: border-color var(--dur-fast), background var(--dur-fast);
}
.cvb-add:hover { border-color: var(--accent-l); background: var(--accent-dim); }
.cvb-add svg { inline-size: 1.05rem; block-size: 1.05rem; }

/* ---- Customization controls --------------------------------------------- */
.cvb-templates { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.55rem; }
@media (min-width: 30em) { .cvb-templates { grid-template-columns: repeat(3, 1fr); } }
.cvb-tmpl {
  border: 1.5px solid var(--border);
  border-radius: var(--r-m);
  padding: 0.4rem;
  background: var(--card-bg);
  cursor: pointer;
  display: grid; gap: 0.3rem;
  transition: border-color var(--dur-fast), transform var(--dur-fast);
}
.cvb-tmpl:hover { transform: translateY(-1px); border-color: color-mix(in srgb, var(--accent-l) 45%, var(--border)); }
.cvb-tmpl.is-active { border-color: var(--accent-l); box-shadow: 0 0 0 2px var(--accent-dim); }
.cvb-tmpl__thumb { aspect-ratio: 3 / 4; border-radius: 4px; overflow: hidden; background: #fff; border: 1px solid var(--border-s); }
.cvb-tmpl__name { font-size: var(--step--2); font-weight: 600; color: var(--text2); text-align: center; }

.cvb-swatches { display: flex; flex-wrap: wrap; gap: 0.45rem; align-items: center; }
.cvb-swatch {
  inline-size: 1.7rem; block-size: 1.7rem; border-radius: 50%;
  border: 2px solid transparent; cursor: pointer; padding: 0;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.12);
}
.cvb-swatch.is-active { border-color: var(--text); }
.cvb-swatch--custom { display: inline-grid; place-items: center; background: conic-gradient(red, yellow, lime, aqua, blue, magenta, red); }
.cvb-swatch--custom input { opacity: 0; position: absolute; inline-size: 1.7rem; block-size: 1.7rem; cursor: pointer; }

.cvb-toggle { display: flex; align-items: center; gap: 0.55rem; font-size: var(--step--1); color: var(--text2); cursor: pointer; }
.cvb-toggle input { inline-size: 1.05rem; block-size: 1.05rem; accent-color: var(--accent-l); }

/* Section order + visibility list */
.cvb-sections { display: grid; gap: 0.4rem; }
.cvb-sec-row {
  display: flex; align-items: center; gap: 0.5rem;
  border: 1px solid var(--border); border-radius: var(--r-m);
  padding: 0.45rem 0.55rem; background: var(--card-bg);
}
.cvb-sec-row__name { flex: 1; font-size: var(--step--1); font-weight: 600; color: var(--text); }
.cvb-sec-row__name small { font-weight: 400; color: var(--muted); }
.cvb-sec-row.is-off .cvb-sec-row__name { color: var(--muted); text-decoration: line-through; }
.cvb-sec-row__btn {
  inline-size: 1.7rem; block-size: 1.7rem; display: grid; place-items: center;
  border-radius: var(--r-s); color: var(--text2); border: 1px solid var(--border-s);
}
.cvb-sec-row__btn:hover { color: var(--accent-l); border-color: var(--accent-l); }
.cvb-sec-row__btn:disabled { opacity: 0.3; pointer-events: none; }
.cvb-sec-row__btn svg { inline-size: 1rem; block-size: 1rem; }
.cvb-sec-row input[type=checkbox] { inline-size: 1.1rem; block-size: 1.1rem; accent-color: var(--accent-l); }

/* =============================================================================
   THE CV PAPER  ·  shared base (always light) + 7 template variants
   ============================================================================= */
.cv-doc {
  --cv-accent: #2d6a4f;
  --cv-font: "DM Sans", system-ui, sans-serif;
  --cv-gap: 1.15rem;
  --cv-pad: 2.6rem;
  --cv-name: 2rem;
  --cv-h2: 1rem;
  --cv-ink: #1a1a1a;
  --cv-ink2: #444;
  --cv-line: #e2e2e2;
  inline-size: 210mm;
  min-block-size: 297mm;
  background: #fff;
  color: var(--cv-ink);
  font-family: var(--cv-font);
  font-size: 10.5pt;
  line-height: 1.5;
  padding: var(--cv-pad);
  box-shadow: 0 10px 40px rgba(0,0,0,0.18);
  box-sizing: border-box;
}
@media (max-width: 60em) { .cv-doc { transform-origin: top center; } }
.cv-doc * { box-sizing: border-box; }
.cv-doc h1, .cv-doc h2, .cv-doc h3 { margin: 0; }
.cv-doc p { margin: 0; }
.cv-doc ul { margin: 0; padding: 0; list-style: none; }

/* density */
.cv-doc.cv--sik { --cv-gap: 0.78rem; --cv-pad: 2rem; line-height: 1.4; }
.cv-doc.cv--ferah { --cv-gap: 1.55rem; --cv-pad: 3rem; line-height: 1.6; }

/* header (single-column templates) */
.cv-head { display: flex; align-items: center; gap: 1.4rem; margin-block-end: var(--cv-gap); }
.cv-head__main { flex: 1; min-inline-size: 0; }
.cv-name { font-size: var(--cv-name); font-weight: 700; letter-spacing: -0.01em; line-height: 1.1; }
.cv-title { font-size: 1.05rem; color: var(--cv-accent); font-weight: 600; margin-block-start: 0.15rem; }
.cv-contact { display: flex; flex-wrap: wrap; gap: 0.35rem 0.9rem; margin-block-start: 0.55rem; font-size: 9pt; color: var(--cv-ink2); }
.cv-contact li { display: inline-flex; align-items: center; gap: 0.3rem; }
.cv-contact li::before { content: ""; inline-size: 4px; block-size: 4px; border-radius: 50%; background: var(--cv-accent); flex: none; }
.cv-photo { flex: none; inline-size: 92px; block-size: 92px; border-radius: 50%; overflow: hidden; background: #eee; }
.cv-photo img { inline-size: 100%; block-size: 100%; object-fit: cover; display: block; }

/* sections */
.cv-sec { margin-block-start: var(--cv-gap); break-inside: avoid; }
.cv-sec > h2 {
  font-size: var(--cv-h2); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--cv-accent); padding-block-end: 0.25rem; margin-block-end: 0.55rem;
  border-block-end: 1.5px solid var(--cv-accent);
}
.cv-summary { font-size: 10pt; color: var(--cv-ink2); }
.cv-item { margin-block-end: 0.7rem; break-inside: avoid; }
.cv-item:last-child { margin-block-end: 0; }
.cv-item__head { display: flex; justify-content: space-between; align-items: baseline; gap: 0.6rem; flex-wrap: wrap; }
.cv-item__role { font-weight: 700; font-size: 10.5pt; }
.cv-item__org { font-weight: 600; color: var(--cv-accent); font-size: 10pt; }
.cv-item__meta { font-size: 8.6pt; color: #777; white-space: nowrap; }
.cv-item__note { font-size: 9.4pt; color: var(--cv-ink2); margin-block-start: 0.15rem; }
.cv-bullets { margin-block-start: 0.3rem; display: grid; gap: 0.18rem; }
.cv-bullets li { position: relative; padding-inline-start: 0.95rem; font-size: 9.6pt; color: var(--cv-ink2); }
.cv-bullets li::before { content: ""; position: absolute; inset-inline-start: 0.15rem; inset-block-start: 0.5em; inline-size: 4px; block-size: 4px; border-radius: 50%; background: var(--cv-accent); }
.cv-chips { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.cv-chip { font-size: 8.8pt; padding: 0.2rem 0.6rem; border-radius: 999px; background: var(--cv-accent-soft, #eef4f0); color: var(--cv-accent-chip, #234a39); border: 1px solid var(--cv-accent-border, #cfe0d6); }
.cv-list { display: grid; gap: 0.2rem; font-size: 9.6pt; color: var(--cv-ink2); }
.cv-list li { display: flex; justify-content: space-between; gap: 0.6rem; }
.cv-list li b { font-weight: 600; color: var(--cv-ink); }

/* ---- TEMPLATE: Klasik (default · serif headings, simple rules) ---------- */
.cv--klasik { --cv-font: "PT Serif", Georgia, serif; }
.cv--klasik .cv-name { font-family: "PT Serif", Georgia, serif; }
.cv--klasik .cv-head { border-block-end: 2px solid var(--cv-accent); padding-block-end: 0.8rem; }

/* ---- TEMPLATE: Modern (clean sans, thin accent, airy) ------------------- */
.cv--modern { --cv-font: "DM Sans", system-ui, sans-serif; }
.cv--modern .cv-sec > h2 { border-block-end: none; border-inline-start: 3px solid var(--cv-accent); padding-inline-start: 0.5rem; padding-block-end: 0; }
.cv--modern .cv-name { font-weight: 600; }

/* ---- TEMPLATE: Minimal (no color blocks, ultra clean, grey rules) ------- */
.cv--minimal .cv-sec > h2 { color: var(--cv-ink); border-block-end-color: var(--cv-line); letter-spacing: 0.12em; font-size: 0.82rem; }
.cv--minimal .cv-title { color: var(--cv-ink2); }
.cv--minimal .cv-item__org { color: var(--cv-ink); }
.cv--minimal .cv-contact li::before, .cv--minimal .cv-bullets li::before { background: var(--cv-ink2); }
.cv--minimal .cv-chip { background: #f4f4f4; color: #333; border-color: #e2e2e2; }

/* ---- TEMPLATE: Zarif (elegant · serif name, letter-spaced, centered head) */
.cv--zarif { --cv-font: "DM Sans", system-ui, sans-serif; }
.cv--zarif .cv-head { flex-direction: column; text-align: center; gap: 0.5rem; border-block-end: 1px solid var(--cv-line); padding-block-end: 1rem; }
.cv--zarif .cv-name { font-family: "PT Serif", Georgia, serif; letter-spacing: 0.08em; }
.cv--zarif .cv-contact { justify-content: center; }
.cv--zarif .cv-sec > h2 { text-align: center; border-block-end: none; position: relative; }
.cv--zarif .cv-sec > h2::after { content: ""; display: block; inline-size: 2.2rem; block-size: 2px; background: var(--cv-accent); margin: 0.3rem auto 0; }

/* ---- TEMPLATE: Vurgulu (bold colored header band) ----------------------- */
.cv--vurgulu { padding: 0; }
.cv--vurgulu .cv-head {
  background: var(--cv-accent); color: #fff; padding: var(--cv-pad) var(--cv-pad) 1.4rem;
  margin-block-end: 0; border: 0;
}
.cv--vurgulu .cv-title { color: rgba(255,255,255,0.92); }
.cv--vurgulu .cv-contact { color: rgba(255,255,255,0.9); }
.cv--vurgulu .cv-contact li::before { background: rgba(255,255,255,0.85); }
.cv--vurgulu .cv-photo { border: 3px solid rgba(255,255,255,0.5); }
.cv--vurgulu .cv-body { padding: 1.2rem var(--cv-pad) var(--cv-pad); }
.cv--vurgulu .cv-sec:first-child { margin-block-start: 0.4rem; }

/* =============================================================================
   SIDEBAR (two-column) templates · Yan Panel (light) + Koyu Panel (dark)
   ============================================================================= */
.cv--sidebar { padding: 0; display: grid; grid-template-columns: 34% 1fr; }
.cv--sidebar .cv-aside { padding: var(--cv-pad) 1.5rem; }
.cv--sidebar .cv-main { padding: var(--cv-pad) 1.7rem var(--cv-pad) 1.6rem; min-inline-size: 0; }
.cv--sidebar .cv-aside__name { margin-block-end: var(--cv-gap); }
.cv--sidebar .cv-aside .cv-name { font-size: 1.6rem; line-height: 1.15; }
.cv--sidebar .cv-aside .cv-title { font-size: 0.95rem; }
.cv--sidebar .cv-aside .cv-photo { inline-size: 110px; block-size: 110px; margin-block-end: 0.9rem; }
.cv--sidebar .cv-aside .cv-contact { flex-direction: column; gap: 0.3rem; font-size: 8.6pt; }
.cv--sidebar .cv-aside .cv-sec > h2 { font-size: 0.82rem; }
.cv--sidebar .cv-aside .cv-chips { flex-direction: column; align-items: flex-start; }
.cv--sidebar .cv-aside .cv-chip { background: transparent; border: none; padding: 0.05rem 0; }

/* Yan Panel · light grey sidebar, accent headings */
.cv--yanpanel .cv-aside { background: #f3f1ec; }
.cv--yanpanel .cv-aside .cv-sec > h2 { color: var(--cv-accent); border-block-end-color: var(--cv-accent-line, #b9d2c4); }

/* Koyu Panel · dark sidebar with light text */
.cv--koyupanel .cv-aside {
  background: #1f2a24;
  color: #e8efe9;
  --cv-ink: #f1f5f1; --cv-ink2: #c4d0c8;
}
.cv--koyupanel .cv-aside .cv-name { color: #fff; }
.cv--koyupanel .cv-aside .cv-title { color: var(--cv-accent-light, #8fbfa6); }
.cv--koyupanel .cv-aside .cv-sec > h2 { color: var(--cv-accent-light, #8fbfa6); border-block-end-color: rgba(255,255,255,0.18); }
.cv--koyupanel .cv-aside .cv-contact li::before, .cv--koyupanel .cv-aside .cv-bullets li::before { background: var(--cv-accent-light, #8fbfa6); }
.cv--koyupanel .cv-aside .cv-photo { border: 3px solid rgba(255,255,255,0.18); }

/* empty-state hint inside an empty section while editing */
.cv-empty { color: #bbb; font-style: italic; font-size: 9.5pt; }

/* When exporting we add this to neutralise the screen shadow. */
.cv-doc.is-exporting { box-shadow: none; }

/* small button + toast (builder-local) */
.btn--sm { padding: 0.4rem 0.7rem; font-size: var(--step--1); }
.cv-toast {
  position: fixed; inset-block-end: 1.2rem; inset-inline: 0; margin-inline: auto;
  inline-size: fit-content; max-inline-size: 90vw;
  background: #14110d; color: #f7f3ec; font-size: var(--step--1); font-weight: 600;
  padding: 0.65rem 1.1rem; border-radius: var(--r-pill);
  box-shadow: 0 12px 30px rgba(0,0,0,0.3); z-index: 60;
  opacity: 0; transform: translateY(10px); pointer-events: none;
  transition: opacity .25s var(--ease-out), transform .25s var(--ease-out);
}
.cv-toast.is-on { opacity: 1; transform: none; }
