/* =========================================================
   Büşra & İsmail — Fotoğraf Paylaşımı
   Ana stil dosyası  (suluboya lavanta teması)
   ========================================================= */

:root{
  --lav-50:#f8f6fd;  --lav-100:#efeafb; --lav-200:#ddd4f4;
  --lav-300:#c6b6ec;  --lav-400:#a992de; --lav-500:#8d74cd;
  --lav-600:#7259b4;  --lav-700:#59459a; --lav-800:#3f2f73;
  --peri:#7d92d6;     --peri-deep:#5f74c4;
  --ink:#3a2f56;      --ink-soft:#6a6088;
  --cream:#fdfcff;    --paper:#ffffff;
  --rose:#e05f83;     --rose-deep:#c9436b;
  --gold:#c9a86a;

  --grad: linear-gradient(135deg, #8d74cd 0%, #7d92d6 100%);
  --grad-soft: linear-gradient(135deg, #a992de 0%, #9fb0e6 100%);

  --shadow-sm: 0 2px 8px rgba(89,69,154,.08);
  --shadow-md: 0 8px 28px rgba(89,69,154,.14);
  --shadow-lg: 0 18px 50px rgba(63,47,115,.22);

  --radius: 20px;
  --radius-sm: 14px;

  --font-display:"Cormorant Garamond", Georgia, serif;
  --font-body:"Jost","Poppins", system-ui, -apple-system, sans-serif;

  --nav-h: 68px;
}

*,*::before,*::after{ box-sizing:border-box; }
[hidden]{ display:none !important; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* Sayfa geneli suluboya doku (çok hafif) */
body::before{
  content:"";
  position:fixed; inset:0;
  background:url("../img/bg-pattern.png") center/620px repeat;
  opacity:.10;
  z-index:-2;
  pointer-events:none;
}
body::after{
  content:"";
  position:fixed; inset:0;
  background:radial-gradient(circle at 50% 0%, rgba(255,255,255,.35), rgba(253,252,255,.92) 60%, var(--cream));
  z-index:-1;
  pointer-events:none;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

h1,h2,h3,.display{ font-family:var(--font-display); font-weight:600; line-height:1.1; letter-spacing:.3px; }

.container{ width:100%; max-width:1240px; margin:0 auto; padding:0 20px; }
.center{ text-align:center; }
.muted{ color:var(--ink-soft); }

/* ---------- Script başlık aksanı ---------- */
.script{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:500;
  color:var(--lav-600);
}

/* =========================================================
   Butonlar
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  border:none; border-radius:100px;
  padding:.85em 1.7em;
  font-size:.98rem; font-weight:500; letter-spacing:.3px;
  background:var(--grad); color:#fff;
  box-shadow:0 8px 22px rgba(125,90,205,.32);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(125,90,205,.42); }
.btn:active{ transform:translateY(0); }
.btn.ghost{
  background:rgba(255,255,255,.7); color:var(--lav-700);
  box-shadow:inset 0 0 0 1.5px var(--lav-300), var(--shadow-sm);
  backdrop-filter:blur(6px);
}
.btn.ghost:hover{ background:#fff; box-shadow:inset 0 0 0 1.5px var(--lav-400), var(--shadow-md); }
.btn.sm{ padding:.6em 1.2em; font-size:.88rem; }
.btn.lg{ padding:1em 2.2em; font-size:1.06rem; }
.btn[disabled]{ opacity:.5; cursor:not-allowed; transform:none; }
.btn svg{ width:1.15em; height:1.15em; }

/* =========================================================
   Üst menü
   ========================================================= */
.nav{
  position:sticky; top:0; z-index:60;
  height:var(--nav-h);
  display:flex; align-items:center;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid rgba(141,116,205,.14);
}
.nav .container{ display:flex; align-items:center; justify-content:center; }
.brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-size:1.55rem; font-weight:600; color:var(--lav-700); }
.brand .amp{ color:var(--peri); font-style:italic; }
.brand-dot{ width:9px; height:9px; border-radius:50%; background:var(--grad); box-shadow:0 0 0 4px rgba(141,116,205,.16); }
@media (max-width:680px){
  .brand{ font-size:1.4rem; }
}

/* =========================================================
   Hero / Karşılama
   ========================================================= */
.hero{
  min-height: calc(100vh - var(--nav-h));
  display:flex; align-items:center; justify-content:center;
  padding:40px 16px 60px;
}
.hero-card{
  position:relative;
  width:100%; max-width:680px; min-width:0;
  background:url("../img/bg-frame.png") center/cover no-repeat, #fff;
  border-radius:28px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
  isolation:isolate;
}
.hero-card::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse at center, rgba(255,255,255,.72) 30%, rgba(255,255,255,.4) 70%, rgba(255,255,255,.15));
  z-index:-1;
}
.hero-inner{ padding:clamp(34px,7vw,70px) clamp(26px,6vw,64px); text-align:center; }
.hero-eyebrow{
  text-transform:uppercase; letter-spacing:4px; font-size:.74rem; font-weight:600;
  color:var(--lav-600); margin-bottom:14px;
}
.hero-names{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,9vw,4.6rem);
  font-weight:600; color:var(--ink); line-height:1.04; margin:0;
  overflow-wrap:break-word; word-break:break-word;
}
.hero-names .amp{ color:var(--peri); font-style:italic; display:inline-block; margin:0 .12em; }
.hero-sub{
  font-family:var(--font-display); font-style:italic;
  font-size:clamp(1.2rem,4.4vw,1.7rem); color:var(--lav-600); margin:.5rem 0 0;
}
.hero-divider{ width:70px; height:2px; margin:22px auto; background:linear-gradient(90deg,transparent,var(--lav-400),transparent); }
.hero-msg{ color:var(--ink-soft); font-size:1.02rem; max-width:46ch; margin:0 auto 8px; }
.hero-date{
  display:inline-flex; align-items:center; gap:.5rem;
  margin-top:18px; padding:.5rem 1.1rem; border-radius:100px;
  background:rgba(255,255,255,.7); box-shadow:inset 0 0 0 1.5px var(--lav-200);
  font-size:.95rem; color:var(--lav-700); font-weight:500;
}
.hero-date svg{ width:1.05em; height:1.05em; }
.hero-actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:26px; }

/* =========================================================
   Geri sayım
   ========================================================= */
.countdown-wrap{ margin-top:30px; }
.countdown-label{ font-size:.8rem; letter-spacing:2px; text-transform:uppercase; color:var(--lav-600); margin-bottom:12px; font-weight:600; }
.countdown{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; max-width:380px; margin:0 auto; }
.cd-box{
  min-width:0; padding:14px 6px;
  background:rgba(255,255,255,.82);
  border-radius:16px; box-shadow:var(--shadow-sm), inset 0 0 0 1px rgba(141,116,205,.14);
}
.cd-num{ font-family:var(--font-display); font-size:clamp(1.7rem,7vw,2.4rem); font-weight:600; color:var(--lav-700); line-height:1; }
.cd-unit{ font-size:.66rem; text-transform:uppercase; letter-spacing:1px; color:var(--ink-soft); margin-top:6px; }
.countdown-done{
  margin-top:22px; padding:14px 20px; border-radius:16px;
  background:var(--grad-soft); color:#fff; font-weight:500;
  box-shadow:var(--shadow-md);
}

/* =========================================================
   Bölüm başlıkları
   ========================================================= */
.section{ padding:54px 0; }
.section-head{ text-align:center; max-width:640px; margin:0 auto 34px; }
.section-eyebrow{ text-transform:uppercase; letter-spacing:3px; font-size:.72rem; font-weight:600; color:var(--lav-500); }
.section-title{ font-size:clamp(2rem,6vw,3rem); color:var(--ink); margin:.3rem 0 .5rem; }
.section-desc{ color:var(--ink-soft); }

/* İstatistik şeridi */
.stat-strip{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin:26px 0; }
.stat{
  background:rgba(255,255,255,.75); backdrop-filter:blur(6px);
  border-radius:var(--radius-sm); padding:16px 26px; text-align:center;
  box-shadow:var(--shadow-sm), inset 0 0 0 1px rgba(141,116,205,.1);
  min-width:120px;
}
.stat b{ display:block; font-family:var(--font-display); font-size:2rem; color:var(--lav-700); line-height:1; }
.stat span{ font-size:.82rem; color:var(--ink-soft); text-transform:uppercase; letter-spacing:1px; }

/* =========================================================
   Galeri araç çubuğu
   ========================================================= */
.gallery-bar{ display:flex; gap:12px; align-items:center; justify-content:center; flex-wrap:wrap; margin-bottom:28px; }
.chips{ display:inline-flex; gap:6px; background:rgba(255,255,255,.7); padding:5px; border-radius:100px; box-shadow:inset 0 0 0 1px rgba(141,116,205,.14); }
.chip{ border:none; background:transparent; padding:.55em 1.1em; border-radius:100px; font-weight:500; color:var(--ink-soft); font-size:.9rem; transition:.16s; }
.chip.active{ background:var(--grad); color:#fff; box-shadow:0 4px 14px rgba(125,90,205,.3); }

/* =========================================================
   Masonry galeri (Pinterest)
   ========================================================= */
.masonry{
  column-count:4; column-gap:16px;
}
@media (max-width:1100px){ .masonry{ column-count:3; } }
@media (max-width:720px){  .masonry{ column-count:2; column-gap:12px; } }
@media (max-width:400px){  .masonry{ column-count:1; } }

.card{
  break-inside:avoid;
  margin-bottom:16px;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--paper);
  box-shadow:var(--shadow-sm);
  position:relative;
  transition:transform .22s ease, box-shadow .22s ease;
  opacity:0; transform:translateY(14px);
  animation:cardIn .5s ease forwards;
}
@keyframes cardIn{ to{ opacity:1; transform:none; } }
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.card-media{ position:relative; display:block; overflow:hidden; background:linear-gradient(135deg,var(--lav-100),var(--lav-50)); cursor:zoom-in; }
/* Blur-up: küçük resim yüklenene kadar hafif bulanık, yüklenince yumuşakça netleşir */
.card-media img{
  width:100%; height:auto; display:block;
  filter:blur(14px); transform:scale(1.06); opacity:.55;
  transition:filter .7s ease, transform .7s ease, opacity .7s ease;
}
.card-media img.loaded{ filter:blur(0); transform:none; opacity:1; }
.card-media .ph{ width:100%; background:linear-gradient(135deg,var(--lav-100),var(--lav-50)); }

.play-badge{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none;
}
.play-badge span{
  width:56px; height:56px; border-radius:50%;
  background:rgba(255,255,255,.85); backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md);
}
.play-badge svg{ width:24px; height:24px; color:var(--lav-700); margin-left:3px; }
.type-tag{
  position:absolute; top:10px; left:10px;
  background:rgba(58,47,86,.62); color:#fff; backdrop-filter:blur(4px);
  font-size:.7rem; font-weight:600; letter-spacing:.5px; text-transform:uppercase;
  padding:.25em .7em; border-radius:100px;
  display:flex; align-items:center; gap:.35em;
}
.type-tag svg{ width:.95em; height:.95em; }

.card-body{ padding:12px 14px 14px; }
.card-cap{ font-size:.94rem; color:var(--ink); margin:0 0 4px; word-break:break-word; }
.card-meta{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.uploader{ font-size:.82rem; color:var(--ink-soft); display:flex; align-items:center; gap:.4em; min-width:0; }
.uploader b{ font-weight:600; color:var(--lav-700); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.card-actions{ display:flex; align-items:center; gap:4px; }

/* Beğeni (kalp) */
.like-btn{
  display:inline-flex; align-items:center; gap:.35em;
  background:none; border:none; padding:.35em .55em; border-radius:100px;
  color:var(--ink-soft); font-weight:600; font-size:.9rem;
  transition:.16s;
}
.like-btn svg{ width:20px; height:20px; transition:transform .2s ease; }
.like-btn .heart-fill{ display:none; color:var(--rose); }
.like-btn.liked{ color:var(--rose-deep); }
.like-btn.liked .heart-fill{ display:block; }
.like-btn.liked .heart-out{ display:none; }
.like-btn:hover{ background:var(--lav-50); }
.like-btn.pop svg{ animation:heartPop .42s ease; }
@keyframes heartPop{ 0%{transform:scale(1);} 35%{transform:scale(1.4);} 60%{transform:scale(.9);} 100%{transform:scale(1);} }

.icon-btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:50%;
  background:none; border:none; color:var(--ink-soft); transition:.16s;
}
.icon-btn svg{ width:19px; height:19px; }
.icon-btn:hover{ background:var(--lav-50); color:var(--lav-700); }

/* Boş galeri durumu */
.empty{
  text-align:center; padding:70px 20px; max-width:460px; margin:0 auto;
}
.empty .em-ico{ width:84px; height:84px; margin:0 auto 20px; color:var(--lav-300); }
.empty h3{ font-size:1.8rem; color:var(--ink); margin:0 0 8px; }
.empty p{ color:var(--ink-soft); margin:0 0 22px; }

/* Sonsuz kaydırma yükleniyor */
.loader{ text-align:center; padding:30px; }
.spinner{
  width:38px; height:38px; margin:0 auto; border-radius:50%;
  border:3px solid var(--lav-200); border-top-color:var(--lav-500);
  animation:spin .8s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* =========================================================
   Lightbox
   ========================================================= */
.lightbox{
  position:fixed; inset:0; z-index:120;
  background:rgba(40,30,64,.85); backdrop-filter:blur(10px);
  display:none; align-items:center; justify-content:center;
  padding:20px;
}
.lightbox.open{ display:flex; animation:fade .25s ease; }
@keyframes fade{ from{ opacity:0; } to{ opacity:1; } }
.lb-stage{ position:relative; max-width:min(1100px,96vw); max-height:92vh; display:flex; flex-direction:column; }
.lb-media{ max-width:100%; max-height:78vh; margin:0 auto; border-radius:16px; box-shadow:var(--shadow-lg); background:#000; }
.lb-media img,.lb-media video{ max-width:100%; max-height:78vh; border-radius:16px; display:block; }
.lb-bar{
  margin-top:14px; display:flex; align-items:center; justify-content:space-between; gap:14px;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  border-radius:100px; padding:10px 18px; color:#fff;
}
.lb-info{ min-width:0; }
.lb-info .cap{ font-size:.98rem; }
.lb-info .by{ font-size:.82rem; opacity:.8; }
.lb-actions{ display:flex; gap:8px; }
.lb-actions .like-btn{ color:#fff; }
.lb-actions .icon-btn{ color:#fff; }
.lb-actions .icon-btn:hover{ background:rgba(255,255,255,.18); color:#fff; }
.lb-close,.lb-nav{
  position:absolute; z-index:5;
  width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.16); backdrop-filter:blur(6px);
  border:none; color:#fff; display:flex; align-items:center; justify-content:center;
  transition:.16s;
}
.lb-close:hover,.lb-nav:hover{ background:rgba(255,255,255,.3); }
.lb-close{ top:-6px; right:-6px; }
.lb-close svg,.lb-nav svg{ width:22px; height:22px; }
.lb-nav{ top:50%; transform:translateY(-50%); }
.lb-prev{ left:-64px; }
.lb-next{ right:-64px; }
@media (max-width:820px){
  .lb-prev{ left:6px; } .lb-next{ right:6px; }
  .lb-close{ top:6px; right:6px; }
}

/* =========================================================
   Toast / bildirim
   ========================================================= */
.toasts{ position:fixed; bottom:20px; left:50%; transform:translateX(-50%); z-index:200; display:flex; flex-direction:column; gap:10px; width:min(92vw,420px); }
.toast{
  background:rgba(58,47,86,.96); color:#fff; padding:14px 18px; border-radius:14px;
  box-shadow:var(--shadow-lg); display:flex; align-items:center; gap:12px;
  animation:toastIn .3s ease; font-size:.95rem;
}
.toast.ok{ background:linear-gradient(135deg,#5b8f6f,#4f9d8a); }
.toast.err{ background:linear-gradient(135deg,#b05470,#c9436b); }
.toast svg{ width:20px; height:20px; flex:none; }
@keyframes toastIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }

/* =========================================================
   Alt bilgi
   ========================================================= */
.footer{
  text-align:center; padding:40px 20px 54px; margin-top:30px;
  color:var(--ink-soft); font-size:.9rem;
  border-top:1px solid rgba(141,116,205,.14);
}
.footer .heart{ color:var(--rose); }
.footer .heart svg{ width:1em; height:1em; vertical-align:-2px; }
.footer-nav{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:.4rem 0; margin-bottom:22px; }
.footer-nav a{ padding:.35rem .95rem; font-size:.95rem; font-weight:500; color:var(--ink-soft); border-radius:100px; transition:.16s; }
.footer-nav a:hover{ color:var(--lav-700); background:var(--lav-50); }
.footer-nav a.on{ color:var(--lav-700); }
.footer-nav .dot{ width:4px; height:4px; border-radius:50%; background:var(--lav-300); }
@media (max-width:420px){ .footer-nav .dot{ display:none; } .footer-nav{ gap:.2rem .6rem; } }
.footer .names{ font-family:var(--font-display); font-style:italic; color:var(--lav-600); font-size:1.05rem; }

/* Kilit / geri sayım bilgi kutusu */
.locked-note{
  max-width:520px; margin:0 auto; text-align:center;
  background:rgba(255,255,255,.72); border-radius:var(--radius);
  padding:32px 28px; box-shadow:var(--shadow-sm), inset 0 0 0 1px rgba(141,116,205,.14);
}
.locked-note .lock-ico{ width:54px; height:54px; margin:0 auto 14px; color:var(--lav-400); }
.locked-note h3{ font-size:1.7rem; margin:0 0 8px; color:var(--ink); }
.locked-note p{ color:var(--ink-soft); margin:0 0 6px; }

.fade-up{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.fade-up.in{ opacity:1; transform:none; }

/* =========================================================
   Yükleme sayfası
   ========================================================= */
.upload-fields{ margin-bottom:18px; }
.fld{ display:block; }
.fld > span{ display:block; font-size:.9rem; font-weight:500; color:var(--lav-700); margin-bottom:6px; }
.fld > span em{ color:var(--ink-soft); font-style:normal; font-weight:400; }
.fld input, .fld textarea, .in{
  width:100%; padding:.85em 1.1em;
  border:1.5px solid var(--lav-200); border-radius:14px;
  background:rgba(255,255,255,.8); font-family:inherit; font-size:1rem; color:var(--ink);
  transition:.16s; resize:vertical;
}
.fld input:focus, .fld textarea:focus, .in:focus{ outline:none; border-color:var(--lav-400); box-shadow:0 0 0 4px rgba(141,116,205,.14); }

.dropzone{
  display:block; text-align:center; cursor:pointer;
  border:2.5px dashed var(--lav-300); border-radius:24px;
  padding:48px 24px; background:rgba(255,255,255,.55);
  transition:.2s; margin-bottom:16px;
}
.dropzone:hover, .dropzone.drag{ border-color:var(--lav-500); background:var(--lav-50); transform:translateY(-2px); }
.dz-ico{ width:64px; height:64px; margin:0 auto 16px; border-radius:50%; background:var(--grad-soft); color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md); }
.dz-ico svg{ width:30px; height:30px; }
.dz-title{ font-family:var(--font-display); font-size:1.6rem; color:var(--ink); }
.dz-sub{ color:var(--ink-soft); margin-top:4px; }
.dz-sub b{ color:var(--lav-600); }
.dz-hint{ font-size:.82rem; color:var(--ink-soft); margin-top:10px; opacity:.85; }

.mod-note{ display:flex; align-items:center; gap:.5em; justify-content:center; font-size:.9rem; color:var(--lav-700); background:var(--lav-50); border-radius:12px; padding:10px 16px; margin-bottom:16px; }
.mod-note svg{ width:1.1em; height:1.1em; }

.upload-queue{ display:flex; flex-direction:column; gap:12px; }
.qitem{
  display:flex; gap:14px; align-items:center;
  background:var(--paper); border-radius:16px; padding:12px;
  box-shadow:var(--shadow-sm); animation:cardIn .35s ease;
}
.qthumb{ width:60px; height:60px; border-radius:12px; overflow:hidden; flex:none; background:var(--lav-50); display:flex; align-items:center; justify-content:center; color:var(--lav-400); }
.qthumb img{ width:100%; height:100%; object-fit:cover; }
.qthumb svg{ width:28px; height:28px; }
.qinfo{ flex:1; min-width:0; }
.qname{ font-size:.92rem; font-weight:500; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.qsize{ font-size:.78rem; color:var(--ink-soft); }
.qbar{ height:7px; border-radius:100px; background:var(--lav-100); overflow:hidden; margin-top:8px; }
.qbar > i{ display:block; height:100%; width:0; background:var(--grad); border-radius:100px; transition:width .2s ease; }
.qstat{ font-size:.76rem; margin-top:5px; color:var(--ink-soft); display:flex; align-items:center; gap:.4em; }
.qstat.ok{ color:#4f9d8a; font-weight:600; }
.qstat.err{ color:var(--rose-deep); font-weight:600; }
.qstat svg{ width:1em; height:1em; }
.qdel{ background:none; border:none; color:var(--ink-soft); padding:8px; border-radius:50%; flex:none; }
.qdel:hover{ background:var(--lav-50); color:var(--rose-deep); }
.qdel svg{ width:18px; height:18px; }

.queue-actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:22px; }

.upload-done{ text-align:center; padding:36px 20px; }
.done-ico{ width:76px; height:76px; margin:0 auto 16px; border-radius:50%; background:linear-gradient(135deg,#5b8f6f,#4f9d8a); color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md); }
.done-ico svg{ width:38px; height:38px; }
.upload-done h3{ font-size:1.9rem; color:var(--ink); margin:0 0 6px; }
.upload-done p{ color:var(--ink-soft); margin:0; }

/* =========================================================
   Anı defteri (guestbook)
   ========================================================= */
.gb-form{
  background:rgba(255,255,255,.7); border-radius:var(--radius); padding:24px;
  box-shadow:var(--shadow-sm), inset 0 0 0 1px rgba(141,116,205,.12); margin-bottom:36px;
}
.gb-form .row{ display:flex; flex-direction:column; gap:14px; }
.gb-list{ column-count:3; column-gap:18px; }
@media (max-width:900px){ .gb-list{ column-count:2; } }
@media (max-width:560px){ .gb-list{ column-count:1; } }
.gb-note{
  break-inside:avoid; margin-bottom:18px;
  background:var(--paper); border-radius:var(--radius); padding:20px 22px;
  box-shadow:var(--shadow-sm); position:relative;
  border-left:3px solid var(--lav-300);
  animation:cardIn .4s ease;
}
.gb-msg{ font-family:var(--font-display); font-size:1.18rem; font-style:italic; color:var(--ink); line-height:1.4; }
.gb-by{ margin-top:12px; font-size:.86rem; color:var(--lav-600); font-weight:600; display:flex; align-items:center; justify-content:space-between; }
.gb-by span{ color:var(--ink-soft); font-weight:400; }
