*{box-sizing:border-box}
body{margin:0}
input,button,select,textarea{font-family:inherit}
::selection{background:#dcc28d;color:#2a2014}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes soft{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}

:root{
  --accent:#9c5b3b;
  --img-filter: sepia(0.45) contrast(1.05) brightness(1.03) saturate(0.92);
  --bg-paper-1:#f7efe0; --bg-paper-2:#efe3cd; --bg-paper-3:#e6d6ba;
  --surface:#fcf8ef;
  --border:#e3d5b8;
  --text-primary:#3a2c1d;
  --text-secondary:#5a4a35;
  --text-muted:#6a5840;
  --text-mono:#a3906a;
  --accent-dark:#2c2318;
  --overlay: rgba(20,14,7,.96);
}

html,body{min-height:100%}
body{
  background:radial-gradient(135% 120% at 50% -10%, var(--bg-paper-1) 0%, var(--bg-paper-2) 52%, var(--bg-paper-3) 100%);
  background-attachment:fixed;
  font-family:'EB Garamond',Georgia,serif;
  color:var(--text-primary);
  -webkit-font-smoothing:antialiased;
}

/* Header */
.site-header{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px 30px;
  background:rgba(245,237,223,0.84);
  backdrop-filter:blur(10px);
  border-bottom:1px solid #d9c8a6;
}
.brand{display:flex;flex-direction:column;line-height:1.05;text-decoration:none;color:inherit}
.brand-title{font-family:'Cormorant Garamond',serif;font-size:23px;font-weight:600;letter-spacing:0.01em;color:#2e2417}
.brand-sub{font-family:'Courier Prime',monospace;font-size:9.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--text-mono);margin-top:3px}
.site-nav{display:flex;align-items:center;gap:22px}
.nav-link{
  background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;
  font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  padding:9px 2px;color:#6e5d40;transition:color .15s;text-decoration:none;
}
.nav-link:hover{color:var(--accent)}
.nav-link.active{color:var(--accent);border-bottom-color:var(--accent)}
.nav-external{color:var(--text-mono)}

/* Hero */
.hero{
  max-width:1180px;margin:0 auto;padding:44px 30px 90px;
  display:grid;grid-template-columns:1.04fr 0.96fr;gap:54px;align-items:center;
  animation:fadeUp .45s ease;
}
.hero-eyebrow{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-mono);margin:0 0 18px}
.hero-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:74px;line-height:0.98;letter-spacing:-0.01em;margin:0;color:#2c2114}
.hero-body{font-size:20px;line-height:1.55;max-width:30em;margin:24px 0 0;color:var(--text-secondary)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Courier Prime',monospace;font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  padding:15px 28px;border-radius:3px;cursor:pointer;text-decoration:none;border:none;
}
.btn-primary{background:var(--accent);color:#fdf7ec;box-shadow:0 10px 22px -12px rgba(120,60,30,.8)}
.btn-primary:hover{filter:brightness(1.07)}
.btn-ghost{background:transparent;color:#5b4a31;border:1px solid #c9b794;padding:15px 26px}
.btn-ghost:hover{background:#ece0c6}
.hero-footnote{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.08em;color:var(--text-mono);margin:30px 0 0}

.hero-photos{position:relative;height:480px}
.polaroid{position:absolute;background:#fbf6ec;border:1px solid #e1d2b3}
.polaroid.back{top:40px;right:54px;width:230px;padding:12px 12px 16px;box-shadow:0 22px 38px -20px rgba(60,40,20,.6);transform:rotate(4.5deg)}
.polaroid.back .frame{aspect-ratio:3/4;overflow:hidden;background:repeating-linear-gradient(135deg,#e7dcc6 0 11px,#ddd0b3 11px 22px);filter:var(--img-filter)}
.polaroid.front{top:8px;left:6px;width:330px;padding:14px 14px 22px;box-shadow:0 30px 50px -22px rgba(60,40,20,.65);transform:rotate(-3deg)}
.polaroid.front .frame{aspect-ratio:3/2;overflow:hidden;background:#e6dac3}
.polaroid.front img{width:100%;height:100%;object-fit:cover;display:block;filter:var(--img-filter)}
.polaroid .caption{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.1em;color:var(--text-mono);margin:12px 4px 0;text-align:center}

/* Gallery */
.gallery-main{max-width:1220px;margin:0 auto;padding:36px 30px 130px;animation:soft .35s ease}
.gallery-header{
  display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:16px;
  border-bottom:1px solid #d9c8a6;padding-bottom:20px;margin-bottom:26px;
}
.gallery-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:42px;margin:0;color:#2c2114}
.gallery-subtitle{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.1em;color:var(--text-mono);margin:6px 0 0}
.gallery-actions{display:flex;gap:10px}

.masonry{columns:232px;column-gap:14px}
.photo-card{
  position:relative;width:100%;display:inline-block;break-inside:avoid;margin:0 0 14px;cursor:zoom-in;
  background:var(--surface);padding:8px 8px 4px;border:1px solid var(--border);border-radius:2px;
  box-shadow:0 1px 0 rgba(0,0,0,.03),0 10px 20px -14px rgba(60,40,20,.5);
  transition:transform .18s ease,box-shadow .18s ease;
}
.photo-card:hover{transform:translateY(-3px);box-shadow:0 16px 28px -16px rgba(60,40,20,.6)}
.photo-image{position:relative;width:100%;overflow:hidden;background:#e7dcc6}
.photo-image img{width:100%;height:100%;object-fit:cover;display:block;filter:var(--img-filter)}
.photo-select{
  position:absolute;top:9px;right:9px;width:28px;height:28px;border-radius:50%;border:2px solid #fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 2px 6px rgba(0,0,0,.3);
  background:rgba(40,30,18,0.34);color:#fff;font-size:15px;line-height:1;
}
.photo-select.selected{background:var(--accent)}
.photo-caption{padding:8px 4px 4px;font-family:'Courier Prime',monospace;font-size:10px;letter-spacing:0.1em;color:#a08c62}

/* Lightbox */
.lightbox-overlay{
  position:fixed;inset:0;z-index:60;background:var(--overlay);
  display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:auto;
  padding:48px 70px 32px;animation:soft .25s ease;backdrop-filter:blur(4px);
}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:fixed;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);border:none;
  color:#f4ead4;font-size:20px;cursor:pointer;z-index:1;
}
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,.22)}
.lightbox-close{top:18px;right:24px}
.lightbox-prev,.lightbox-next{width:52px;height:52px;top:50%;transform:translateY(-50%);font-size:26px}
.lightbox-prev{left:16px}
.lightbox-next{right:16px}
.lightbox-frame{margin:0;display:flex;flex-direction:column;align-items:center}
.lightbox-photo{background:var(--surface);padding:16px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8)}
.lightbox-photo img{display:block;max-width:88vw;max-height:80vh;width:auto;height:auto;object-fit:contain;filter:var(--img-filter)}
.lightbox-caption{display:flex;align-items:center;gap:16px;margin-top:18px;flex-wrap:wrap;justify-content:center}
.lightbox-code{font-family:'Courier Prime',monospace;font-size:12px;letter-spacing:0.12em;color:#c9b58a}
.lightbox-pos{font-family:'Courier Prime',monospace;font-size:11px;color:#857452}
.lightbox-download{
  display:inline-flex;align-items:center;font-family:'Courier Prime',monospace;font-size:11px;font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase;padding:10px 20px;background:var(--accent);color:#fdf7ec;
  border:none;border-radius:3px;text-decoration:none;cursor:pointer;
}
.lightbox-download:hover{filter:brightness(1.08)}

/* Download bar */
.download-bar{
  position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:50;
  display:flex;align-items:center;gap:18px;background:var(--accent-dark);color:#f4ead4;
  padding:12px 16px 12px 24px;border-radius:8px;box-shadow:0 22px 46px -18px rgba(0,0,0,.6);animation:pop .25s ease;
}
.download-bar .label{font-family:'Courier Prime',monospace;font-size:13px;letter-spacing:0.06em}
.btn-cancel{
  font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;
  padding:9px 14px;background:transparent;border:1px solid rgba(255,255,255,.25);border-radius:4px;color:#d8cab0;cursor:pointer;
}
.btn-cancel:hover{background:rgba(255,255,255,.08)}
.btn-zip{
  font-family:'Courier Prime',monospace;font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:9px 18px;background:var(--accent);color:#fdf7ec;border:none;border-radius:4px;cursor:pointer;
}
.btn-zip:hover{filter:brightness(1.1)}

/* Toast */
.toast{
  position:fixed;top:74px;left:50%;transform:translateX(-50%);z-index:90;background:var(--accent-dark);color:#f3e9d6;
  font-family:'Courier Prime',monospace;font-size:12px;letter-spacing:0.05em;padding:11px 20px;border-radius:5px;
  box-shadow:0 16px 34px -14px rgba(0,0,0,.55);animation:pop .2s ease;
}

/* Grain */
.grain-overlay{
  position:fixed;inset:0;z-index:95;pointer-events:none;opacity:0.05;mix-blend-mode:multiply;
  background-image:url('data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%22120%22 height=%22120%22%3E%3Cfilter id=%22n%22%3E%3CfeTurbulence type=%22fractalNoise%22 baseFrequency=%220.85%22 numOctaves=%222%22 stitchTiles=%22stitch%22/%3E%3C/filter%3E%3Crect width=%22100%25%22 height=%22100%25%22 filter=%22url(%23n)%22/%3E%3C/svg%3E');
  background-size:170px;
}

/* Admin */
.admin-main{max-width:1080px;margin:0 auto;padding:36px 30px 120px;animation:soft .35s ease}
.admin-header{border-bottom:1px solid #d9c8a6;padding-bottom:20px;margin-bottom:28px}
.admin-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:42px;margin:0;color:#2c2114}
.admin-subtitle{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.1em;color:var(--text-mono);margin:6px 0 0}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:24px;margin:0 0 14px;color:var(--text-primary)}
.section-note{font-size:15px;color:var(--text-muted);margin:0 0 18px}

.upload-dropzone{border:2px dashed #cdb98f;border-radius:6px;background:#faf4e8;padding:34px;text-align:center}
.upload-dropzone p{font-size:18px;color:var(--text-secondary);margin:0 0 4px}
.upload-hint{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.06em;color:var(--text-mono);margin:0 0 18px !important}
.btn-select-files{
  font-family:'Courier Prime',monospace;font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  padding:13px 26px;background:var(--accent);color:#fdf7ec;border:none;border-radius:3px;cursor:pointer;
}
.btn-select-files:hover{filter:brightness(1.07)}

.upload-list{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.upload-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:11px 16px}
.upload-name{font-family:'Courier Prime',monospace;font-size:12px;color:var(--text-secondary);width:160px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload-track{flex:1;height:6px;background:#e6dac3;border-radius:99px;overflow:hidden}
.upload-track .fill{height:100%;background:var(--accent);transition:width .25s ease}
.upload-pct{font-family:'Courier Prime',monospace;font-size:11px;color:#a08c62;width:54px;text-align:right}

.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:14px}
.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;display:flex;flex-direction:column}
.admin-card-image{position:relative;aspect-ratio:4/3;overflow:hidden;background:#e7dcc6}
.admin-card-image img{width:100%;height:100%;object-fit:cover;display:block;filter:var(--img-filter)}
.admin-badge{
  position:absolute;top:8px;left:8px;font-family:'Courier Prime',monospace;font-size:9px;letter-spacing:0.08em;
  text-transform:uppercase;padding:4px 8px;border-radius:99px;background:#e3ead7;color:#5b6b3f;
}
.admin-badge.hidden{background:#e5ddd4;color:#7a6a5a}
.admin-card-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:9px}
.admin-card-code{font-family:'Courier Prime',monospace;font-size:10px;letter-spacing:0.1em;color:#a08c62}
.admin-card-actions{display:flex;gap:6px}
.btn-small{
  flex:1;font-family:'Courier Prime',monospace;font-size:10px;letter-spacing:0.05em;text-transform:uppercase;
  padding:8px;background:transparent;border:1px solid #c9b794;border-radius:3px;color:#5b4a31;cursor:pointer;text-align:center;text-decoration:none;
}
.btn-small:hover{background:#ece0c6}
.btn-small.danger{flex:none;padding:8px 10px;border-color:#e0c3b8;color:#a8553c;font-size:11px}
.btn-small.danger:hover{background:#f3e3dc}

/* Edit modal */
.edit-modal-overlay{position:fixed;inset:0;z-index:70;background:rgba(28,21,12,.75);display:flex;align-items:center;justify-content:center;padding:24px;animation:soft .2s ease}
.edit-modal{
  width:760px;max-width:100%;background:#f7efe0;border-radius:8px;overflow:hidden;display:grid;
  grid-template-columns:1.3fr 1fr;animation:pop .25s ease;box-shadow:0 40px 80px -30px rgba(0,0,0,.7);
}
.edit-preview{background:#241d14;display:flex;align-items:center;justify-content:center;padding:24px;min-height:340px}
.edit-preview img{max-width:100%;max-height:340px;object-fit:contain;transition:filter .1s,transform .25s}
.edit-controls{padding:26px 24px;display:flex;flex-direction:column;gap:18px}
.edit-eyebrow{font-family:'Courier Prime',monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-mono);margin:0 0 4px}
.edit-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:24px;margin:0;color:#2c2114}
.edit-slider-row .row-label{display:flex;justify-content:space-between;font-family:'Courier Prime',monospace;font-size:11px;color:#8a7a55;margin-bottom:5px}
.edit-slider-row input[type=range]{width:100%;accent-color:var(--accent)}
.edit-rotate-label{font-family:'Courier Prime',monospace;font-size:11px;color:#8a7a55;margin:0 0 7px}
.edit-rotate-row{display:flex;gap:8px}
.edit-rotate-row button{flex:1;padding:9px;background:var(--surface);border:1px solid #c9b794;border-radius:3px;cursor:pointer;font-size:15px;color:#5b4a31}
.edit-rotate-row button:hover{background:#ece0c6}
.edit-footer{margin-top:auto;display:flex;gap:8px;padding-top:6px}
.edit-footer .btn-small{flex:1;padding:11px}

/* Login (family) */
.login-main{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;animation:fadeUp .4s ease}
.login-box{width:440px;max-width:100%}
.login-head{text-align:center;margin-bottom:32px}
.login-eyebrow{font-family:'Courier Prime',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-mono);margin:0 0 14px}
.login-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:48px;line-height:1;margin:0;color:#2c2114}
.login-desc{font-size:17px;line-height:1.5;color:var(--text-muted);margin:12px 0 0}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:32px}
.field-label{display:block;font-family:'Courier Prime',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-mono);margin-bottom:6px}
.field-input{width:100%;padding:13px 14px;border:1px solid #d6c5a3;border-radius:3px;background:#fffdf8;font-size:16px;color:#2c2114;margin-bottom:16px;outline:none}
.field-input:focus{border-color:var(--accent)}
.field-error{font-size:14px;color:#a8442f;margin:10px 0 0}
.btn-block{width:100%;margin-top:22px}
.code-input{
  width:100%;text-align:center;padding:18px;border:1px solid #d6c5a3;border-radius:4px;background:#fffdf8;
  font-family:'Courier Prime',monospace;font-size:36px;letter-spacing:0.5em;color:#2c2114;outline:none;
}
.code-input:focus{border-color:var(--accent)}
.login-links{display:flex;justify-content:space-between;margin-top:16px}
.login-links span{font-family:'Courier Prime',monospace;font-size:11px;color:#a08c62;cursor:pointer}
.login-links span:hover{color:#5b4a31}
.login-note{font-family:'Courier Prime',monospace;font-size:10px;letter-spacing:0.06em;color:#bcab86;margin:18px 0 0;text-align:center}

@media (max-width:860px){
  .hero{grid-template-columns:1fr;padding:34px 20px 60px}
  .hero-title{font-size:52px}
  .hero-photos{display:none}
  .edit-modal{grid-template-columns:1fr}
}
