:root{
  --paper:#F5F3EC; --card:#FFFFFF; --ink:#2E2B24; --ink-soft:#6B6558; --ink-faint:#9B9587;
  --line:#E4E0D3; --line-strong:#D2CCBB; --teal:#0B5D4A; --teal-light:#E3F0EB; --teal-mid:#3D8A73;
  --gold:#B4842A; --gold-light:#F7ECD8; --stone:#3A362E; --danger:#B8452F; --danger-light:#F7E4DE;
  --success:#2F7D4F; --success-light:#E1F1E5; --radius:12px; --radius-sm:7px;
}
*{box-sizing:border-box; margin:0; padding:0;}
body{font-family:'Plus Jakarta Sans', -apple-system, 'Segoe UI', Roboto, sans-serif; background:var(--paper); color:var(--ink); line-height:1.55; padding-bottom:40px;}
h1,h2,h3{font-family:'Fraunces', Georgia, serif; font-weight:600; color:var(--stone);}
a{color:var(--teal); text-decoration:none;}
.wrap{max-width:720px; margin:0 auto; padding:0 16px;}
.wrap-wide{max-width:1100px; margin:0 auto; padding:0 16px;}

/* ===== Buttons / forms ===== */
.btn{display:inline-block; padding:11px 18px; border-radius:var(--radius-sm); border:1px solid var(--line-strong); background:var(--card); font-family:inherit; font-weight:600; font-size:13.5px; cursor:pointer; color:var(--ink); text-align:center;}
.btn.primary{background:var(--teal); color:#fff; border-color:var(--teal);}
.btn.danger{background:var(--danger-light); color:var(--danger); border-color:var(--danger-light);}
.btn.block{display:block; width:100%;}
.form-card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:20px;}
.form-row{margin-bottom:14px;}
.form-row label{font-size:11.5px; font-weight:700; color:var(--ink-soft); display:block; margin-bottom:5px; text-transform:uppercase; letter-spacing:.03em;}
.form-row input[type=text], .form-row input[type=password], .form-row input[type=email],
.form-row input[type=date], .form-row input[type=number], .form-row select, .form-row textarea{
  width:100%; padding:10px 12px; border:1px solid var(--line-strong); border-radius:var(--radius-sm);
  font-family:inherit; font-size:14px; background:#fff; color:var(--ink);
}
.form-row textarea{min-height:90px; resize:vertical;}
.form-row input[type=file]{width:100%; font-size:13px; padding:8px 0;}
.two-col{display:grid; grid-template-columns:1fr; gap:12px;}
@media(min-width:560px){ .two-col{grid-template-columns:1fr 1fr;} }
.alert{padding:11px 14px; border-radius:var(--radius-sm); font-size:13px; margin-bottom:14px;}
.alert.error{background:var(--danger-light); color:var(--danger);}
.alert.success{background:var(--success-light); color:var(--success);}

/* ===== Auth pages ===== */
.auth-page{min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--stone);}
.auth-box{background:var(--card); border-radius:var(--radius); padding:32px 28px; max-width:380px; width:100%; margin:20px;}
.auth-box h1{font-size:22px; text-align:center; margin-bottom:6px;}
.auth-box p.sub{text-align:center; color:var(--ink-soft); font-size:13px; margin-bottom:22px;}

/* ===== Public profile page ===== */
.profile-banner{width:100%; height:200px; background:linear-gradient(135deg, var(--teal), var(--stone)); background-size:cover; background-position:center; position:relative;}
.profile-header{position:relative; text-align:center; margin-top:-56px; padding:0 16px;}
.profile-avatar{width:112px; height:112px; border-radius:50%; border:4px solid var(--paper); background:var(--gold); object-fit:cover; margin:0 auto; display:block; box-shadow:0 2px 8px rgba(0,0,0,.15);}
.profile-avatar-fallback{width:112px; height:112px; border-radius:50%; border:4px solid var(--paper); background:var(--gold); margin:0 auto; display:flex; align-items:center; justify-content:center; font-size:40px; color:#fff; font-family:'Fraunces',serif; box-shadow:0 2px 8px rgba(0,0,0,.15);}
.profile-name{font-size:22px; margin-top:12px;}
.profile-city{color:var(--ink-soft); font-size:13px; margin-top:2px;}
.profile-bio{max-width:480px; margin:14px auto 0; text-align:center; color:var(--ink-soft); font-size:13.5px; line-height:1.7;}
.profile-socials{display:flex; justify-content:center; gap:10px; margin-top:16px; flex-wrap:wrap;}
.social-chip{display:inline-flex; align-items:center; gap:6px; padding:8px 14px; border-radius:20px; background:var(--card); border:1px solid var(--line-strong); font-size:12.5px; font-weight:600; color:var(--ink);}
.social-chip:hover{border-color:var(--teal-mid);}

.slideshow{max-width:640px; margin:26px auto 0; position:relative; border-radius:var(--radius); overflow:hidden; background:var(--card); border:1px solid var(--line);}
.slideshow-track{display:flex; transition:transform .4s ease;}
.slideshow-slide{min-width:100%; position:relative;}
.slideshow-slide img{width:100%; height:340px; object-fit:cover; display:block;}
.slideshow-caption{position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent, rgba(0,0,0,.65)); color:#fff; padding:26px 16px 12px; font-size:13px;}
.slideshow-arrows{position:absolute; top:50%; transform:translateY(-50%); width:100%; display:flex; justify-content:space-between; padding:0 10px; pointer-events:none;}
.slideshow-arrows button{pointer-events:all; background:rgba(0,0,0,.4); color:#fff; border:none; width:32px; height:32px; border-radius:50%; cursor:pointer; font-size:15px;}
.slideshow-dots{display:flex; justify-content:center; gap:6px; padding:10px 0;}
.slideshow-dots span{width:6px; height:6px; border-radius:50%; background:var(--line-strong); cursor:pointer;}
.slideshow-dots span.active{background:var(--teal);}

.cta-dashboard{text-align:center; margin:28px auto 0;}

/* ===== Hamburger nav (private dashboard) ===== */
.topbar{background:var(--stone); color:#F5F3EC; padding:14px 0; position:sticky; top:0; z-index:50;}
.topbar .wrap-wide{display:flex; align-items:center; justify-content:space-between;}
.topbar-brand{display:flex; align-items:center; gap:10px; font-family:'Fraunces',serif; font-size:16px;}
.topbar-brand img{width:30px; height:30px; border-radius:50%; object-fit:cover;}
.burger-btn{background:none; border:none; color:#F5F3EC; font-size:22px; cursor:pointer; padding:4px 8px;}

.nav-drawer{display:none; position:fixed; inset:0; z-index:100; background:rgba(46,43,36,.55);}
.nav-drawer.open{display:block;}
.nav-panel{background:var(--card); width:280px; max-width:82vw; height:100%; overflow-y:auto; padding:18px 0;}
.nav-panel-head{display:flex; align-items:center; justify-content:space-between; padding:0 18px 14px; border-bottom:1px solid var(--line); margin-bottom:8px;}
.nav-panel-head b{font-family:'Fraunces',serif; font-size:16px;}
.nav-panel-close{background:none; border:none; font-size:18px; cursor:pointer; color:var(--ink-soft);}
.nav-item{display:flex; align-items:center; gap:12px; padding:12px 18px; font-size:14px; font-weight:600; color:var(--ink); cursor:pointer;}
.nav-item:hover{background:var(--paper);}
.nav-item.active{background:var(--teal-light); color:var(--teal); border-right:3px solid var(--teal);}
.nav-item .ic{width:20px; text-align:center; font-size:16px;}
.nav-item .soon{margin-left:auto; font-size:10px; background:var(--gold-light); color:var(--gold); padding:2px 7px; border-radius:10px; font-weight:700;}
.nav-divider{padding:12px 18px 6px; font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-faint); font-weight:700;}

main.dash-main{padding-top:22px;}
.section-head{margin-bottom:16px;}
.section-head h2{font-size:21px; margin-bottom:3px;}
.section-head p{color:var(--ink-soft); font-size:13px;}

.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:10px; margin-bottom:20px;}
.stat{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:14px 12px; text-align:center;}
.stat b{display:block; font-size:22px; font-family:'Fraunces',serif; color:var(--teal);}
.stat span{font-size:10.5px; color:var(--ink-soft);}

.menu-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px;}
.menu-card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:16px; text-align:center; cursor:pointer;}
.menu-card:hover{border-color:var(--teal-mid);}
.menu-card .ic{font-size:26px; margin-bottom:8px;}
.menu-card b{font-size:12.5px; display:block;}
.menu-card .soon{display:inline-block; margin-top:6px; font-size:9.5px; background:var(--gold-light); color:var(--gold); padding:2px 8px; border-radius:10px; font-weight:700;}

/* ===== Blog/diary list cards ===== */
.diary-card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-bottom:14px; display:flex; gap:0; cursor:pointer;}
.diary-card:hover{border-color:var(--teal-mid);}
.diary-thumb{width:160px; flex-shrink:0; background:var(--paper);}
.diary-thumb img{width:100%; height:100%; object-fit:cover; display:block; min-height:100px;}
.diary-body{padding:14px 16px; flex:1; min-width:0;}
.diary-date{font-size:11px; color:var(--ink-faint); font-weight:600;}
.diary-title{font-size:15.5px; margin:4px 0 6px; font-family:'Fraunces',serif;}
.diary-preview{font-size:12.5px; color:var(--ink-soft); line-height:1.6; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
.diary-meta{display:flex; gap:6px; margin-top:8px; flex-wrap:wrap;}
.chip{display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:20px; font-size:10.5px; font-weight:600; white-space:nowrap; background:var(--teal-light); color:var(--teal);}
.chip.gold{background:var(--gold-light); color:var(--gold);}
@media(max-width:520px){ .diary-card{flex-direction:column;} .diary-thumb{width:100%; height:160px;} }

.diary-detail-thumb{width:100%; max-height:360px; object-fit:cover; border-radius:var(--radius); margin-bottom:16px;}
.diary-detail-body{font-size:14.5px; line-height:1.85; white-space:pre-wrap;}

.add-box{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:18px; margin-bottom:20px;}
.add-box h3{font-size:15px; margin-bottom:12px;}

.type-add-row{display:flex; gap:6px; margin-top:6px;}
.type-add-row input{flex:1; font-size:12.5px; padding:7px 9px; border:1px solid var(--line-strong); border-radius:var(--radius-sm); font-family:inherit;}

table.admin-table{width:100%; border-collapse:collapse; background:var(--card); border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); font-size:13px;}
table.admin-table th{background:var(--teal-light); color:var(--teal); text-align:left; padding:10px 12px; font-size:11px; text-transform:uppercase; letter-spacing:.03em; font-weight:700;}
table.admin-table td{padding:10px 12px; border-top:1px solid var(--line); vertical-align:middle;}
.badge-active{background:var(--success-light); color:var(--success); padding:3px 9px; border-radius:20px; font-size:11px; font-weight:700;}
.badge-inactive{background:var(--danger-light); color:var(--danger); padding:3px 9px; border-radius:20px; font-size:11px; font-weight:700;}
.icon-link{background:none; border:none; cursor:pointer; color:var(--ink-faint); font-size:14px; padding:4px 6px;}
.icon-link:hover{color:var(--teal);}
.icon-link.del:hover{color:var(--danger);}

.empty-note{text-align:center; color:var(--ink-faint); font-size:13px; padding:30px 10px; line-height:1.7;}

.soon-box{background:var(--card); border:1.5px dashed var(--line-strong); border-radius:var(--radius); padding:40px 20px; text-align:center; color:var(--ink-soft);}
.soon-box .ic{font-size:36px; margin-bottom:12px;}

.footer-note{text-align:center; color:var(--ink-faint); font-size:11px; padding:30px 20px 10px;}
