:root{
  --bg:#f5f0e7; --card:#fffaf2; --ink:#0f2742; --muted:#5a6a7a;
  --line:rgba(15,39,66,.12); --accent:#0f2742; --accent2:#1f4b7a;
  --shadow:0 12px 30px rgba(0,0,0,.10); --radius:18px;

  /* Brand colors για share */
  --wa:#25D366; --vb:#7360F2; --sm:#1f4b7a; --cp:#0f2742;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:ui-sans-serif,-apple-system,system-ui,"Segoe UI",Roboto,Arial,"Noto Sans";
  background:radial-gradient(1200px 700px at 20% 0%,#fff 0%,var(--bg) 55%,#efe7da 100%);
  color:var(--ink);
}
.topbar{
  position:sticky; top:0; z-index:30;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:14px 16px; background:rgba(245,240,231,.85); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand__title{font-weight:900;letter-spacing:.2px}
.brand__title span{color:var(--accent2)}
.brand__sub{font-size:12px;color:var(--muted);margin-top:2px}
.topbar__actions{display:flex;gap:10px;flex-wrap:wrap}

.wrap{max-width:1120px;margin:16px auto;padding:0 14px 40px}
.grid{display:grid;grid-template-columns:1.05fr 1fr;gap:14px}
@media (max-width:980px){.grid{grid-template-columns:1fr}.topbar{position:static}}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.card--preview{position:relative;overflow:hidden}
.h{margin:0 0 12px;font-size:15px;letter-spacing:.2px}

/* ============= SEGMENTED CONTROL ============= */
.seg{
  display:grid;grid-template-columns:repeat(3,1fr);gap:6px;
  padding:5px;background:rgba(15,39,66,.06);border:1px solid var(--line);
  border-radius:14px;margin-bottom:14px
}
.seg__btn{
  border:0;background:transparent;padding:10px 8px;border-radius:10px;
  font-weight:900;color:var(--muted);cursor:pointer;font-size:14px;
  letter-spacing:.2px;transition:.15s ease
}
.seg__btn:hover{color:var(--ink)}
.seg__btn.is-active{
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  color:#fff;box-shadow:0 6px 16px rgba(15,39,66,.25)
}

.sectionLabel{
  font-size:12px;font-weight:1000;letter-spacing:.8px;text-transform:uppercase;
  color:var(--accent2);margin:6px 0 8px
}
.divLine{height:1px;background:var(--line);margin:8px 0 4px}

.form{display:flex;flex-direction:column;gap:12px}
.field span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:800}
input,textarea,select{
  width:100%;border:1px solid var(--line);background:rgba(255,255,255,.75);
  border-radius:14px;padding:12px;color:var(--ink);outline:none;font-size:15px
}
input:focus,textarea:focus,select:focus{border-color:rgba(31,75,122,.45);box-shadow:0 0 0 4px rgba(31,75,122,.12)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:420px){.row2{grid-template-columns:1fr}}

.btn{
  border:1px solid var(--line);padding:10px 12px;border-radius:14px;cursor:pointer;
  font-weight:900;letter-spacing:.2px;background:rgba(255,255,255,.6);color:var(--ink)
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:linear-gradient(180deg,var(--accent2),var(--accent));color:#fff;border-color:rgba(0,0,0,.08)}
.btn--ghost{background:rgba(255,255,255,.55)}
.previewActions{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}

.previewLabel{
  font-size:11px;font-weight:1000;letter-spacing:1px;color:var(--muted);
  text-transform:uppercase;margin-bottom:8px
}

/* ============= SHARE BLOCK ============= */
.shareBlock{
  margin-top:16px;padding:14px;border-radius:14px;
  background:linear-gradient(180deg,rgba(31,75,122,.06),rgba(31,75,122,.02));
  border:1px dashed rgba(31,75,122,.25)
}
.shareBlock__title{
  font-size:12px;font-weight:1000;letter-spacing:.8px;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px
}
.shareGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media (max-width:540px){.shareGrid{grid-template-columns:repeat(2,1fr)}}

.shareBtn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  padding:14px 8px;border-radius:14px;border:0;cursor:pointer;
  background:#fff;color:#fff;font-weight:900;font-size:13px;letter-spacing:.2px;
  box-shadow:0 6px 14px rgba(0,0,0,.10);transition:.15s ease;
  min-height:78px
}
.shareBtn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.15)}
.shareBtn:active{transform:translateY(0)}
.shareBtn__icon{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:999px;background:rgba(255,255,255,.18)
}
.shareBtn--wa{background:linear-gradient(180deg,#2ed26f,var(--wa))}
.shareBtn--vb{background:linear-gradient(180deg,#8a78ff,var(--vb))}
.shareBtn--sm{background:linear-gradient(180deg,#2c6cb0,var(--sm))}
.shareBtn--cp{background:linear-gradient(180deg,#1f4b7a,var(--cp))}
.shareBtn.is-loading{opacity:.6;pointer-events:none}
.shareBtn.is-loading .shareBtn__icon{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.shareHint{margin-top:10px;font-size:12px;color:var(--muted);line-height:1.5}
.shareHint b{color:var(--ink)}

.toast{
  position:absolute;left:16px;bottom:16px;padding:10px 12px;border-radius:14px;
  background:rgba(15,39,66,.92);color:#fff;font-weight:900;opacity:0;transform:translateY(6px);
  transition:.18s ease;pointer-events:none;z-index:5
}
.toast.show{opacity:1;transform:translateY(0)}
.toast--viewer{position:fixed;left:16px;bottom:18px;z-index:50}

.history{display:flex;flex-direction:column;gap:10px}
.histItem{
  border:1px solid rgba(15,39,66,.12);border-radius:14px;padding:10px 12px;
  background:rgba(255,255,255,.55);display:flex;align-items:center;justify-content:space-between;gap:10px
}
.histMeta{display:flex;flex-direction:column;gap:3px}
.histTitle{font-weight:1000}
.histSub{font-size:12px;color:var(--muted)}
.histActions{display:flex;gap:8px;flex-wrap:wrap}

/* ============= VIEWER ============= */
.viewer{max-width:820px;margin:0 auto;padding:14px 14px 100px}
.viewer__card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.viewer__card--clean{padding:0;background:transparent;border:0;box-shadow:none}

.viewerActions{
  margin-top:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px
}
.vBtn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 12px;border-radius:14px;border:1px solid rgba(0,0,0,.10);
  background:#fff;color:var(--ink);font-weight:900;font-size:14px;
  text-decoration:none;cursor:pointer;
  box-shadow:0 6px 16px rgba(0,0,0,.08);transition:.15s ease
}
.vBtn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.12)}
.vBtn__ic{
  width:34px;height:34px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  background:rgba(15,39,66,.08);color:var(--accent)
}
.vBtn--primary{background:linear-gradient(180deg,var(--accent2),var(--accent));color:#fff;border-color:rgba(0,0,0,.06)}
.vBtn--primary .vBtn__ic{background:rgba(255,255,255,.18);color:#fff}

/* Classic look – δεν αλλάζει */
.classic{
  padding:18px 12px 10px;text-align:center;color:#000;background:rgba(255,255,255,.72);
  border-radius:16px;border:1px solid rgba(15,39,66,.10)
}
.cMain{font-family:Georgia,"Times New Roman",serif}
.cTitle{font-weight:900;font-size:38px;letter-spacing:.03em;margin-top:6px}
.cDed{font-weight:900;font-size:16px;letter-spacing:.02em;margin-top:10px}
.cRoles{font-weight:900;font-size:20px;margin-top:2px}
.cParish{font-weight:800;font-size:15px;margin-top:8px;color:#333;font-style:italic}
.cName{font-weight:1000;font-size:44px;margin-top:20px;letter-spacing:.02em}
.cProf{font-size:17px;margin-top:4px;font-weight:800}
.cWhen{margin-top:22px;font-size:22px;font-weight:900;line-height:1.55}
.cWhen b{font-weight:1000}
.cPlace{margin-top:14px;font-size:22px;font-weight:900;line-height:1.55}
.cPlace > div{margin-top:6px}
.cPlace > div:first-child{margin-top:0}
.cPlace a{color:#0b4bd6;text-decoration:underline;font-weight:1000}
.cNote{margin-top:14px;font-size:14px;font-weight:800;color:#222;line-height:1.5}

.cRelCenter{margin-top:22px;display:flex;flex-direction:column;gap:14px;align-items:center}
.cRelCenter .grp{text-align:center}
.cRelCenter .role{font-weight:1000;font-size:18px;letter-spacing:.02em}
.cRelCenter .names{margin-top:2px;font-weight:1000;font-size:18px;line-height:1.55}

.cOffice{
  margin-top:18px;padding-top:12px;border-top:1px solid rgba(0,0,0,.12);
  font-size:13px;color:rgba(0,0,0,.70);line-height:1.55;font-weight:900
}
.cOffice b{font-weight:1000;color:rgba(0,0,0,.82)}
.cOffice a{color:rgba(0,0,0,.72);text-decoration:underline;text-decoration-style:dotted;font-weight:900}

.relHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.relGroups{display:flex;flex-direction:column;gap:12px}
.relCard{border:1px solid rgba(15,39,66,.12);border-radius:14px;padding:12px;background:rgba(255,255,255,.55)}
.relRow{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.relRow .btn{padding:9px 10px}
.mutedSmall{margin-top:0;font-size:12px;color:var(--muted);line-height:1.5}
.muted{color:var(--muted)}

.fab{
  position:fixed;right:16px;bottom:16px;z-index:60;width:54px;height:54px;border-radius:999px;
  border:1px solid rgba(0,0,0,.10);background:rgba(255,255,255,.90);
  box-shadow:0 10px 25px rgba(0,0,0,.18);font-size:22px;font-weight:1000;cursor:pointer
}
.fab:active{transform:translateY(1px)}