/* ════════════════════════════════════════
   不倫ちゃんねる — Main CSS
   ════════════════════════════════════════ */

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 2px; }

/* ── Theme Variables ── */
[data-theme="dark"] {
  --bg:         #0a0608;
  --bg2:        #100c0e;
  --bg3:        rgba(255,255,255,.025);
  --border:     rgba(180,60,80,.18);
  --border-h:   rgba(180,60,80,.4);
  --text:       #e8ddd5;
  --text2:      #9a7878;
  --text3:      #7a6060;
  --text4:      #5a3848;
  --accent:     #c8506e;
  --accent2:    #f0b8c8;
  --accent-bg:  rgba(180,60,80,.12);
  --header-bg:  rgba(10,6,8,.92);
  --card-hover: rgba(180,60,80,.07);
  --shadow:     rgba(0,0,0,.6);
  --modal-bg:   #130d10;
  --input-bg:   rgba(255,255,255,.04);
  --chat-me:    rgba(180,60,80,.25);
  --chat-other: rgba(255,255,255,.04);
}
[data-theme="light"] {
  --bg:         #fdf5f7;
  --bg2:        #f5eaed;
  --bg3:        rgba(180,60,80,.04);
  --border:     rgba(180,60,80,.2);
  --border-h:   rgba(180,60,80,.5);
  --text:       #2a1520;
  --text2:      #7a4555;
  --text3:      #9a6070;
  --text4:      #c8a0b0;
  --accent:     #c8506e;
  --accent2:    #8a2535;
  --accent-bg:  rgba(180,60,80,.08);
  --header-bg:  rgba(253,245,247,.94);
  --card-hover: rgba(180,60,80,.05);
  --shadow:     rgba(180,60,80,.12);
  --modal-bg:   #fff0f3;
  --input-bg:   rgba(180,60,80,.05);
  --chat-me:    rgba(200,80,110,.15);
  --chat-other: rgba(180,60,80,.05);
}

/* ── Animations ── */
@keyframes float {
  0%,100% { transform:translateY(0) translateX(0); opacity:.3; }
  33%      { transform:translateY(-20px) translateX(8px); opacity:.6; }
  66%      { transform:translateY(-10px) translateX(-5px); opacity:.4; }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes shimmer {
  0%   { background-position:-200% center; }
  100% { background-position:200% center; }
}
@keyframes modalIn {
  from { opacity:0; transform:scale(.96) translateY(10px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
@keyframes pulseDot {
  0%,100% { transform:scale(1); opacity:1; }
  50%     { transform:scale(1.5); opacity:.6; }
}
@keyframes slideDown {
  from { opacity:0; transform:translateY(-10px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── Base ── */
body {
  min-height:100vh;
  background:var(--bg);
  font-family:'Noto Serif JP','Georgia',serif;
  color:var(--text);
  overflow-x:hidden;
  transition:background .4s, color .4s;
}
a { color:inherit; text-decoration:none; }

/* ── Particles ── */
.particle {
  position:fixed; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle,rgba(200,80,100,.7),rgba(180,60,80,0));
  animation:float var(--dur) var(--delay) ease-in-out infinite;
  z-index:0;
}
.vignette {
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(100,20,35,.2) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(80,15,30,.15) 0%, transparent 50%);
  transition:background .4s;
}

/* ── Header ── */
header {
  border-bottom:1px solid var(--border);
  padding:0 32px;
  display:flex; align-items:center; justify-content:space-between;
  height:64px; position:sticky; top:0; z-index:200;
  background:var(--header-bg); backdrop-filter:blur(14px);
  transition:background .4s, border-color .4s;
  animation:fadeUp .6s ease both;
}
.logo-wrap { display:flex; align-items:baseline; gap:8px; }
.logo-sub  { font-size:8px; letter-spacing:.3em; color:var(--accent); text-transform:uppercase; }
.logo-text {
  font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:300; letter-spacing:.06em;
  background:linear-gradient(90deg,#c8506e,#f0b8c8,#c8506e,#e88ea8);
  background-size:300% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; animation:shimmer 4s linear infinite;
}
.header-nav { display:flex; gap:20px; align-items:center; }
.header-nav a {
  color:var(--text2); font-size:12px; letter-spacing:.1em; transition:color .2s;
}
.header-nav a:hover { color:var(--accent); }
.header-nav a.cta {
  color:var(--accent2); border:1px solid var(--border);
  padding:5px 14px; border-radius:1px; transition:all .2s;
}
.header-nav a.cta:hover { background:var(--accent-bg); border-color:var(--accent); }
.theme-toggle {
  background:var(--bg3); border:1px solid var(--border); color:var(--text2);
  width:36px; height:36px; border-radius:50%; cursor:pointer; font-size:16px;
  display:flex; align-items:center; justify-content:center; transition:all .3s;
}
.theme-toggle:hover { border-color:var(--accent); color:var(--accent); transform:rotate(20deg); }
.hamburger {
  display:none; background:transparent; border:1px solid var(--border);
  color:var(--text2); padding:6px 10px; cursor:pointer; border-radius:1px;
  font-size:16px; transition:all .2s;
}

/* ── Mobile Menu ── */
.mobile-menu {
  display:none; flex-direction:column;
  background:var(--modal-bg); border-bottom:1px solid var(--border);
  position:sticky; top:64px; z-index:190;
}
.mobile-menu.open { display:flex; animation:slideDown .2s ease; }
.mobile-menu a {
  padding:14px 24px; font-size:13px; color:var(--text2); border-bottom:1px solid var(--border);
  letter-spacing:.06em; transition:background .2s;
}
.mobile-menu a:hover { background:var(--accent-bg); color:var(--accent); }

/* ── Flash Messages ── */
.flash {
  padding:12px 24px; font-size:13px; letter-spacing:.06em; text-align:center;
  position:sticky; top:64px; z-index:180;
  animation:slideDown .3s ease;
}
.flash-success { background:rgba(50,150,80,.15); color:#7adfaa; border-bottom:1px solid rgba(50,150,80,.3); }
.flash-error   { background:rgba(180,60,80,.15); color:var(--accent); border-bottom:1px solid var(--border); }

/* ── Tab Nav ── */
.tab-nav {
  display:flex; border-bottom:1px solid var(--border);
  background:var(--bg2); position:sticky; top:64px; z-index:100;
  overflow-x:auto; transition:background .4s;
}
.tab-btn {
  background:transparent; border:none; color:var(--text2);
  padding:12px 20px; font-family:'Noto Serif JP',serif; font-size:12px;
  letter-spacing:.1em; cursor:pointer; border-bottom:2px solid transparent;
  transition:all .2s; white-space:nowrap; text-decoration:none; display:block;
}
.tab-btn:hover  { color:var(--accent); }
.tab-btn.active { color:var(--accent); border-bottom-color:var(--accent); background:var(--accent-bg); }

/* ── Layout ── */
.layout {
  display:flex; max-width:1100px; margin:0 auto; padding:28px 20px; gap:24px;
  position:relative; z-index:1;
}
.main-col { flex:1; min-width:0; }
.side-col  { width:260px; flex-shrink:0; }

/* ── Hero ── */
.hero { text-align:center; padding:36px 0 28px; animation:fadeUp .6s .1s ease both; }
.hero-eye { font-size:10px; letter-spacing:.4em; color:var(--text4); text-transform:uppercase; margin-bottom:14px; }
.hero h2 { font-family:'Cormorant Garamond',serif; font-size:36px; font-weight:300; line-height:1.6; margin-bottom:10px; }
.hero h2 em { font-style:italic; color:var(--accent); }
.hero-sub { color:var(--text3); font-size:12px; letter-spacing:.08em; }
.hero-stats {
  display:flex; justify-content:center; gap:32px; margin-top:24px; padding:18px 0;
  border-top:1px solid rgba(180,60,80,.12); border-bottom:1px solid rgba(180,60,80,.12);
}
.h-stat-n { font-family:'Cormorant Garamond',serif; font-style:italic; color:var(--accent); font-size:26px; }
.h-stat-l { font-size:10px; color:var(--text3); letter-spacing:.12em; margin-top:3px; }

/* ── Filter Bar ── */
.filter-bar { margin-bottom:12px; animation:fadeUp .6s .15s ease both; }
.filter-form { display:flex; gap:8px; align-items:center; }
.pref-select {
  background:var(--input-bg); border:1px solid var(--border); color:var(--text);
  padding:6px 28px 6px 12px; font-family:'Noto Serif JP',serif; font-size:12px;
  letter-spacing:.06em; border-radius:1px; outline:none; transition:border-color .2s;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23c8506e'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center; background-color:var(--input-bg);
}
.pref-select:focus { border-color:var(--accent); }

/* ── Controls ── */
.controls {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:16px; flex-wrap:wrap; gap:10px;
  animation:fadeUp .6s .2s ease both;
}
.tags { display:flex; gap:6px; flex-wrap:wrap; }
.tag-btn {
  background:transparent; border:1px solid var(--border); color:var(--text2);
  padding:5px 13px; border-radius:1px; cursor:pointer;
  font-family:'Noto Serif JP',serif; font-size:12px; letter-spacing:.06em; transition:all .2s;
  display:inline-block;
}
.tag-btn:hover, .tag-btn.active { background:var(--accent-bg); border-color:var(--accent); color:var(--accent2); }

/* ── Buttons ── */
.post-btn {
  background:linear-gradient(135deg,#8a2535,#c8506e); border:none;
  color:#fff0f3; padding:9px 20px; font-family:'Noto Serif JP',serif;
  font-size:12px; letter-spacing:.1em; cursor:pointer; border-radius:1px;
  transition:all .3s; white-space:nowrap; position:relative; overflow:hidden;
}
.post-btn::after {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transition:left .4s;
}
.post-btn:hover::after { left:100%; }
.post-btn:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(180,60,80,.4); }
.post-btn-photo { background:linear-gradient(135deg,#1a4a80,#3a80d0); }
.post-btn-video { background:linear-gradient(135deg,#1a5030,#3aaa70); }

hr.div {
  border:none; height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  margin:0 0 16px; opacity:.3;
}

/* ── Post Cards ── */
.posts { display:flex; flex-direction:column; gap:10px; }
.post-card {
  background:var(--bg3); border:1px solid var(--border); border-radius:2px;
  padding:18px 22px; cursor:pointer; transition:all .3s; position:relative; overflow:hidden;
  animation:fadeUp .5s ease both; display:block;
}
.post-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(180deg,#c8506e,transparent);
  transform:scaleY(0); transform-origin:top; transition:transform .3s;
}
.post-card:hover { background:var(--card-hover); border-color:var(--border-h); transform:translateX(3px); }
.post-card:hover::before { transform:scaleY(1); }
.post-card.pinned { border-color:rgba(200,160,80,.3); }
.pin-icon { position:absolute; top:10px; right:14px; font-size:11px; opacity:.5; }
.post-inner { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.post-body  { flex:1; }
.post-meta  { display:flex; align-items:center; gap:7px; margin-bottom:7px; flex-wrap:wrap; }
.p-tag  { font-size:10px; letter-spacing:.1em; color:var(--accent); border:1px solid rgba(200,80,110,.3); padding:2px 7px; border-radius:1px; }
.p-pref { font-size:10px; color:var(--text3); background:var(--bg3); border:1px solid var(--border); padding:2px 7px; border-radius:1px; }
.p-time { font-size:10px; color:var(--text4); }
.p-new  { font-size:9px; background:#c8506e; color:#fff; padding:2px 6px; border-radius:1px; letter-spacing:.1em; }
.media-badge { font-size:12px; }
.post-title   { font-size:15px; font-weight:400; color:var(--text); margin-bottom:5px; letter-spacing:.04em; }
.post-excerpt { font-size:12px; color:var(--text3); line-height:1.75; letter-spacing:.02em; }
.post-stats   { text-align:right; flex-shrink:0; padding-top:2px; }
.p-stat       { font-size:10px; color:var(--text4); margin-bottom:3px; }
.p-stat span  { color:var(--text3); }

/* Ranking number */
.rank-num-large {
  font-family:'Cormorant Garamond',serif; font-style:italic; font-size:40px;
  color:var(--accent); opacity:.4; width:50px; flex-shrink:0; line-height:1;
}
.rank-num-large.top { color:#c8a020; opacity:1; }

/* ── Empty State ── */
.empty-state {
  text-align:center; padding:48px; color:var(--text3);
  font-size:13px; letter-spacing:.08em;
}

/* ── Pager ── */
.pager { display:flex; justify-content:center; gap:6px; margin-top:28px; padding:12px 0; }
.pager a, .pager span {
  padding:6px 12px; border:1px solid var(--border); border-radius:1px;
  font-size:12px; color:var(--text2); transition:all .2s;
}
.pager a:hover      { border-color:var(--accent); color:var(--accent); }
.pager span.current { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ── Post Detail ── */
.breadcrumb { font-size:11px; color:var(--text4); letter-spacing:.08em; margin-bottom:20px; padding:16px 0 0; }
.breadcrumb a { color:var(--accent); }
.post-detail { background:var(--bg3); border:1px solid var(--border); border-radius:2px; padding:28px; margin-bottom:24px; animation:fadeUp .5s ease both; }
.post-detail-meta { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:14px; }
.anon-name { font-size:11px; color:var(--text4); letter-spacing:.08em; }
.post-detail-title { font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:300; line-height:1.5; margin-bottom:20px; color:var(--text); }
.post-media-full { margin-bottom:20px; border-radius:2px; overflow:hidden; }
.post-media-full img, .post-media-full video { width:100%; max-height:480px; object-fit:contain; background:#000; display:block; }
.post-detail-body { font-size:14px; line-height:2; color:var(--text2); letter-spacing:.04em; }
.post-detail-actions { display:flex; align-items:center; gap:16px; margin-top:24px; padding-top:16px; border-top:1px solid var(--border); }
.like-btn {
  background:var(--accent-bg); border:1px solid var(--border); color:var(--accent);
  padding:8px 20px; border-radius:1px; cursor:pointer; font-size:13px; letter-spacing:.08em;
  transition:all .2s; font-family:'Noto Serif JP',serif;
}
.like-btn:hover, .like-btn.liked { background:var(--accent); color:#fff; border-color:var(--accent); }
.view-count { font-size:12px; color:var(--text4); }
.delete-btn { font-size:12px; color:var(--text4); margin-left:auto; transition:color .2s; }
.delete-btn:hover { color:#c8506e; }

/* ── Replies ── */
.section-title {
  font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:300;
  color:var(--text); letter-spacing:.06em; margin:24px 0 16px;
  padding-bottom:8px; border-bottom:1px solid var(--border);
}
.reply-card {
  background:var(--bg3); border:1px solid var(--border); border-radius:2px;
  padding:14px 18px; margin-bottom:8px; animation:fadeUp .4s ease both;
}
.reply-meta { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.reply-num  { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:20px; color:var(--accent); opacity:.5; }
.reply-body { font-size:13px; line-height:1.8; color:var(--text2); }
.reply-form-wrap { margin-top:28px; background:var(--bg3); border:1px solid var(--border); border-radius:2px; padding:20px; }

/* ── Forms ── */
.form-group  { margin-bottom:16px; }
.form-label  { font-size:11px; color:var(--text3); letter-spacing:.12em; display:block; margin-bottom:6px; }
.form-input, .form-select, .form-textarea {
  width:100%; background:var(--input-bg); border:1px solid var(--border);
  color:var(--text); padding:10px 14px; font-family:'Noto Serif JP',serif;
  font-size:13px; border-radius:1px; outline:none; transition:border-color .2s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--accent); }
.form-textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* ── Sidebar ── */
.side-widget { background:var(--bg3); border:1px solid var(--border); border-radius:2px; margin-bottom:16px; overflow:hidden; animation:fadeUp .5s ease both; transition:background .4s; }
.widget-title { padding:10px 16px; font-size:10px; letter-spacing:.2em; color:var(--accent); border-bottom:1px solid var(--border); background:var(--accent-bg); text-transform:uppercase; }
.widget-body { padding:12px 16px; }

/* ── Online dot ── */
.online-dot {
  display:inline-block; width:7px; height:7px; border-radius:50%;
  background:#4caf79; margin-right:6px; vertical-align:middle;
  animation:pulseDot 1.5s infinite;
}

/* ── Modal ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.72); z-index:300;
  display:none; align-items:center; justify-content:center; backdrop-filter:blur(4px);
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--modal-bg); border:1px solid var(--border); border-radius:3px;
  width:min(560px,94vw); padding:28px; animation:modalIn .3s ease;
  box-shadow:0 20px 60px var(--shadow); max-height:92vh; overflow-y:auto;
}
.modal-title { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; color:var(--text); margin-bottom:20px; }
.mtab {
  background:transparent; border:none; color:var(--text3);
  padding:12px 18px; font-family:'Noto Serif JP',serif; font-size:12px;
  letter-spacing:.08em; cursor:pointer; border-bottom:2px solid transparent;
  transition:all .2s; flex:1;
}
.mtab:hover  { color:var(--accent); }
.mtab.active { color:var(--accent); border-bottom-color:var(--accent); background:var(--accent-bg); }
.modal-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:20px; }
.btn-cancel {
  background:transparent; border:1px solid var(--border); color:var(--text2);
  padding:9px 20px; font-family:'Noto Serif JP',serif; font-size:13px;
  cursor:pointer; border-radius:1px; transition:all .2s; letter-spacing:.06em;
}
.btn-cancel:hover { border-color:var(--accent); color:var(--text); }
.btn-submit {
  background:linear-gradient(135deg,#8a2535,#c8506e); border:none;
  color:#fff0f3; padding:9px 24px; font-family:'Noto Serif JP',serif;
  font-size:13px; cursor:pointer; border-radius:1px; letter-spacing:.08em; transition:opacity .2s;
}
.btn-submit:hover { opacity:.85; }

/* ── Upload ── */
.upload-zone {
  border:2px dashed var(--border); border-radius:3px; padding:28px 20px;
  text-align:center; cursor:pointer; transition:all .25s; background:var(--input-bg);
}
.upload-zone:hover, .upload-zone.drag { border-color:var(--accent); background:var(--accent-bg); }
.upload-icon { font-size:30px; margin-bottom:8px; }
.upload-text { font-size:13px; color:var(--text2); margin-bottom:4px; }
.upload-sub  { font-size:10px; color:var(--text4); }
.preview-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(80px,1fr)); gap:8px; margin-top:10px; }
.preview-item { position:relative; aspect-ratio:1; border-radius:2px; overflow:hidden; border:1px solid var(--border); background:var(--bg3); animation:fadeUp .3s ease both; }
.preview-item img { width:100%; height:100%; object-fit:cover; }
.preview-remove { position:absolute; top:3px; right:3px; background:rgba(0,0,0,.65); color:#fff; border:none; width:18px; height:18px; border-radius:50%; cursor:pointer; font-size:10px; display:flex; align-items:center; justify-content:center; }
.preview-remove:hover { background:#c8506e; }
.video-preview-box { background:var(--bg3); border:1px solid var(--border); border-radius:2px; padding:12px; margin-top:10px; display:flex; gap:12px; align-items:center; animation:fadeUp .3s ease both; }
.video-thumb { width:80px; height:56px; background:#000; border-radius:2px; display:flex; align-items:center; justify-content:center; flex-shrink:0; overflow:hidden; position:relative; }
.video-thumb video { width:100%; height:100%; object-fit:cover; }
.video-thumb .play-icon { position:absolute; color:rgba(255,255,255,.8); font-size:18px; }
.video-info { flex:1; min-width:0; }
.video-name { font-size:12px; color:var(--text2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.video-size { font-size:10px; color:var(--text4); margin-top:3px; }
.video-remove { background:transparent; border:1px solid var(--border); color:var(--text3); padding:4px 10px; border-radius:1px; cursor:pointer; font-size:11px; transition:all .2s; }
.video-remove:hover { border-color:var(--accent); color:var(--accent); }

/* ── Chat ── */
.chat-fullpage {
  background:var(--bg3); border:1px solid var(--border); border-radius:2px;
  display:flex; flex-direction:column; height:60vh; min-height:400px;
}
.chat-messages { flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:10px; }
.chat-msg { display:flex; flex-direction:column; gap:3px; max-width:80%; }
.chat-msg.me    { align-self:flex-end; align-items:flex-end; }
.chat-msg.other { align-self:flex-start; }
.msg-name   { font-size:10px; color:var(--text4); letter-spacing:.08em; }
.msg-bubble { padding:9px 13px; border-radius:2px; font-size:13px; line-height:1.65; color:var(--text); }
.chat-msg.me    .msg-bubble { background:var(--chat-me); border:1px solid rgba(180,60,80,.25); }
.chat-msg.other .msg-bubble { background:var(--chat-other); border:1px solid var(--border); }
.msg-time   { font-size:9px; color:var(--text4); }
.chat-input-row { padding:12px; border-top:1px solid var(--border); display:flex; gap:8px; }
.chat-input {
  flex:1; background:var(--input-bg); border:1px solid var(--border);
  color:var(--text); padding:9px 13px; font-family:'Noto Serif JP',serif;
  font-size:13px; border-radius:1px; outline:none; transition:border-color .2s;
}
.chat-input:focus { border-color:var(--accent); }
.chat-send { background:var(--accent); border:none; color:#fff; padding:9px 18px; border-radius:1px; cursor:pointer; font-family:'Noto Serif JP',serif; font-size:12px; transition:opacity .2s; }
.chat-send:hover { opacity:.8; }

/* ── Auth ── */
.auth-wrap { display:flex; justify-content:center; align-items:center; min-height:calc(100vh - 200px); padding:40px 20px; position:relative; z-index:1; }
.auth-card { background:var(--modal-bg); border:1px solid var(--border); border-radius:3px; width:min(460px,100%); padding:36px; box-shadow:0 20px 60px var(--shadow); animation:fadeUp .5s ease both; }
.auth-logo { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; letter-spacing:.06em; background:linear-gradient(90deg,#c8506e,#f0b8c8,#c8506e); background-size:300% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:shimmer 4s linear infinite; margin-bottom:8px; }
.auth-title { font-size:18px; font-weight:400; color:var(--text); margin-bottom:6px; letter-spacing:.06em; }
.auth-sub   { font-size:11px; color:var(--text3); letter-spacing:.08em; margin-bottom:24px; }
.auth-links { margin-top:20px; text-align:center; font-size:12px; color:var(--text3); }
.auth-links a { color:var(--accent); }

/* ── Footer ── */
footer { position:relative; z-index:1; border-top:1px solid var(--border); background:var(--bg2); margin-top:48px; transition:background .4s, border-color .4s; }
.footer-top { max-width:1100px; margin:0 auto; padding:40px 20px 32px; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; }
.footer-brand { display:flex; flex-direction:column; gap:12px; }
.footer-logo-sub  { font-size:8px; letter-spacing:.3em; color:var(--accent); text-transform:uppercase; margin-bottom:4px; }
.footer-logo-text { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; letter-spacing:.06em; background:linear-gradient(90deg,#c8506e,#f0b8c8,#c8506e); background-size:300% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:shimmer 4s linear infinite; }
.footer-tagline { font-size:11px; color:var(--text3); letter-spacing:.12em; line-height:1.9; }
.footer-company { font-size:11px; color:var(--text4); letter-spacing:.08em; }
.footer-col-title { font-size:10px; letter-spacing:.25em; color:var(--accent); text-transform:uppercase; margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid var(--border); }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:8px; }
.footer-links a { font-size:12px; color:var(--text3); letter-spacing:.06em; transition:color .2s; display:flex; align-items:center; gap:6px; }
.footer-links a::before { content:'›'; color:var(--accent); font-size:14px; }
.footer-links a:hover { color:var(--accent); }
.footer-badges { display:flex; gap:8px; }
.footer-badge { font-size:9px; letter-spacing:.12em; color:var(--text4); border:1px solid var(--border); padding:3px 9px; border-radius:1px; }
.footer-divider { border:none; height:1px; background:linear-gradient(90deg,transparent,var(--accent),transparent); opacity:.2; }
.footer-bottom { max-width:1100px; margin:0 auto; padding:18px 20px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-copy    { font-size:11px; color:var(--text4); letter-spacing:.08em; }
.footer-address { font-size:10px; color:var(--text4); margin-top:4px; letter-spacing:.06em; }
.footer-legal   { display:flex; gap:20px; }
.footer-legal a { font-size:11px; color:var(--text4); letter-spacing:.06em; transition:color .2s; }
.footer-legal a:hover { color:var(--accent); }

/* ── Responsive ── */
@media (max-width: 900px) {
  .layout { flex-direction:column; }
  .side-col { width:100%; }
  .footer-top { grid-template-columns:1fr 1fr; gap:24px; }
  .footer-brand { grid-column:1/-1; }
}
@media (max-width: 640px) {
  header { padding:0 16px; }
  .header-nav a:not(.cta):not(:last-child) { display:none; }
  .hamburger { display:block; }
  .hero h2 { font-size:26px; }
  .hero-stats { gap:20px; }
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .form-row { grid-template-columns:1fr; }
  .controls { flex-direction:column; align-items:flex-start; }
}
