/* Public Website */
:root{
  --bg:#f4f7fb;
  --surface:#fff;
  --surface-2:#f8fbff;
  --ink:#122033;
  --muted:#66758a;
  --line:#d8e2ef;
  --line-2:#e9eef5;
  --brand:#214e86;
  --brand-2:#16355a;
  --accent:#d1a14a;
  --accent-soft:#f6ead2;
  --success:#1f7a5b;
  --danger:#b0413e;
  --shadow:0 20px 60px rgba(18,32,51,.10);
  --shadow-soft:0 10px 35px rgba(18,32,51,.07);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(33,78,134,.10), transparent 24%),
    radial-gradient(circle at bottom right, rgba(209,161,74,.12), transparent 24%),
    linear-gradient(180deg,#f4f7fb,#eef3f8);
}
a{color:inherit}
button,input,select,textarea{font:inherit}
.public-page{padding:20px}
.wrap{max-width:1360px;margin:0 auto}
.hero{
  position:relative;overflow:hidden;border-radius:38px;
  background:linear-gradient(135deg,rgba(19,40,67,.97),rgba(33,78,134,.94));
  color:#fff;box-shadow:var(--shadow);padding:34px;
}
.hero:before{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:end}
.eyebrow{display:inline-flex;gap:10px;align-items:center;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.15);color:#d7e3f3;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.eyebrow i{width:9px;height:9px;border-radius:50%;display:block;background:var(--accent);box-shadow:0 0 16px rgba(209,161,74,.9)}
.hero h1{margin:18px 0 10px;font-size:clamp(40px,5vw,72px);line-height:.94;letter-spacing:-.05em;font-family:Georgia,"Times New Roman",serif}
.hero p{margin:0;max-width:760px;font-size:17px;line-height:1.75;color:rgba(255,255,255,.78)}
.hero-card{padding:20px;border-radius:24px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(16px)}
.hero-card h3{margin:0 0 12px;color:#fff}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.stat{padding:14px;border-radius:18px;background:rgba(255,255,255,.08)}
.stat b{display:block;font-size:26px;color:#fff;line-height:1}
.stat span{display:block;margin-top:6px;color:rgba(255,255,255,.68);font-size:12px}
.toolbar{
  position:sticky;top:12px;z-index:8;margin:20px 0;padding:14px;border-radius:26px;
  background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.75);
  box-shadow:var(--shadow-soft);backdrop-filter:blur(20px);display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;
}
.breadcrumb{display:flex;gap:8px;align-items:center;flex-wrap:wrap;min-height:40px}
.crumb-link,.crumb-active{font-size:14px;padding:10px 14px;border-radius:999px;text-decoration:none;font-weight:800}
.crumb-link{background:#edf3fb;color:var(--brand)}
.crumb-active{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}
.crumb-sep{color:#95a2b3}
.search-box{position:relative;min-width:min(360px,100%)}
.search-box input{width:100%;padding:14px 16px 14px 44px;border:1px solid var(--line);border-radius:16px;background:#fff;outline:none;color:var(--ink)}
.search-box svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;opacity:.45}
.panel{background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.8);border-radius:30px;box-shadow:var(--shadow-soft);padding:28px;backdrop-filter:blur(14px)}
.section-head{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:18px}
.section-head h2{margin:0;font-size:clamp(30px,4vw,46px);letter-spacing:-.03em;line-height:1;font-family:Georgia,"Times New Roman",serif;color:var(--brand-2)}
.section-head p{margin:0;color:var(--muted);line-height:1.7;max-width:650px;text-align:right}
.root-wrap{display:flex;justify-content:center;margin:14px 0 22px}
.couple{position:relative;display:grid;grid-template-columns:repeat(2,minmax(250px,1fr));gap:14px;padding:14px;border-radius:28px;background:linear-gradient(180deg,#fff,#f9fbfe);border:1px solid var(--line-2);box-shadow:var(--shadow-soft)}
.couple:after{content:"♥";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:15px;box-shadow:0 12px 28px rgba(33,78,134,.28);z-index:3}
.connector{position:relative;height:48px;margin-bottom:8px}
.connector:before{content:"";position:absolute;left:50%;top:0;height:48px;border-left:2px solid var(--line)}
.connector:after{content:"";position:absolute;left:8%;right:8%;bottom:0;border-top:2px solid var(--line)}
.grid{display:grid;grid-template-columns:repeat(4,minmax(220px,1fr));gap:18px}
.single-row{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}
.card{
  position:relative;border:none;border-radius:24px;background:linear-gradient(180deg,#fff,#fbfdff);
  box-shadow:0 16px 35px rgba(18,32,51,.07);border:1px solid var(--line-2);text-align:center;
  min-height:238px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;gap:14px;
  cursor:pointer;transition:transform .24s ease,box-shadow .24s ease,opacity .2s ease;text-decoration:none;color:inherit;
}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(18,32,51,.11)}
.card.no-tree{cursor:default}
.card.no-tree:hover{transform:none}
.card.hidden{opacity:.18}
.avatar{width:84px;height:84px;margin:6px auto 0;border-radius:24px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(33,78,134,.14),rgba(209,161,74,.18)),#fff;border:1px solid #dde8f5;color:var(--brand-2);font-family:Georgia,"Times New Roman",serif;font-size:28px;font-weight:900;box-shadow:inset 0 0 0 6px rgba(255,255,255,.65);overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.card h3{margin:0;font-size:18px;line-height:1.28;color:var(--ink)}
.card p{margin:7px 0 0;font-size:13px;line-height:1.55;color:var(--muted)}
.meta{display:flex;justify-content:center;flex-wrap:wrap;gap:8px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:8px 11px;border-radius:999px;background:#eff5fb;color:var(--brand);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.pill.gold{background:var(--accent-soft);color:#946a1c}
.pill.green{background:#eaf6f1;color:var(--success)}
.card-top{position:relative;padding-top:8px}
.info-btn{position:absolute;top:0;right:0;width:38px;height:38px;border:none;border-radius:14px;background:#f4f8fc;color:var(--brand-2);display:grid;place-items:center;cursor:pointer;box-shadow:0 8px 16px rgba(18,32,51,.06);transition:.2s ease;z-index:2}
.info-btn:hover{transform:translateY(-1px);background:#eaf1f8}
.info-btn svg{width:16px;height:16px}
.subnote{margin-top:22px;padding:18px 20px;border-radius:20px;background:linear-gradient(180deg,#f8fbfe,#f3f8fd);border:1px solid var(--line-2);color:var(--muted);line-height:1.75;font-size:14px}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;z-index:30;background:rgba(9,17,29,.55);backdrop-filter:blur(12px)}
.modal.open{display:flex}
.profile{width:min(1020px,100%);max-height:min(860px,92vh);overflow:auto;background:#fff;border-radius:32px;box-shadow:0 30px 80px rgba(0,0,0,.20);animation:rise .22s ease}
@keyframes rise{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
.profile-head{position:relative;padding:28px;background:radial-gradient(circle at top right,rgba(209,161,74,.22),transparent 28%),linear-gradient(135deg,var(--brand-2),var(--brand));color:#fff;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center}
.profile-avatar{width:104px;height:104px;border-radius:28px;display:grid;place-items:center;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);color:#fff;font-family:Georgia,"Times New Roman",serif;font-size:36px;font-weight:900;overflow:hidden}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.profile-head h2{margin:0 0 8px;font-size:clamp(30px,4vw,44px);line-height:1;letter-spacing:-.03em;font-family:Georgia,"Times New Roman",serif}
.profile-head p{margin:0;line-height:1.7;color:rgba(255,255,255,.76)}
.close{border:none;width:44px;height:44px;border-radius:14px;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;font-size:24px}
.profile-body{padding:22px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.profile-section{padding:20px;border-radius:24px;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--line-2)}
.profile-section.full{grid-column:1 / -1}
.profile-section h4{margin:0 0 14px;color:var(--brand);font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.info{padding:13px;border-radius:16px;background:#f7fbff;border:1px solid #e8eff7}
.info small{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
.info strong{display:block;font-size:14px;line-height:1.45;color:var(--ink)}
.timeline{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.timeline li{position:relative;padding:0 0 0 20px;line-height:1.7;color:var(--muted)}
.timeline li:before{content:"";position:absolute;left:0;top:10px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(209,161,74,.12)}
.timeline strong{color:var(--ink)}
.footer{text-align:center;color:var(--muted);font-size:13px;padding:16px 0 6px}

/* Admin Panel */
.admin-body{display:grid;grid-template-columns:280px 1fr;min-height:100vh;background:#f4f7fb}
.admin-sidebar{position:sticky;top:0;height:100vh;background:#102033;color:#fff;padding:20px;box-shadow:var(--shadow)}
.brand{display:flex;align-items:center;gap:12px;padding:10px 6px 24px}
.brand span{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--accent));font-weight:900}
.brand strong{display:block}
.brand small{display:block;color:rgba(255,255,255,.6);margin-top:3px}
.admin-sidebar nav{display:grid;gap:8px}
.admin-sidebar a{display:block;text-decoration:none;color:rgba(255,255,255,.78);padding:13px 14px;border-radius:14px;font-weight:700}
.admin-sidebar a:hover,.admin-sidebar a.active{background:rgba(255,255,255,.10);color:#fff}
.admin-main{padding:28px}
.admin-card{background:#fff;border:1px solid var(--line-2);border-radius:24px;box-shadow:var(--shadow-soft);padding:22px;margin-bottom:18px}
.admin-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.admin-head h1{margin:0;font-size:32px;letter-spacing:-.03em;color:var(--brand-2)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:14px;background:var(--brand);color:#fff;padding:12px 16px;text-decoration:none;font-weight:800;cursor:pointer}
.btn.secondary{background:#edf3fb;color:var(--brand)}
.btn.danger{background:var(--danger)}
.btn.small{padding:8px 11px;font-size:13px;border-radius:10px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:12px;border-bottom:1px solid var(--line-2);text-align:left;vertical-align:middle}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.admin-form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:grid;gap:7px}
.field.full{grid-column:1/-1}
label{font-weight:800;color:var(--ink);font-size:14px}
input,select,textarea{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fff;outline:none}
textarea{min-height:120px;resize:vertical}
.alert{padding:14px 16px;border-radius:16px;margin-bottom:16px;background:#fff4df;color:#6f4a00;border:1px solid #f0d8a7}
.alert.success{background:#eaf6f1;color:var(--success);border-color:#c9eadc}
.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(135deg,var(--brand-2),var(--brand))}
.login-box{width:min(440px,100%);background:#fff;border-radius:28px;padding:28px;box-shadow:0 30px 80px rgba(0,0,0,.22)}
.login-box h1{margin:0 0 6px;color:var(--brand-2)}
.login-box p{margin:0 0 22px;color:var(--muted)}
.photo-thumb{width:48px;height:48px;border-radius:14px;background:#edf3fb;display:grid;place-items:center;overflow:hidden;font-weight:900;color:var(--brand)}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.muted{color:var(--muted)}
@media(max-width:1100px){.hero-grid,.profile-body{grid-template-columns:1fr}.section-head{display:block}.section-head p{margin-top:10px;text-align:left}.grid{grid-template-columns:repeat(2,minmax(220px,1fr))}.toolbar{grid-template-columns:1fr}.search-box{min-width:100%}.admin-body{grid-template-columns:1fr}.admin-sidebar{position:static;height:auto}.admin-main{padding:18px}.admin-form{grid-template-columns:1fr}}
@media(max-width:720px){.public-page{padding:14px}.hero{padding:24px;border-radius:28px}.panel{padding:20px}.stats{grid-template-columns:1fr}.grid,.couple,.info-grid{grid-template-columns:1fr}.profile-head{grid-template-columns:1fr;text-align:center}.profile-avatar{margin:auto}.close{position:absolute;right:16px;top:16px}.toolbar{position:static}}
