/* assets/css/app.css */
:root{
  --bg:#0f0f10; --card:#1e1e1e; --text:#f5f5f7; --muted:#b3b3b7; --brand:#ff2a6d; --ok:#18c964; --bad:#ff5757;
  --line:#26272b;
}
*{box-sizing:border-box}

html, body {
  min-height: 100vh;
  margin: 0;
  padding: 0;
  background: linear-gradient(180deg, #1b0e29, #5b1f35) fixed no-repeat;
  background-size: cover;            /* fill the viewport */
  color:var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  
}

a{color:#fff;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:720px;margin:70px auto 80px;padding:0 14px}

/* Header */
.m-header{position:fixed;top:0;left:0;right:0;height:56px;background:#111;display:flex;align-items:center;gap:8px;padding:0 10px;border-bottom:1px solid var(--line);z-index:40}
.m-header .brand{font-weight:700;letter-spacing:.3px}
.icon-btn{background:transparent;border:0;color:#fff;cursor:pointer;font-size:18px}
.icon-btn .bar{display:block;width:18px;height:2px;background:#fff;margin:4px 0;border-radius:2px}
.btn{background:var(--brand);border:0;border-radius:10px;color:#fff;padding:10px 14px;font-weight:600}
.btn.small{padding:10px 15px;border-radius:8px;font-size:17px}
.btn.link{background:transparent;text-decoration:underline;padding:6px 2px}
.btn.outline{background:transparent;border:1px solid var(--line)}
.btn.full{width:100%}
.spacer{flex:1}

/* Drawer */
.m-drawer{position:fixed;top:0;left:0;height:100vh;width:82vw;max-width:360px;background:#121214;border-right:1px solid var(--line);transform:translateX(-100%);transition:.25s ease;z-index:60;padding:12px}
.m-drawer.open{transform:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.m-drawer a, .m-drawer span{display:block;padding:12px;border-radius:10px;color:#fff}
.m-drawer a:hover{background:#1b1c1f}
.m-drawer .disabled{opacity:.5}

/* Cards feed */
.feed{display:flex;flex-direction:column;gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.card .photo{aspect-ratio:4/5;overflow:hidden;background:#0b0b0c;}
.card .photo img{width:100%;height:100%;object-fit:cover; object-position: top;}
.card .meta{padding:12px 12px 6px}
.card .title{font-size:20px;font-weight:800;margin:0 0 6px}
.card .sub{color:#fff;font-size:15px; padding:5px 0px 5px 0px;}
.card .actions{display:flex;align-items:center;gap:10px;border-top:1px solid var(--line);padding:8px 10px}
.vote{display:flex;align-items:center;gap:8px}
.vote button{background:var(--brand);border:1px solid var(--line);padding:8px 10px;border-radius:10px;color:#fff;cursor:pointer}
.vote .count{font-weight:700}

/* Modal */
.modal{position:fixed;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.55);z-index:100}
.modal[hidden]{display:none}
.modal-card{width:min(420px,92vw);background:#141416;border:1px solid var(--line);border-radius:16px;padding:16px}
.modal-close{float:right;background:transparent;border:0;color:#fff;font-size:20px}
label{display:block;margin:10px 0 6px;font-size:13px;color:var(--muted)}
input[type="email"],input[type="tel"],input[type="text"],input[type="file"]{width:100%;padding:12px;border-radius:12px;border:1px solid var(--line);background:#121214;color:#fff}
.or{display:flex;align-items:center;gap:8px;margin:8px 0;color:var(--muted);font-size:12px}
.or::before,.or::after{content:"";flex:1;height:1px;background:var(--line)}
.muted{color:var(--muted)} .tiny{font-size:12px}

/* Footer */
.m-footer{position:fixed;left:0;right:0;bottom:0;background:#111;border-top:1px solid var(--line);padding:10px;text-align:center}

/* Avatar circle */
.avatar{width:84px;height:84px;border-radius:999px;overflow:hidden;border:2px solid var(--line);background:#0c0c0d}
.avatar img{width:100%;height:100%;object-fit:cover}

/* GDPR */
.gdpr-banner{position:fixed;left:10px;right:10px;bottom:70px;background:#151515;border:1px solid var(--line);border-radius:12px;padding:12px;z-index:99}
.gdpr-inner{display:flex;gap:10px;align-items:center;justify-content:space-between}
.gdpr-actions{display:flex;gap:8px;flex-wrap:wrap}
@media (max-width:560px){.gdpr-inner{flex-direction:column;align-items:flex-start}}
.logout-form{margin-top:8px}


/* Poll section */
.poll-card { background: var(--card); border:1px solid var(--line); border-radius:14px; padding:14px; margin-bottom:18px; }
.poll-title { margin: 0 0 6px; font-size: 18px; font-weight: 800; }
.poll-desc { margin: 0 0 12px; color: var(--muted); font-size: 14px; }
.poll-grid { display:grid; gap:12px; grid-template-columns: 1fr 1fr; }
@media (min-width:560px){ .poll-grid{ grid-template-columns: 1fr 1fr 1fr; } }

.poll-option {
  display:flex; gap:10px; align-items:center; background:#1b1c1f;
  border:1px solid var(--line); border-radius:12px; padding:8px;
}
.poll-option .thumb { width:56px; height:56px; border-radius:10px; overflow:hidden; background:#0b0b0c; }
.poll-option .thumb img { width:100%; height:100%; object-fit:cover; }
.poll-option .names { font-weight:700; }
.poll-option .sub { color:var(--muted); font-size:12px; }
.poll-option .vote-btn {
  margin-left:auto; display:flex; align-items:center; gap:8px;
  background:#232429; border:1px solid var(--line); border-radius:10px; padding:6px 10px; cursor:pointer;
}
.poll-option.active, .poll-option:hover { outline:1px solid var(--brand); }

/* Hero / marketing */
.hero{
  margin: 14px auto 18px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(17,17,17,.75);
  backdrop-filter: blur(6px);
}
.hero-body{ padding: 16px 14px; }
.hero-title{
  margin: 0 0 6px;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 800;
}
.hero-sub{
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 14px;
}
.hero-chips{
  display:flex; gap:8px; flex-wrap:wrap; margin: 10px 0 12px;
}
.chip{
  display:inline-flex; align-items:center; gap:6px;
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 12px;
  color: #ddd;
  background: #1a1b1f;
}
.hero-cta{ display:flex; gap:10px; flex-wrap:wrap; }
.hero-cta .btn{ padding: 8px 12px; border-radius: 10px; }

@media (min-width: 560px){
  .hero-body{ padding: 18px 16px; }
  .hero-title{ font-size: 24px; }
}

/* Couples poll layout */
.poll-grid.couples{
  display: grid;
  grid-template-columns: 1fr;          /* big single column on phones */
  gap: 20px;
}
@media (min-width: 520px){
  .poll-grid.couples{ grid-template-columns: 1fr 1fr; }   /* 2 cols on small tablets */
}
@media (min-width: 900px){
  .poll-grid.couples{ grid-template-columns: 1fr 1fr 1fr; } /* 3 cols on desktop */
}

/* Make the entire card a big, clickable button */
.poll-option.couple{
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;                 /* controls height relative to width */
  border: 2px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  background: #0b0b0c;
  padding: 0;
  cursor: pointer;
  text-align: left;
}

/* Split collage */
.poll-option.couple .thumb.couple-split{
  display: flex;
  width: 100%;
  height: 100%;
}
.poll-option.couple img{
  width: 50%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: top center;
}

/* Overlays */
.poll-option.couple .names{
  position: absolute;
  left: 10px; right: 10px; bottom: 38px;
  font-weight: 800;
  text-shadow: 0 1px 2px rgba(0,0,0,.55);
  color:#ccc;
}
.poll-option.couple .sub{
  position: absolute;
  right: 10px; bottom: 10px;
  font-size: 18px; opacity: .9;
}

/* Active state */
.poll-option.couple.active{
  outline: 4px solid var(--brand, #ff2a6d);
  outline-offset: 0px;
}
.poll-option.couple:focus-visible{
  outline: 4px solid var(--brand, #ff2a6d);
  outline-offset: 0px;
}

/* Force couples poll to 1 per row, always */
.poll-card.couples .poll-grid.couples{
  display: grid;
  grid-template-columns: 1fr !important; /* override any earlier breakpoints */
  gap: 12px;
}

/* Keep each couple card big and tappable */
.poll-option.couple{
  width: 100%;
  aspect-ratio: 4 / 3;   /* adjust to 4/5 or 16/9 if you want it taller/shorter */
}
