@import url('https://fonts.googleapis.com/css2?family=Anton&family=DM+Mono:wght@500&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,700;1,9..40,400;1,9..40,500;1,9..40,700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

/* ── Full-page cream — no gray anywhere ── */
html,body{
  background:#FBF5EE;
  min-height:100%;
}
body{
  font-family:'DM Sans',sans-serif;
  color:#1a1a1a;
}

.page{
  max-width:720px;
  margin:0 auto;
  padding:1.5rem 2rem 3rem;
  min-height:100vh;
  background:#FBF5EE;
}

/* ── Admin bar ── */
.admin-bar{
  background:#AB5050;color:#fff;
  text-align:center;padding:4px 0;
  font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.05em;
  margin:-1.5rem -2rem 1.25rem;
}
.admin-bar a{color:#ffd5d5;text-decoration:underline;}

/* ── Header ── */
.site-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:1rem;
}

.logo{
  font-family:'Anton',sans-serif;color:#AB5050;
  font-size:1.1rem;text-decoration:none;
}

.admin-link{
  font-family:'DM Mono',monospace;font-size:.72rem;
  color:#777;text-decoration:none;
}
.admin-link:hover{color:#AB5050;}

/* ── Language switcher ── */
.lang-switcher{
  display:flex;align-items:center;gap:2px;
  font-family:'DM Mono',monospace;font-size:.72rem;
}
.lang-switcher a{
  text-decoration:none;color:#555;padding:2px 7px;border-radius:20px;
}
.lang-switcher a.active{background:#FAE9DB;color:#1a1a1a;}
.lang-switcher .sep{color:#bbb;}

/* ── Homepage hero ── */
.hero{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:3rem 1rem 2rem;
}
.hero h1{
  font-family:'Anton',sans-serif;color:#AB5050;
  font-size:2.75rem;line-height:1.1;margin-bottom:.6rem;
}
.hero .subtitle{font-style:italic;color:#777;font-size:.95rem;margin-bottom:2.5rem;}
.hero-spacer{flex:1;min-height:4rem;}
.hero .cta{font-style:italic;color:#555;font-size:.9rem;}
.hero .cta a{color:#555;}

/* ── Resource listing ── */
.section-heading{
  font-weight:700;font-size:1rem;
  text-align:center;margin:1.5rem 0 1.25rem;
}

.resource-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.25rem;justify-items:center;
}

.resource-card-wrap{width:100%;max-width:310px;}

.resource-card{
  background:#fff;border:2px solid #1a1a1a;
  border-radius:14px;overflow:hidden;
  width:100%;display:block;text-decoration:none;color:inherit;
  transition:transform .15s,box-shadow .15s;
}
.resource-card:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.1);}
.resource-card-img{
  width:100%;aspect-ratio:5/7;object-fit:cover;
  display:block;background:#d5d5d5;
}

.resource-card-img.placeholder{background:#d5d5d5;}

.resource-card-label{padding:.6rem .85rem .7rem;font-weight:700;font-size:.95rem;}
.resource-card-actions{padding:.4rem .85rem .75rem;display:flex;gap:.5rem;}

/* ── Individual resource ── */
.resource-nav{
  display:flex;justify-content:space-between;
  align-items:center;margin-bottom:1.25rem;
}
.back-link{
  font-family:'DM Mono',monospace;font-size:.75rem;
  color:#555;text-decoration:none;
}
.back-link:hover{color:#AB5050;}
.resource-page-title{font-weight:700;font-size:1.4rem;}

.resource-content-box{
  background:#fff;border:1.5px solid #d5d5d5;
  border-radius:14px;overflow:hidden;
}
.resource-layout{display:flex;}

/* Desktop sidebar */
.tab-sidebar{
  min-width:190px;max-width:190px;
  border-right:1px solid #ebebeb;
  padding:1.25rem 0;flex-shrink:0;
}
.tab-btn{
  display:block;width:100%;text-align:left;
  padding:.65rem 1.1rem;
  font-family:'DM Mono',monospace;font-size:.78rem;
  background:none;border:none;border-bottom:1px solid #ebebeb;
  cursor:pointer;color:#444;text-decoration:none;
  transition:background .1s;
}
.tab-btn:last-child{border-bottom:none;}
.tab-btn.active{font-weight:600;color:#1a1a1a;}
.tab-btn:hover:not(.active){background:#f9f9f9;}

/* Mobile tabs */
.tab-buttons-mobile{
  display:none;flex-wrap:wrap;gap:.4rem;
  padding:.85rem;border-bottom:1px solid #ebebeb;
}
.tab-buttons-mobile .tab-btn{
  display:inline-block;width:auto;
  border:1.5px solid #d5d5d5;border-radius:8px;
  padding:.35rem .65rem;font-size:.72rem;
}

.tab-content{flex:1;padding:1.5rem;min-width:0;}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

.section-img{
  width:100%;max-width:300px;
  margin:0 auto 1.25rem;display:block;border-radius:8px;
}
.section-img-placeholder{
  width:100%;max-width:300px;height:200px;
  background:#ebebeb;border-radius:8px;
  margin:0 auto 1.25rem;
  display:flex;align-items:center;justify-content:center;
  color:#aaa;font-family:'DM Mono',monospace;font-size:.75rem;
}

.tab-text p{font-size:.875rem;line-height:1.65;margin-bottom:.9rem;color:#333;}
.tab-text p:last-child{margin-bottom:0;}
.tab-text strong{font-weight:700;}
.tab-text em{font-style:italic;}

.section-images{display:flex;flex-wrap:wrap;gap:.75rem;margin:1rem 0;}
.section-images img{border-radius:6px;max-height:180px;width:auto;}

.admin-controls{margin-top:1rem;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;}

/* ── Buttons ── */
.btn{
  font-family:'DM Mono',monospace;font-size:.8rem;
  padding:.55rem 1.25rem;border:1.5px solid #1a1a1a;
  border-radius:8px;background:#fff;color:#1a1a1a;
  cursor:pointer;text-decoration:none;display:inline-block;text-align:center;
  transition:background .15s;
}
.btn:hover{background:#f0f0f0;}

.btn-save{
  background:#C9E55A;border-color:#A8C43A;
  color:#1a1a1a;font-weight:600;
}
.btn-save:hover{background:#BAD84E;}

.btn-edit{
  font-family:'DM Mono',monospace;font-size:.72rem;
  background:#fff;border:1.5px solid #AB5050;color:#AB5050;
  padding:3px 12px;border-radius:20px;cursor:pointer;
  text-decoration:none;display:inline-block;
  transition:background .15s,color .15s;
}
.btn-edit:hover{background:#AB5050;color:#fff;}

.btn-add-section{
  font-family:'DM Mono',monospace;font-size:.72rem;
  background:none;border:1.5px dashed #AB5050;color:#AB5050;
  padding:3px 12px;border-radius:20px;cursor:pointer;
}
.btn-add-section:hover{background:#fff0f0;}

/* ── Inline editor ── */
.section-edit-form{
  display:none;margin-top:1rem;
  border:1.5px dashed #d5d5d5;border-radius:10px;
  padding:1rem;background:#fafafa;
}
.section-edit-form.open{display:block;}

.editor-wrap{border:1.5px solid #d5d5d5;border-radius:8px;overflow:hidden;margin-bottom:.65rem;}
.editor-toolbar{
  display:flex;align-items:center;gap:.35rem;
  padding:.35rem .65rem;background:#fafafa;border-bottom:1px solid #ebebeb;
}
.toolbar-btn{
  font-family:'DM Sans',sans-serif;font-weight:700;font-size:.85rem;
  padding:2px 7px;border:none;background:none;cursor:pointer;border-radius:4px;color:#333;
}
.toolbar-btn:hover{background:#e5e5e5;}
.t-italic{font-style:italic;font-weight:400;}
.t-underline{text-decoration:underline;}
.upload-pill{
  font-family:'DM Mono',monospace;font-size:.7rem;
  padding:3px 10px;border:1.5px solid #d5d5d5;border-radius:20px;
  background:#fff;cursor:pointer;color:#555;margin-left:auto;
}
.upload-pill:hover{background:#f0f0f0;}
.editor-area{
  min-height:180px;padding:.75rem;
  font-family:'DM Sans',sans-serif;font-size:.875rem;line-height:1.6;
  outline:none;color:#333;
}
.form-actions{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;margin-top:.5rem;}

/* ── Modal ── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.45);z-index:200;
  align-items:center;justify-content:center;padding:1rem;
}
.modal-overlay.open{display:flex;}

/* ── Admin pages ── */
.admin-page-title{
  font-family:'Anton',sans-serif;color:#AB5050;
  font-size:2rem;text-transform:uppercase;
  text-align:center;margin:2rem 0 1.75rem;
}
.admin-login-form{
  display:flex;flex-direction:column;gap:.65rem;
  max-width:380px;margin:0 auto;
}
.admin-login-form input{
  font-family:'DM Mono',monospace;font-size:.8rem;
  padding:.6rem 1rem;border:1.5px solid #d5d5d5;
  border-radius:8px;background:#fff;color:#333;width:100%;
}
.admin-login-form input::placeholder{color:#bbb;text-transform:uppercase;letter-spacing:.05em;}
.admin-login-form input:focus{outline:none;border-color:#AB5050;}

.admin-dashboard-btns{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 0;}
.admin-dashboard-btns .btn{width:220px;}

/* ── Add resource ── */
.add-resource-wrap h2{font-weight:700;font-size:1.15rem;margin-bottom:1rem;}
.form-card{
  background:#fff;border:1.5px solid #d5d5d5;
  border-radius:12px;padding:1.25rem;
  position:relative;max-width:480px;margin:0 auto;
}
.form-field{margin-bottom:.65rem;}
.form-input{
  width:100%;font-family:'DM Mono',monospace;font-size:.8rem;
  padding:.55rem .85rem;border:1.5px solid #d5d5d5;
  border-radius:8px;background:#fff;color:#333;
}
.form-input:focus{outline:none;border-color:#AB5050;}
.close-btn{
  position:absolute;top:.75rem;right:.75rem;
  background:none;border:none;font-size:1.1rem;cursor:pointer;color:#888;
  width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;
}
.close-btn:hover{background:#f0f0f0;color:#333;}

/* ── Alerts ── */
.alert{padding:.65rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.83rem;}
.alert-error{background:#fee2e2;color:#991b1b;}
.alert-success{background:#d1fae5;color:#065f46;}

/* ── Responsive ── */
@media(max-width:620px){
  .page{padding:1rem .85rem 2rem;}
  .admin-bar{margin:-1rem -.85rem 1rem;}
  .hero h1{font-size:2rem;}
  .hero{padding:2rem .5rem 1rem;}
  .resource-grid{grid-template-columns:1fr;justify-items:center;}
.resource-card{max-width:260px;}
  .resource-card-wrap{max-width:280px;margin:0 auto;}
  .resource-nav{flex-direction:column;gap:.35rem;align-items:flex-start;}
  .tab-sidebar{display:none;}
  .tab-buttons-mobile{display:flex;}
  .resource-layout{flex-direction:column;}
  .tab-content{padding:1rem;}
  .admin-page-title{font-size:1.6rem;}
  .site-header{flex-direction:column;gap:.4rem;align-items:flex-start;}
}

/* ── Section header image with delete button ── */
.section-img-wrap {
  position: relative;
  width: 100%;
  max-width: 300px;
  margin: 0 auto 1.25rem;
}
.section-img-wrap .section-img {
  max-width: 100%;
  margin: 0;
  display: block;
}
.img-delete-btn {
  position: absolute;
  top: .4rem; right: .4rem;
  background: rgba(0,0,0,.55);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 24px; height: 24px;
  font-size: .75rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.img-delete-btn:hover { background: #AB5050; }