/* =====================================================================
   SnapWed · Düğün QR Foto Paylaşım Platformu
   Tasarım sistemi v2  ·  admin + misafir + slayt + yazdirma
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --accent:#c9a227;
  --accent-2:#d98a7c;          /* yumusak blush ikincil */
  --accent-soft:#f5ecd6;
  --accent-ink:#8a6d12;
  --ink:#241f1a;
  --ink-soft:#6c6258;
  --muted:#a0958a;
  --bg:#fbf8f2;
  --bg-2:#f5efe4;
  --card:#ffffff;
  --line:#ece3d4;
  --line-strong:#ddd2bf;
  --danger:#c0392b;
  --ok:#2e8b57;
  --warn:#b8860b;
  --radius:20px;
  --radius-md:14px;
  --radius-sm:10px;
  --shadow:0 18px 50px -18px rgba(70,52,24,.28);
  --shadow-sm:0 8px 24px -12px rgba(70,52,24,.22);
  --shadow-xs:0 2px 8px rgba(70,52,24,.08);
  --serif:"Fraunces","Georgia",serif;
  --sans:"Manrope",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden;-webkit-text-size-adjust:100%}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;letter-spacing:.1px;
  overflow-x:hidden;width:100%;max-width:100%}
img,video,iframe,svg{max-width:100%;height:auto;display:block}
img{height:auto}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;margin:0 0 .4em;letter-spacing:.2px}
a{color:var(--accent-ink);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent)}
.muted{color:var(--muted)}
.small{font-size:.86rem}.xsmall{font-size:.76rem}
.center{text-align:center}

/* ---- Brand ---- */
.brand-mark{color:var(--accent);font-size:1.1em}
.brand-mark.big{font-size:2.6rem;display:block;margin-bottom:.1em}
.brand-lockup{display:flex;align-items:center;justify-content:center;gap:.45rem;margin-bottom:.2rem}
.brand-lockup h1{margin:0;font-size:1.7rem;letter-spacing:.3px}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.66rem 1.15rem;border-radius:999px;border:1px solid var(--line-strong);
  background:#fff;color:var(--ink);font-family:var(--sans);font-size:.92rem;font-weight:600;
  cursor:pointer;transition:.2s var(--ease);text-decoration:none;line-height:1;white-space:nowrap}
.btn:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-xs);color:var(--ink)}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(135deg,var(--accent),#dcc26b);color:#fff;border-color:transparent;
  box-shadow:0 10px 22px -10px rgba(201,162,39,.7)}
.btn-primary:hover{color:#fff;filter:brightness(1.04);box-shadow:0 14px 28px -10px rgba(201,162,39,.75)}
.btn-ghost{background:transparent;border-color:var(--line-strong)}
.btn-danger{background:#fff;color:var(--danger);border-color:#e7c9c4}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-sm{padding:.42rem .8rem;font-size:.82rem}
.btn-lg{padding:.9rem 1.5rem;font-size:1.05rem}
.btn-block{display:flex;width:100%}
.btn-wrap{white-space:normal;text-align:center}

/* Taşmayı önle: flex/grid çocukları küçülebilsin */
.topbar,.page-head,.head-actions,.link-row,.bulkbar,.lb-bar,.hero-actions,
.admin-main,.guest-main,.card,.auth-card,.upload-card,.split-panel{min-width:0;max-width:100%}
.link-row input,.link-row .btn{min-width:0}
.link-row input{overflow:hidden;text-overflow:ellipsis}

/* ---- Alerts ---- */
.alert{padding:.85rem 1.05rem;border-radius:var(--radius-sm);margin:0 0 1rem;font-size:.92rem;
  border:1px solid transparent;display:flex;gap:.5rem;align-items:flex-start}
.alert-success{background:#eaf7ef;color:#1d6b41;border-color:#c6e7d4}
.alert-error{background:#fbecea;color:#a4271b;border-color:#f0cdc8}
.alert-info{background:#fdf6e3;color:#8a6d12;border-color:#f0e2b8}

/* ---- Toasts ---- */
#toastWrap{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:2000;
  display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none}
.toast{background:#2b2620;color:#fff;padding:.7rem 1.1rem;border-radius:999px;font-size:.9rem;
  font-weight:600;box-shadow:var(--shadow);opacity:0;transform:translateY(-12px);
  transition:.3s var(--ease);max-width:90vw}
.toast.show{opacity:1;transform:translateY(0)}
.toast.ok{background:linear-gradient(135deg,#2e8b57,#3fa86c)}
.toast.err{background:linear-gradient(135deg,#c0392b,#d65647)}

/* ---- Forms ---- */
.form label{display:block;margin-bottom:.95rem;font-size:.88rem;font-weight:600;color:var(--ink-soft)}
.form input[type=text],.form input[type=email],.form input[type=password],
.form input[type=date],.form input[type=number],.form textarea,.form select,
input[type=text],input[type=email],input[type=password]{
  width:100%;margin-top:.4rem;padding:.78rem .95rem;border:1.5px solid var(--line);
  border-radius:var(--radius-sm);font:inherit;background:#fff;color:var(--ink);transition:.18s}
.form input::placeholder,.form textarea::placeholder{color:#bcb2a4}
.form input:focus,.form textarea:focus,input:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(201,162,39,.16)}
.form textarea{resize:vertical}
.color-input{height:48px;padding:.25rem;cursor:pointer}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 1.1rem}
@media(max-width:560px){.grid-2{grid-template-columns:1fr}}
.form-wide{max-width:740px}
.settings-box{border:1px solid var(--line);border-radius:var(--radius-md);padding:1.1rem 1.2rem;margin:.4rem 0 1.2rem;background:var(--bg)}
.settings-box legend{font-weight:700;padding:0 .5rem;color:var(--ink);font-family:var(--sans)}
.switch{display:flex;align-items:center;gap:.55rem;margin-bottom:.7rem!important;cursor:pointer;font-weight:500}
.switch input{width:auto!important;margin:0!important;width:18px!important;height:18px;accent-color:var(--accent)}

/* ---- Cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1.2rem}

/* ---- animasyon ---- */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.fade-up{animation:fadeUp .5s var(--ease) both}

/* =====================================================================
   AUTH / INSTALL
   ===================================================================== */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem;
  overflow-x:hidden;
  background:
    radial-gradient(900px 500px at 15% -10%,var(--accent-soft),transparent 60%),
    radial-gradient(900px 600px at 110% 10%,#f6e2dd,transparent 55%),
    var(--bg)}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:2.4rem;width:min(94vw,430px);box-shadow:var(--shadow);animation:fadeUp .5s var(--ease) both}
.auth-card .form{margin-top:1.3rem}

/* =====================================================================
   ADMIN
   ===================================================================== */
.admin-body{overflow-x:hidden}
.topbar{display:flex;align-items:center;gap:1.2rem;padding:.85rem 1.6rem;
  background:rgba(255,255,255,.85);backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.topbar-brand{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--ink)}
.topbar-brand:hover{color:var(--ink)}
.topbar-nav{display:flex;gap:.3rem;margin-left:1rem}
.topbar-nav a{padding:.5rem .85rem;border-radius:999px;color:var(--ink-soft);font-size:.9rem;font-weight:600}
.topbar-nav a:hover{background:var(--accent-soft);color:var(--accent-ink)}
.topbar-nav a.active{background:var(--accent-soft);color:var(--accent-ink)}
.topbar-user{margin-left:auto;display:flex;align-items:center;gap:.7rem}
.admin-main{max-width:1140px;margin:0 auto;padding:2rem 1.4rem 4rem}
.admin-footer{text-align:center;color:var(--muted);font-size:.82rem;padding:2rem;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:.35rem;align-items:center}

.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.page-head h1{font-size:2rem;margin:0}
.head-actions{display:flex;gap:.5rem;flex-wrap:wrap}

/* stat */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.7rem}
.stat-row.compact{grid-template-columns:repeat(4,1fr);gap:.7rem;margin-bottom:.9rem}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:1.2rem;text-align:center;box-shadow:var(--shadow-xs);transition:.2s var(--ease)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.stat-num{display:block;font-family:var(--serif);font-size:2.1rem;font-weight:700;color:var(--accent-ink);line-height:1}
.stat-row.compact .stat-num{font-size:1.5rem}
.stat-label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}

/* wedding grid */
.wedding-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr));gap:1.3rem}
.wedding-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-xs);transition:.22s var(--ease);color:var(--ink);animation:fadeUp .5s var(--ease) both}
.wedding-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--accent);color:var(--ink)}
.wc-cover{height:150px;background:linear-gradient(135deg,var(--accent),#e7d6a3);
  background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center}
.wc-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.25))}
.wc-cover-mark{font-size:2.8rem;color:rgba(255,255,255,.9);position:relative;z-index:1}
.wc-body{padding:1.05rem 1.15rem 1.25rem}
.wc-body h3{margin:0 0 .2rem;font-size:1.3rem}
.wc-meta{display:flex;justify-content:space-between;margin-top:.8rem;font-size:.82rem;color:var(--muted);font-weight:600}
.badge{position:absolute;top:.65rem;left:.65rem;background:rgba(0,0,0,.6);color:#fff;
  font-size:.72rem;padding:.28rem .6rem;border-radius:999px;z-index:2;font-weight:600}
.badge-warn{background:linear-gradient(135deg,#c79a18,#b8860b)}
.badge-muted{background:rgba(0,0,0,.55);left:auto;right:.65rem}

/* empty */
.empty-state{text-align:center;padding:4.5rem 1rem;background:#fff;border:1px dashed var(--line-strong);border-radius:var(--radius)}
.empty-state.small{padding:2.6rem 1rem}
.empty-icon{font-size:3.2rem;color:var(--accent);opacity:.55;margin-bottom:.5rem}

/* split panel */
.split-panel{display:grid;grid-template-columns:340px 1fr;gap:1.3rem;margin-bottom:1.4rem}
@media(max-width:760px){.split-panel{grid-template-columns:1fr}}
.qr-card{text-align:center}
.qr-img{width:210px;height:210px;margin:0 auto .7rem;border:1px solid var(--line);border-radius:var(--radius-md);background:#fff;padding:10px}
.qr-img.sm{width:130px;height:130px}
.link-row{display:flex;gap:.4rem;margin:.7rem 0}
.link-row input{flex:1;font-size:.8rem;margin-top:0}
.setting-flags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.chip{font-size:.74rem;padding:.28rem .65rem;border-radius:999px;border:1px solid var(--line);font-weight:600}
.chip-on{background:#eaf7ef;color:var(--ok);border-color:#c6e7d4}
.chip-off{background:var(--bg-2);color:var(--muted)}

/* contributors */
.contrib-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.6rem}
.contrib{display:flex;align-items:center;gap:.7rem;font-size:.9rem}
.contrib .avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex:none}
.contrib .cname{font-weight:600}
.contrib .ccount{margin-left:auto;color:var(--muted);font-weight:600}

/* filterbar */
.filterbar{display:flex;gap:.3rem;flex-wrap:wrap;margin:1.6rem 0 1rem;border-bottom:1px solid var(--line);padding-bottom:.3rem}
.filter-tab{padding:.55rem .95rem;border-radius:999px;color:var(--ink-soft);font-size:.9rem;font-weight:600}
.filter-tab:hover{background:var(--accent-soft);color:var(--accent-ink)}
.filter-tab.active{background:var(--accent);color:#fff}
.filter-tab.active:hover{color:#fff}

/* bulkbar */
.bulkbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:.65rem .95rem;margin-bottom:1rem;flex-wrap:wrap;position:sticky;top:64px;z-index:10;box-shadow:var(--shadow-xs)}
.checkall{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer;font-weight:600}
.checkall input{accent-color:var(--accent);width:17px;height:17px}
.bulk-actions{display:flex;gap:.4rem;flex-wrap:wrap}

/* photo grid (admin) */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,150px),1fr));gap:1rem}
.photo-item{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden;position:relative;box-shadow:var(--shadow-xs);transition:.2s var(--ease)}
.photo-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.photo-item.status-pending{border-color:#f0d98a}
.photo-item.status-rejected{opacity:.5}
.photo-check{position:absolute;top:.55rem;left:.55rem;z-index:2;background:rgba(255,255,255,.92);border-radius:7px;padding:.2rem;line-height:0}
.photo-check input{accent-color:var(--accent);width:17px;height:17px}
.fav-star{position:absolute;top:.55rem;right:.55rem;z-index:2;color:#f1c40f;font-size:1.15rem;text-shadow:0 1px 3px rgba(0,0,0,.35)}
.photo-thumb{display:block;aspect-ratio:1;background:var(--bg-2);position:relative}
.photo-thumb img,.photo-thumb video{width:100%;height:100%;object-fit:cover}
.video-badge{position:absolute;bottom:.55rem;left:.55rem;background:rgba(0,0,0,.65);color:#fff;font-size:.72rem;padding:.18rem .55rem;border-radius:999px;z-index:1;font-weight:600}
.like-pill{position:absolute;bottom:.55rem;right:.55rem;background:rgba(0,0,0,.6);color:#fff;font-size:.74rem;padding:.18rem .5rem;border-radius:999px;z-index:1;font-weight:600}
.photo-item figcaption{padding:.65rem .75rem;font-size:.82rem;display:flex;flex-direction:column;gap:.18rem}
.photo-item figcaption .msg{color:var(--ink-soft);font-style:italic}
.tag{align-self:flex-start;font-size:.7rem;padding:.12rem .5rem;border-radius:999px;margin-top:.25rem;font-weight:600}
.tag-warn{background:#fdf6e3;color:var(--warn)}
.tag-muted{background:var(--bg-2);color:var(--muted)}

.danger-zone{margin-top:2.6rem;padding-top:1.3rem;border-top:1px dashed var(--line-strong)}

/* tables */
.table-actions{margin:.4rem 0 1.2rem;display:flex;gap:.5rem;flex-wrap:wrap}
.table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,150px),1fr));gap:1rem}
.table-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:1.1rem;text-align:center;box-shadow:var(--shadow-xs);transition:.2s var(--ease)}
.table-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.table-card h4{margin:.55rem 0 .1rem}
.table-card-actions{display:flex;gap:.4rem;justify-content:center;margin-top:.8rem}
.table-card-actions form{margin:0}

/* admin guestbook list */
.gb-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:1rem}
.gb-admin .gb-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:1.1rem;box-shadow:var(--shadow-xs);position:relative}
.gb-admin .gb-msg{font-family:var(--serif);font-size:1.02rem;color:var(--ink);margin:.2rem 0 .6rem}
.gb-admin .gb-who{font-weight:700;color:var(--accent-ink)}

/* =====================================================================
   GUEST
   ===================================================================== */
.guest-body{background:var(--bg);overflow-x:hidden}
.guest-hero{min-height:52vh;background:linear-gradient(135deg,var(--accent),#e7d6a3);
  background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;
  text-align:center;color:#fff;padding:3.5rem 1.5rem;position:relative;overflow:hidden}
.guest-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 0,transparent 50%,rgba(0,0,0,.32))}
.hero-content{max-width:680px;position:relative;z-index:1;animation:fadeUp .6s var(--ease) both}
.hero-orn{font-size:2rem;opacity:.92;display:block;margin-bottom:.5rem}
.guest-hero h1{font-size:3rem;margin:0;color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.3);font-weight:600}
.hero-date{font-size:1.05rem;margin:.6rem 0 0;opacity:.96;font-weight:500;letter-spacing:.3px}
.hero-table{display:inline-block;margin-top:1rem;background:rgba(255,255,255,.22);
  backdrop-filter:blur(4px);padding:.4rem 1rem;border-radius:999px;font-size:.9rem;border:1px solid rgba(255,255,255,.4);font-weight:600}
.hero-actions{margin-top:1.3rem;display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}
.hero-actions .btn{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5);color:#fff;backdrop-filter:blur(4px)}
.hero-actions .btn:hover{background:#fff;color:var(--accent-ink)}

.guest-main{max-width:960px;margin:0 auto;padding:1.6rem 1.1rem 3rem}
.welcome-msg{text-align:center;font-family:var(--serif);font-size:1.25rem;color:var(--ink-soft);
  max-width:680px;margin:0 auto 1.8rem;font-style:italic;line-height:1.6}

.upload-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem;box-shadow:var(--shadow);margin-bottom:2.2rem;margin-top:-4rem;position:relative;z-index:2;animation:fadeUp .5s var(--ease) both}
.upload-card h2{font-size:1.45rem;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin:1.1rem 0}
@media(max-width:520px){.field-row{grid-template-columns:1fr}}
.field-row input{margin-top:0}

.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;
  border:2px dashed var(--line-strong);border-radius:var(--radius-md);padding:2.3rem 1rem;cursor:pointer;
  background:var(--bg);transition:.2s var(--ease);text-align:center}
.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--accent-soft)}
@media (hover:hover){.dropzone:hover,.dropzone.drag{transform:scale(1.01)}}
.dz-icon{font-size:2.2rem;color:var(--accent)}
.dz-title{font-weight:700;font-size:1.08rem}
.dz-sub{font-size:.85rem;color:var(--muted)}

.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:.5rem;margin:1.1rem 0}
.preview-grid:empty{display:none}
.preview-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:#eee;border:1px solid var(--line);animation:fadeUp .3s var(--ease) both}
.preview-thumb img,.preview-thumb video{width:100%;height:100%;object-fit:cover}
.preview-thumb .pv-remove{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.65);color:#fff;
  border:none;border-radius:50%;width:21px;height:21px;font-size:.7rem;cursor:pointer;line-height:1}
.preview-thumb .pv-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.3rem;background:rgba(255,255,255,.55);font-weight:700}
.preview-thumb.done .pv-state{color:var(--ok)}
.preview-thumb.err .pv-state{color:var(--danger)}

.upload-progress{margin-top:1rem;display:flex;align-items:center;gap:.7rem}
.progress-track{flex:1;height:9px;background:var(--line);border-radius:999px;overflow:hidden}
.progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .25s}
#progressText{font-size:.82rem;color:var(--muted);min-width:70px;text-align:right;font-weight:600}

/* section title */
.section-title{display:flex;align-items:center;gap:.8rem;justify-content:center;margin:2.4rem 0 1.4rem;color:var(--ink)}
.section-title::before,.section-title::after{content:"";height:1px;flex:1;max-width:80px;background:var(--line-strong)}
.section-title h2{margin:0;font-size:1.6rem}

/* guest gallery */
.gallery-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1rem}
.gallery-head h2{margin:0}
.guest-gallery{columns:4 200px;column-gap:.8rem}
@media(max-width:560px){.guest-gallery{columns:2 150px;column-gap:.6rem}}
.g-item{display:block;margin:0 0 .8rem;border-radius:var(--radius-md);overflow:hidden;position:relative;
  break-inside:avoid;box-shadow:var(--shadow-xs);background:#eee;cursor:zoom-in;animation:fadeUp .5s var(--ease) both}
.g-item:hover{box-shadow:var(--shadow-sm)}
.g-item img,.g-item video{width:100%;display:block;transition:.4s var(--ease)}
.g-item:hover img{transform:scale(1.05)}
.g-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:.7rem;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.6));
  opacity:0;transition:.25s var(--ease);color:#fff}
.g-item:hover .g-overlay{opacity:1}
.g-overlay .g-name{font-weight:700;font-size:.85rem}
.g-overlay .g-likes{font-size:.8rem;opacity:.95}
.g-item .video-badge{font-size:1rem;padding:.22rem .6rem}
.load-more-wrap{text-align:center;margin-top:1.4rem}

/* guestbook (guest) */
.guestbook-section{margin-top:1rem}
.gb-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow-sm);margin-bottom:1.6rem}
.gb-form .gb-row{display:flex;gap:.7rem;margin-top:.8rem;flex-wrap:wrap}
.gb-form .gb-row .btn{flex:none}
.gb-grid{columns:3 260px;column-gap:1rem}
@media(max-width:560px){.gb-grid{columns:1}}
.gb-note{break-inside:avoid;margin:0 0 1rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  padding:1.2rem;box-shadow:var(--shadow-xs);position:relative}
.gb-note::before{content:"\201C";position:absolute;top:-.2rem;left:.6rem;font-family:var(--serif);font-size:3rem;color:var(--accent-soft);line-height:1}
.gb-note .gb-text{font-family:var(--serif);font-size:1.08rem;color:var(--ink);margin:.4rem 0 .7rem;position:relative;z-index:1}
.gb-note .gb-from{font-weight:700;color:var(--accent-ink);font-size:.9rem}
.gb-note .gb-date{color:var(--muted);font-size:.74rem}

.guest-footer{text-align:center;padding:2.2rem 1rem;color:var(--muted);font-size:.85rem;border-top:1px solid var(--line)}
.footer-credit{font-size:.78rem;margin:.35rem 0 0;color:var(--muted)}
.footer-credit a{color:var(--accent-ink);font-weight:600;text-decoration:none;border-bottom:1px solid transparent;transition:.15s}
.footer-credit a:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* pin */
.pin-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem;
  background:radial-gradient(900px 500px at 50% -10%,var(--accent-soft),var(--bg))}
.pin-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:2.6rem 2rem;
  text-align:center;width:min(94vw,390px);box-shadow:var(--shadow);animation:fadeUp .5s var(--ease) both}
.pin-card .form{margin-top:1rem}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(18,14,9,.95);z-index:1000;display:flex;
  flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;animation:fadeUp .2s ease both}
.lightbox[hidden]{display:none}
[hidden]{display:none!important}
.lb-content{display:flex;align-items:center;justify-content:center;max-width:94vw;max-height:74vh}
.lb-content img,.lb-content video{max-width:94vw;max-height:74vh;border-radius:var(--radius-sm);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close{position:absolute;top:1rem;right:1.3rem;background:rgba(255,255,255,.12);border:none;color:#fff;
  font-size:1.4rem;cursor:pointer;width:44px;height:44px;border-radius:50%;transition:.2s}
.lb-close:hover{background:rgba(255,255,255,.25)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;
  color:#fff;font-size:1.6rem;cursor:pointer;width:50px;height:50px;border-radius:50%;transition:.2s;display:flex;align-items:center;justify-content:center}
.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-prev{left:1rem}.lb-next{right:1rem}
.lb-bar{margin-top:1.1rem;display:flex;align-items:center;gap:1rem;color:#fff;flex-wrap:wrap;justify-content:center}
.lb-caption{font-size:.95rem;opacity:.92;text-align:center}
.lb-caption b{color:#fff}
.lb-actions{display:flex;gap:.5rem}
.lb-btn{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);color:#fff;padding:.45rem .9rem;
  border-radius:999px;font-size:.85rem;cursor:pointer;font-weight:600;display:inline-flex;gap:.4rem;align-items:center;transition:.2s}
.lb-btn:hover{background:rgba(255,255,255,.28);color:#fff}
.lb-btn.liked{background:var(--accent-2);border-color:transparent}
.lb-counter{font-size:.82rem;opacity:.75}

/* =====================================================================
   SLIDESHOW / CANLI YANSITMA
   ===================================================================== */
.slideshow-body{margin:0;background:#0c0a07;overflow:hidden;height:100vh}
.ss-stage{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0c0a07}
.ss-slide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;
  transition:opacity 1.1s ease}
.ss-slide.active{opacity:1}
.ss-slide img,.ss-slide video{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:8px;
  box-shadow:0 30px 90px rgba(0,0,0,.6)}
.ss-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(45px) brightness(.4);transform:scale(1.2);z-index:-1}
.ss-caption{position:fixed;left:0;right:0;bottom:0;padding:2rem 2.5rem;color:#fff;z-index:5;
  background:linear-gradient(0deg,rgba(0,0,0,.75),transparent);display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}
.ss-caption .ss-who{font-family:var(--serif);font-size:1.8rem;font-weight:600}
.ss-caption .ss-msg{font-size:1.1rem;opacity:.9;font-style:italic}
.ss-brand{font-family:var(--serif);font-size:1.2rem;opacity:.85;text-align:right}
.ss-brand .ss-qr{margin-top:.5rem;width:90px;height:90px;border-radius:8px;background:#fff;padding:5px}
.ss-empty{color:#fff;text-align:center;font-family:var(--serif);font-size:1.6rem;opacity:.8}
.ss-controls{position:fixed;top:1rem;right:1rem;z-index:10;display:flex;gap:.5rem;opacity:.25;transition:.2s}
.ss-controls:hover{opacity:1}
.ss-controls button{background:rgba(255,255,255,.15);border:none;color:#fff;width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:1.1rem}
.ss-progress{position:fixed;top:0;left:0;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:10;width:0;transition:width .15s linear}

/* =====================================================================
   QR POSTER / SHEET (print)
   ===================================================================== */
.poster-body,.sheet-body{background:#efe9dd;min-height:100vh;overflow-x:hidden}
.poster-toolbar{display:flex;justify-content:space-between;align-items:center;max-width:800px;
  margin:0 auto;padding:1rem 1.2rem;gap:.5rem}
.poster-toolbar>div{display:flex;gap:.5rem}
.poster{max-width:560px;margin:0 auto 3rem;padding:0 1rem}
.poster-inner{background:#fff;border-radius:24px;padding:2.8rem 2rem 2rem;text-align:center;
  box-shadow:var(--shadow);border:1px solid var(--line);position:relative;overflow:hidden}
.poster-inner::before{content:"";position:absolute;top:0;left:0;right:0;height:8px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.poster-orn{color:var(--accent);font-size:1.7rem}
.poster-orn.small{font-size:1.1rem}
.poster-eyebrow{letter-spacing:3px;text-transform:uppercase;font-size:.72rem;color:var(--muted);margin:.7rem 0 .2rem;font-weight:700}
.poster-title{font-size:2.4rem;color:var(--ink);margin:.2rem 0}
.poster-date{color:var(--accent-ink);font-size:1rem;margin:0;font-weight:600}
.poster-qr{margin:1.7rem auto;width:min(320px,80%)}
.poster-qr img{width:100%;border:1px solid var(--line);border-radius:var(--radius-md);padding:12px;background:#fff}
.poster-table{display:inline-block;background:var(--accent-soft);color:var(--accent-ink);
  font-weight:700;padding:.45rem 1.2rem;border-radius:999px;margin-bottom:1rem}
.poster-steps{text-align:left;max-width:340px;margin:0 auto 1.5rem;display:flex;flex-direction:column;gap:.7rem}
.pstep{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--ink-soft)}
.pstep span{flex:none;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}
.poster-foot{border-top:1px solid var(--line);padding-top:1rem;color:var(--muted);font-size:.78rem}

.sheet{max-width:900px;margin:0 auto 3rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 1rem}
.sheet-cell{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:1.4rem;text-align:center}
.sheet-cell img{width:min(220px,70%);margin:.6rem auto;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px}
.sheet-eyebrow{font-family:var(--serif);color:var(--accent-ink);font-size:.9rem;margin:0}
.sheet-cell h3{margin:.2rem 0}

/* Toplu QR föyü — A4, sayfa başına 4 kart (2×2) */
.sheet-page{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:900px;
  margin:0 auto 2rem;padding:0 1rem}
.qr-sheet-card{background:#fff;border:1px solid var(--line);border-radius:16px;
  overflow:hidden;text-align:center;box-shadow:var(--shadow-xs);position:relative}
.qsc-accent{height:5px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.qsc-body{padding:1.1rem 1rem 1.15rem;display:flex;flex-direction:column;align-items:center;gap:0}
.qsc-orn{color:var(--accent);font-size:1rem;line-height:1;margin-bottom:.15rem}
.qsc-couple{font-family:var(--serif);font-size:1.35rem;font-weight:600;color:var(--ink);
  margin:0;line-height:1.2;max-width:100%;overflow-wrap:anywhere}
.qsc-tagline{font-size:.78rem;color:var(--ink-soft);margin:.45rem 0 .65rem;line-height:1.45;
  font-weight:500;max-width:14em}
.qsc-qr{width:min(148px, 72%);margin:0 auto .55rem}
.qsc-qr img{width:100%;display:block;border:1px solid var(--line);border-radius:10px;padding:7px;background:#fff}
.qsc-table{display:inline-block;background:var(--accent-soft);color:var(--accent-ink);
  font-weight:700;font-size:.82rem;padding:.32rem .85rem;border-radius:999px;margin-bottom:.55rem}
.qsc-link-block{border-top:1px dashed var(--line);padding-top:.5rem;width:100%;margin-top:.1rem}
.qsc-link-or{display:block;font-family:var(--serif);font-size:.85rem;color:var(--muted);font-style:italic;margin-bottom:.15rem}
.qsc-link{display:block;font-size:.68rem;color:var(--accent-ink);font-weight:600;
  word-break:break-all;line-height:1.35;padding:0 .15rem}

@media print{
  @page{size:A4;margin:10mm}
  .no-print{display:none!important}
  body{background:#fff!important}
  .poster-inner,.sheet-cell,.qr-sheet-card{box-shadow:none;border:1px solid #ccc}
  .poster{margin:0 auto}
  .sheet-cell{break-inside:avoid;page-break-inside:avoid}
  .sheet-page{
    width:190mm;height:277mm;max-width:none;margin:0;padding:0;gap:6mm;
    grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
    page-break-after:always;break-after:page
  }
  .sheet-page:last-child{page-break-after:auto;break-after:auto}
  .qr-sheet-card{
    break-inside:avoid;page-break-inside:avoid;height:100%;
    display:flex;flex-direction:column;border-radius:8px
  }
  .qsc-body{flex:1;justify-content:center;padding:.9rem .75rem 1rem}
  .qsc-couple{font-size:1.2rem}
  .qsc-tagline{font-size:.72rem;margin:.35rem 0 .5rem}
  .qsc-qr{width:38mm;margin-bottom:.4rem}
  .qsc-qr img{padding:4px;border-radius:6px}
  .qsc-table{font-size:.75rem;margin-bottom:.4rem}
  .qsc-link{font-size:.62rem}
  .qsc-link-or{font-size:.78rem}
}

/* =====================================================================
   LANDING · SnapWed giriş sayfası
   ===================================================================== */
.landing-page{background:var(--bg);overflow-x:hidden}

/* Üst navigasyon */
.landing-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.85rem max(1.4rem, env(safe-area-inset-right)) .85rem max(1.4rem, env(safe-area-inset-left));
  background:rgba(255,255,255,.88);backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.landing-logo{display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--ink);font-weight:700}
.landing-logo:hover{color:var(--ink)}
.logo-mark{color:var(--accent);font-size:1.15rem}
.logo-text{font-family:var(--serif);font-size:1.35rem;letter-spacing:.2px}
.logo-accent{color:var(--accent-ink)}
.landing-nav-links{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.landing-nav-links a:not(.btn){padding:.45rem .75rem;font-size:.88rem;font-weight:600;color:var(--ink-soft);border-radius:999px}
.landing-nav-links a:not(.btn):hover{color:var(--accent-ink);background:var(--accent-soft)}

/* Hero */
.landing-hero{padding:3.5rem 1.5rem 4rem;
  background:
    radial-gradient(900px 520px at 8% -5%,var(--accent-soft),transparent 58%),
    radial-gradient(800px 500px at 105% 15%,#f6e2dd,transparent 52%),
    var(--bg)}
.hero-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;
  gap:2.5rem;align-items:center}
.hero-copy{text-align:left}
.landing-badge{display:inline-block;background:var(--accent-soft);color:var(--accent-ink);
  font-size:.76rem;font-weight:700;padding:.38rem .9rem;border-radius:999px;
  letter-spacing:.4px;text-transform:uppercase;margin-bottom:1rem}
.landing-hero h1{font-family:var(--serif);font-size:clamp(2rem,4.5vw,3.1rem);line-height:1.12;
  margin:0 0 1rem;color:var(--ink)}
.landing-hero h1 em{font-style:normal;color:var(--accent-ink);position:relative}
.landing-hero p.lead{font-size:1.08rem;color:var(--ink-soft);max-width:34em;margin:0 0 1.6rem;line-height:1.65}
.landing-actions{display:flex;gap:.65rem;flex-wrap:wrap}
.hero-trust{display:flex;flex-wrap:wrap;gap:.65rem 1.1rem;margin:1.4rem 0 0;padding:0;list-style:none}
.hero-trust li{font-size:.82rem;color:var(--muted);font-weight:600}

/* Telefon mockup */
.hero-visual{position:relative;display:flex;justify-content:center;padding:1rem 0}
.phone-mock{width:min(260px,88vw);background:#1a1612;border-radius:32px;padding:10px;
  box-shadow:0 28px 60px -20px rgba(40,30,15,.45),inset 0 0 0 1px rgba(255,255,255,.08)}
.phone-notch{width:36%;height:5px;background:#333;border-radius:99px;margin:4px auto 8px}
.phone-screen{background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);border-radius:24px;
  padding:1rem .85rem 1.1rem;text-align:center}
.mock-header{font-family:var(--serif);font-weight:600;font-size:.95rem;color:var(--ink);margin-bottom:.7rem}
.mock-qr{width:100px;height:100px;margin:0 auto .55rem;border:2px solid var(--line);border-radius:12px;
  display:flex;align-items:center;justify-content:center;background:#fff;padding:8px}
.mock-qr-grid{display:block;width:100%;height:100%;
  background:
    linear-gradient(90deg,#111 2px,transparent 2px) 0 0/14px 14px,
    linear-gradient(#111 2px,transparent 2px) 0 0/14px 14px;
  opacity:.85;border-radius:4px}
.mock-hint{font-size:.68rem;color:var(--muted);margin:0 0 .75rem;font-weight:600}
.mock-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.mock-gallery span{aspect-ratio:1;background:linear-gradient(135deg,var(--accent-soft),#f0e6d0);
  border-radius:5px;border:1px solid var(--line)}
.hero-float{position:absolute;background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:.4rem .75rem;font-size:.74rem;font-weight:700;box-shadow:var(--shadow-sm);white-space:nowrap}
.hero-float-1{top:8%;right:0;animation:floatY 4s ease-in-out infinite}
.hero-float-2{bottom:12%;left:-2%;animation:floatY 4.5s ease-in-out infinite reverse}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Bölümler */
.landing-section{padding:3.5rem 1.5rem}
.landing-section-alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-wrap{max-width:980px;margin:0 auto}
.section-head{margin-bottom:2rem}
.section-head.center{text-align:center}
.section-head h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:.3rem 0 .5rem}
.section-head .muted{max-width:36em;margin:0 auto}
.section-label{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;color:var(--accent-ink);background:var(--accent-soft);padding:.3rem .75rem;border-radius:999px}

.landing-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.l-step{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  padding:1.4rem 1.2rem;box-shadow:var(--shadow-xs);text-align:left;transition:.2s var(--ease)}
.l-step:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.l-step-num{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:.75rem;font-size:.95rem}
.l-step h3{margin:0 0 .35rem;font-size:1.05rem;font-family:var(--sans)}

.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.feature{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:1.3rem;box-shadow:var(--shadow-xs);transition:.2s var(--ease);text-align:left}
.landing-section-alt .feature{background:#fff}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.feature .fic{font-size:1.7rem;margin-bottom:.35rem;line-height:1}
.feature h3{font-size:1.02rem;margin:.15rem 0 .35rem;font-family:var(--sans)}

/* Hedef kitle kartları */
.audience-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.audience-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.4rem;text-align:center;box-shadow:var(--shadow-xs)}
.audience-card-muted{background:var(--bg-2)}
.audience-icon{font-size:2rem;display:block;margin-bottom:.5rem}
.audience-card h3{margin:0 0 .5rem;font-size:1.15rem}
.audience-card .btn{margin-top:.9rem}
.audience-note{margin-top:.75rem;font-style:italic}

/* Alt CTA bandı */
.landing-cta{padding:3.2rem 1.5rem;
  background:linear-gradient(135deg,var(--accent-soft) 0%,#f6e8dc 50%,var(--bg) 100%);
  border-top:1px solid var(--line)}
.landing-cta h2{margin:0 0 .4rem;font-size:clamp(1.5rem,3vw,2rem)}
.landing-cta .landing-actions{justify-content:center;margin-top:1.2rem}

.landing-footer{text-align:center;padding:2rem 1rem 2.5rem;color:var(--muted);
  border-top:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:.25rem}
.landing-footer strong{color:var(--ink);font-family:var(--serif)}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-copy{text-align:center}
  .landing-actions,.hero-trust{justify-content:center}
  .feature-row{grid-template-columns:repeat(2,1fr)}
  .landing-nav-links a:not(.btn):nth-child(1),
  .landing-nav-links a:not(.btn):nth-child(2){display:none}
}
@media(max-width:640px){
  .landing-steps,.audience-grid,.feature-row{grid-template-columns:1fr}
  .landing-hero{padding:2.5rem 1.1rem 3rem}
  .landing-section{padding:2.5rem 1.1rem}
  .hero-float{display:none}
  .landing-nav-links .btn-ghost{display:none}
}

/* =====================================================================
   RESPONSIVE  ·  tablet & telefon uyumu
   ===================================================================== */

/* ---- Tablet (<= 900px) ---- */
@media (max-width:900px){
  .admin-main{padding:1.6rem 1.1rem 3.5rem}
  .page-head h1{font-size:1.7rem}
  .stat-num{font-size:1.8rem}
  .landing-hero h1{font-size:2.8rem}
}

/* ---- Üst bar: küçük ekranlarda yeniden düzen ---- */
@media (max-width:720px){
  .topbar{flex-wrap:wrap;gap:.5rem .9rem;padding:.6rem max(.9rem, env(safe-area-inset-right)) .6rem max(.9rem, env(safe-area-inset-left))}
  .topbar-brand{font-size:1.12rem;flex:1 1 auto;min-width:0}
  .topbar-nav{order:3;width:100%;margin-left:0;gap:.35rem;
    overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;
    padding-bottom:.15rem;scrollbar-width:none;max-width:100%}
  .topbar-nav::-webkit-scrollbar{display:none}
  .topbar-nav a{flex:none}
  .topbar-user{margin-left:auto;flex-shrink:0}
  .bulkbar{position:static}
}
@media (max-width:480px){
  .topbar-user .muted{display:none}
}

/* ---- Telefon (<= 600px) ---- */
@media (max-width:600px){
  body{letter-spacing:0}
  .admin-main{padding:1.1rem max(.85rem, env(safe-area-inset-right)) 3rem max(.85rem, env(safe-area-inset-left))}
  .guest-main{padding:1.2rem max(.9rem, env(safe-area-inset-right)) 2.6rem max(.9rem, env(safe-area-inset-left))}

  /* uzun metinler taşmasın */
  h1,h2,h3,h4,.welcome-msg,.gb-note .gb-text,.poster-foot p{overflow-wrap:anywhere;word-break:break-word}

  /* butonlar satır kırabilsin */
  .btn{white-space:normal;text-align:center;max-width:100%}
  .head-actions{display:grid;grid-template-columns:1fr 1fr;gap:.45rem;width:100%}
  .head-actions .btn{width:100%;padding-left:.75rem;padding-right:.75rem;font-size:.82rem}
  .head-actions .btn-primary{grid-column:1 / -1}

  /* başlık + aksiyonlar */
  .page-head{flex-direction:column;align-items:stretch;gap:.8rem}
  .page-head h1{font-size:1.5rem}

  /* istatistik kartları */
  .stat-row{grid-template-columns:repeat(3,1fr);gap:.6rem}
  .stat-row.compact{grid-template-columns:repeat(2,1fr)}
  .stat-card{padding:.9rem .45rem;min-width:0}
  .stat-num{font-size:1.5rem}
  .stat-label{font-size:.68rem}

  /* ızgaralar */
  .wedding-grid{grid-template-columns:1fr;gap:1rem}
  .photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}
  .table-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}
  .gb-admin{grid-template-columns:1fr}

  /* filtre & toplu işlem barı kaydırılabilir (sayfa kaydırmaz) */
  .filterbar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
    padding-bottom:.4rem;max-width:100%;width:100%}
  .filterbar::-webkit-scrollbar{display:none}
  .filter-tab{white-space:nowrap;flex:none}
  .bulkbar{flex-direction:column;align-items:stretch;gap:.6rem}
  .bulk-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem;width:100%}
  .bulk-actions .btn{justify-content:center;width:100%}

  /* QR link satırı */
  .link-row{flex-direction:column;align-items:stretch}
  .link-row .btn{width:100%}

  /* formlar */
  .card{padding:1.1rem}
  .auth-card{padding:1.8rem 1.4rem;width:100%;max-width:100%}
  /* iOS otomatik yakınlaşmasını engelle (>=16px) */
  .form input,.form textarea,.form select,
  input[type=text],input[type=email],input[type=password],
  input[type=date],input[type=number]{font-size:16px;max-width:100%}

  /* misafir kahraman bölümü */
  .guest-hero{min-height:38vh;padding:2.2rem max(1rem, env(safe-area-inset-right)) 2.2rem max(1rem, env(safe-area-inset-left))}
  .guest-hero h1{font-size:2rem;line-height:1.15}
  .hero-date{font-size:.92rem}
  .hero-orn{font-size:1.6rem}
  .hero-actions{gap:.45rem;width:100%}
  .hero-actions .btn{font-size:.84rem;padding:.55rem .85rem;flex:1 1 auto;min-width:0}
  .welcome-msg{font-size:1.05rem;margin-bottom:1.4rem;padding:0 .2rem}

  .upload-card{margin-top:-2rem;padding:1.15rem;border-radius:18px;width:100%}
  .upload-card h2{font-size:1.2rem;flex-wrap:wrap}
  .dropzone{padding:1.6rem .85rem}
  .section-title{margin:2rem 0 1.1rem;padding:0 .2rem}
  .section-title h2{font-size:1.3rem}
  .section-title::before,.section-title::after{max-width:28px}
  .upload-progress{flex-wrap:wrap}
  #progressText{min-width:0;width:100%;text-align:left;margin-top:.2rem}

  /* galeri: masonry yerine düzenli grid (taşma riski yok) */
  .guest-gallery{columns:unset!important;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}
  .g-item{margin:0!important}
  .gb-grid{columns:unset!important;display:grid;grid-template-columns:1fr;gap:.8rem}
  .gb-note{margin:0!important}

  /* lightbox */
  .lightbox{padding:max(.75rem, env(safe-area-inset-top)) max(.75rem, env(safe-area-inset-right)) max(.75rem, env(safe-area-inset-bottom)) max(.75rem, env(safe-area-inset-left))}
  .lb-close{top:max(.6rem, env(safe-area-inset-top));right:max(.7rem, env(safe-area-inset-right));width:40px;height:40px;font-size:1.2rem}
  .lb-nav{width:38px;height:38px;font-size:1.2rem}
  .lb-prev{left:max(.35rem, env(safe-area-inset-left))}.lb-next{right:max(.35rem, env(safe-area-inset-right))}
  .lb-content,.lb-content img,.lb-content video{max-width:100%;max-height:62vh}
  .lb-bar{flex-direction:column;gap:.5rem;text-align:center;width:100%;padding:0 .5rem}
  .lb-actions{flex-wrap:wrap;justify-content:center}

  /* slayt gösterisi */
  .ss-caption{padding:1rem max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
    flex-direction:column;align-items:flex-start;gap:.4rem}
  .ss-caption .ss-who{font-size:1.2rem}
  .ss-caption .ss-msg{font-size:.9rem}
  .ss-brand{text-align:left;font-size:.95rem}
  .ss-brand .ss-qr{width:62px;height:62px;margin-top:.3rem}
  .ss-controls{opacity:.85;top:max(1rem, env(safe-area-inset-top));right:max(1rem, env(safe-area-inset-right))}
  .ss-controls button{width:40px;height:40px}

  /* yazdırma araç çubuğu / föy */
  .poster-toolbar{flex-wrap:wrap;padding-left:max(1rem, env(safe-area-inset-left));padding-right:max(1rem, env(safe-area-inset-right))}
  .poster-toolbar>div{width:100%;justify-content:center}
  .poster{padding-left:max(1rem, env(safe-area-inset-left));padding-right:max(1rem, env(safe-area-inset-right))}
  .poster-title{font-size:1.85rem}
  .poster-inner{padding:2rem 1.2rem 1.6rem}
  .sheet{grid-template-columns:1fr;padding-left:max(1rem, env(safe-area-inset-left));padding-right:max(1rem, env(safe-area-inset-right))}
  .sheet-page{grid-template-columns:1fr;max-width:100%;padding:0 1rem}
  .qsc-couple{font-size:1.2rem}
  .qsc-qr{width:min(180px, 65%)}

  /* açılış (landing) */
  .landing-actions .btn{flex:1 1 auto;min-width:0}
  .landing-actions{width:100%;justify-content:center}
  .hero-inner{gap:1.5rem}

  /* masa kartları */
  .table-card-actions{flex-wrap:wrap}
  .table-card-actions .btn,.table-card-actions form .btn{flex:1 1 auto}
  .table-card-actions form{flex:1 1 100%;display:flex;justify-content:center}

  /* pin ekranı */
  .pin-screen{padding:max(1.5rem, env(safe-area-inset-top)) max(1.5rem, env(safe-area-inset-right)) max(1.5rem, env(safe-area-inset-bottom)) max(1.5rem, env(safe-area-inset-left))}
  .pin-card{width:100%;max-width:100%;padding:2rem 1.3rem}
}

/* ---- Küçük telefon (<= 380px) ---- */
@media (max-width:380px){
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}
  .guest-hero h1{font-size:1.75rem}
  .qr-img{width:min(180px, 72vw);height:min(180px, 72vw)}
  .head-actions{grid-template-columns:1fr}
  .hero-actions .btn{flex:1 1 100%}
}

/* =====================================================================
   v3 · Misafir deneyimi + admin ekleri
   ===================================================================== */

/* Canlı istatistik şeridi */
.live-stats{display:flex;justify-content:space-around;gap:.5rem;padding:.75rem 1rem;
  background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;
  box-shadow:0 2px 12px rgba(70,52,24,.06)}
.ls-item{text-align:center;flex:1;min-width:0}
.ls-num{display:block;font-family:var(--serif);font-size:1.35rem;font-weight:700;color:var(--accent-ink);line-height:1.1}
.ls-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-weight:600}

.goal-strip{padding:.55rem 1rem;background:var(--accent-soft);border-bottom:1px solid var(--line)}
.goal-strip-text{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600;color:var(--accent-ink);margin-bottom:.35rem}
.goal-bar{height:8px;background:rgba(255,255,255,.7);border-radius:999px;overflow:hidden}
.goal-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:999px;transition:width .6s var(--ease)}
.goal-bar-wrap{margin:.8rem 0}
.goal-bar-label{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600;margin-bottom:.35rem}

/* v3 hero — daha kompakt */
.guest-v3 .v3-hero{min-height:38vh;padding:2.5rem 1.5rem 3rem}
.guest-v3 .guest-main{padding-bottom:5.5rem}

/* Adım başlıkları */
.step-header{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:1.1rem}
.step-header.sm{margin-bottom:.75rem;align-items:center}
.step-header h2{margin:0;font-size:1.35rem}
.step-badge{flex:none;width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#dcc26b);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;
  box-shadow:0 4px 12px rgba(201,162,39,.35)}
.step-header.sm .step-badge{width:26px;height:26px;font-size:.78rem}
.upload-step{margin-bottom:1.4rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.upload-step:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}

.v3-upload{margin-top:-2.5rem}
.v3-drop{border-radius:var(--radius);padding:0;overflow:hidden;border-width:2px}
.v3-drop .dz-inner{padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.3rem}

/* Görev seçici */
.challenge-picker{display:flex;flex-wrap:wrap;gap:.5rem}
.ch-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;
  border:1.5px solid var(--line);border-radius:999px;cursor:pointer;
  font-size:.85rem;font-weight:600;background:#fff;transition:.18s var(--ease);user-select:none}
.ch-pill:hover{border-color:var(--accent);background:var(--accent-soft)}
.ch-pill.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink);
  box-shadow:0 0 0 3px rgba(201,162,39,.15)}
.ch-pill .ch-emoji{font-size:1.1rem}

/* Galeri sıralama */
.sort-tabs{display:flex;gap:.3rem}
.sort-tab{padding:.35rem .75rem;border-radius:999px;font-size:.82rem;font-weight:600;
  color:var(--muted);border:1px solid var(--line);transition:.15s}
.sort-tab:hover{color:var(--accent-ink);border-color:var(--accent)}
.sort-tab.active{background:var(--accent);color:#fff;border-color:transparent}

.empty-gallery{text-align:center;padding:2.5rem 1rem;color:var(--muted)}
.empty-g-icon{font-size:2.5rem;display:block;margin-bottom:.5rem}

/* Alt navigasyon */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;
  display:flex;background:rgba(255,255,255,.94);backdrop-filter:saturate(180%) blur(14px);
  border-top:1px solid var(--line);padding:.35rem 0 max(.35rem, env(safe-area-inset-bottom));
  box-shadow:0 -4px 20px rgba(70,52,24,.08)}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;
  padding:.45rem .3rem;font-size:.68rem;font-weight:600;color:var(--muted);text-decoration:none;transition:.15s}
.bn-item span{font-size:1.25rem;line-height:1}
.bn-item:hover,.bn-item.active{color:var(--accent-ink)}
.bn-item.active span{transform:scale(1.1)}
.bn-wa{color:#25D366}
.bn-wa:hover{color:#128C7E}

/* Lightbox emoji tepkileri */
.lb-reactions{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;width:100%}
.lb-react{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;
  padding:.4rem .7rem;border-radius:999px;font-size:.9rem;cursor:pointer;font-weight:600;
  display:inline-flex;gap:.3rem;align-items:center;transition:.18s}
.lb-react:hover,.lb-react.active{background:rgba(255,255,255,.25);transform:scale(1.05)}
.lb-react.active{border-color:var(--accent);background:rgba(201,162,39,.35)}

/* Confetti */
#confettiCanvas{position:fixed;inset:0;pointer-events:none;z-index:3000;overflow:hidden}
.confetti-piece{position:absolute;top:-10px;width:10px;height:10px;border-radius:2px;
  animation:confettiFall linear forwards}
@keyframes confettiFall{
  0%{transform:translateY(0) rotate(0deg);opacity:1}
  100%{transform:translateY(100vh) rotate(720deg);opacity:0}
}

/* Admin: aktivite & görevler */
.activity-feed{display:flex;flex-direction:column;gap:.45rem;margin-top:.5rem}
.activity-item{display:flex;align-items:center;gap:.55rem;font-size:.88rem;padding:.45rem 0;border-bottom:1px solid var(--line)}
.activity-item:last-child{border-bottom:none}
.act-icon{flex:none;font-size:1.1rem}
.act-text{flex:1;min-width:0}
.act-time{flex:none}

.challenge-admin-list{display:flex;flex-direction:column;gap:.6rem}
.challenge-admin-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-md)}
.challenge-admin-item.inactive{opacity:.55}
.challenge-admin-item .ch-emoji{font-size:1.5rem;flex:none}
.challenge-admin-item .ch-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}
.challenge-admin-item .ch-actions{display:flex;gap:.35rem;flex-wrap:wrap}

/* Kullanıcı onay tablosu */
.user-table{width:100%;border-collapse:collapse;font-size:.9rem}
.user-table th,.user-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.user-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;background:var(--bg)}
.user-table tr:last-child td{border-bottom:none}
.user-actions{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}
.user-actions form{margin:0}
@media(max-width:720px){
  .user-table thead{display:none}
  .user-table tr{display:block;padding:.85rem 1rem;border-bottom:1px solid var(--line)}
  .user-table td{display:flex;justify-content:space-between;gap:.5rem;padding:.25rem 0;border:none}
  .user-table td::before{content:attr(data-label);font-weight:600;color:var(--muted);font-size:.75rem}
  .user-actions{justify-content:flex-start;margin-top:.4rem}
}

.lock-upload-box{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--line)}
.upload-closed-notice{text-align:center;line-height:1.6}

@media(max-width:600px){
  .live-stats{padding:.6rem .5rem}
  .ls-num{font-size:1.15rem}
  .ls-label{font-size:.62rem}
  .challenge-picker{gap:.4rem}
  .ch-pill{font-size:.78rem;padding:.4rem .65rem}
  .guest-v3 .v3-upload{margin-top:-1.5rem}
  .bottom-nav .bn-item{font-size:.62rem}
}
