:root{
  --primary:#6D2E59;--primary-dark:#32162A;--accent:#E5B85C;--bg:#FFF7EC;--card:#fff;--text:#261C23;--muted:#7B6D75;--border:#EFDCCD;--success:#417C55;--warning:#B9792C;--danger:#B84A4A;--blue:#2563EB;--shadow:0 18px 44px rgba(50,22,42,.13)
}
*{box-sizing:border-box}
body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,#FFE8BD,#FFF7EC 42%,#F8EDF4);font-family:Inter,system-ui,-apple-system,"Segoe UI",sans-serif;color:var(--text)}
a{color:inherit;text-decoration:none}.app{width:min(460px,100%);margin:0 auto;min-height:100vh;padding:22px 18px 96px}.top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.brand{display:flex;align-items:center;gap:12px}.logo{width:54px;height:54px;border-radius:18px;background:var(--primary);display:grid;place-items:center;color:#fff;font-size:27px;box-shadow:var(--shadow)}.brand h1{font-size:24px;margin:0;color:var(--primary-dark);letter-spacing:-.04em}.brand p{font-size:13px;margin:2px 0 0;color:var(--muted)}h1,h2,h3{color:var(--primary-dark)}.page-title{font-size:31px;letter-spacing:-.05em;margin:14px 0 6px}.page-intro{color:var(--muted);line-height:1.55;margin:0 0 18px}.card{background:rgba(255,255,255,.93);border:1px solid var(--border);border-radius:26px;padding:18px;box-shadow:var(--shadow)}.stack{display:grid;gap:14px}.form{display:grid;gap:12px}label{font-size:13px;font-weight:900;color:var(--primary-dark)}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:15px;padding:13px 14px;font-size:16px;background:#fff;color:var(--text)}textarea{min-height:78px;resize:vertical}.btn{border:0;border-radius:999px;min-height:48px;padding:12px 18px;background:var(--primary);color:white;font-size:15px;font-weight:900;cursor:pointer;box-shadow:0 10px 22px rgba(109,46,89,.22)}.btn.secondary{background:#fff;color:var(--primary);border:1px solid var(--border);box-shadow:none}.btn.danger{background:var(--danger)}.btn.full{width:100%}.link{color:var(--blue);font-weight:900;text-decoration:underline}.back{font-weight:900;color:var(--primary);display:inline-block;margin-bottom:8px}.grid{display:grid;gap:14px}.tile{display:flex;align-items:center;gap:14px;padding:16px;border-radius:21px;background:#fff;border:1px solid var(--border);box-shadow:0 10px 22px rgba(50,22,42,.08)}.tile-icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:#F7E9F2;color:var(--primary);font-size:25px;flex:0 0 auto}.tile h3{margin:0 0 3px;font-size:17px}.tile p{margin:0;color:var(--muted);font-size:13px}.section-title{font-size:20px;margin:22px 0 10px}.empty{background:rgba(255,255,255,.65);border:1px dashed var(--border);border-radius:20px;padding:16px;color:var(--muted)}.status{display:none;margin-top:10px;padding:12px 14px;border-radius:15px;background:#F7E9F2;color:var(--primary-dark)}.status.show{display:block}.gift-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:14px;display:grid;grid-template-columns:82px 1fr;gap:14px}.gift-img{width:82px;height:82px;border-radius:18px;background:#F7E9F2;display:grid;place-items:center;font-size:32px;overflow:hidden}.gift-img img{width:100%;height:100%;object-fit:cover}.gift-card h3{margin:0 0 4px;font-size:16px;line-height:1.25}.small{font-size:13px;color:var(--muted);line-height:1.45}.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:9px}.text-btn{background:transparent;border:0;padding:0;font:inherit;font-weight:900;cursor:pointer;text-decoration:underline;color:var(--primary)}.text-btn.danger{color:var(--danger)}.pills{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}.pill{font-size:12px;font-weight:900;border-radius:999px;padding:5px 9px;background:#F7E9F2;color:var(--primary)}.pill.Available{background:#EAF5ED;color:var(--success)}.pill.Reserved{background:#FFF2D9;color:var(--warning)}.pill.Purchased{background:#F6E2E2;color:var(--danger)}.header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.icon-btn{width:45px;height:45px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--primary);font-size:20px;font-weight:900;cursor:pointer;box-shadow:0 8px 18px rgba(50,22,42,.08)}.fab{width:54px;height:54px;border-radius:999px;border:0;background:var(--primary);color:#fff;font-size:32px;font-weight:900;box-shadow:var(--shadow);cursor:pointer}.controls{display:grid;gap:10px;margin:16px 0}.modal-backdrop{position:fixed;inset:0;background:rgba(38,28,35,.42);display:none;align-items:center;justify-content:center;padding:14px;z-index:1000}.modal-backdrop.show{display:flex}.modal{width:min(430px,96vw);max-height:84vh;overflow:auto;background:#fff;border-radius:24px;border:1px solid var(--border);box-shadow:var(--shadow);padding:18px}.modal h2{margin:0 0 10px}.modal .form{gap:10px}.modal input,.modal select,.modal textarea{padding:11px 12px;font-size:15px}.modal-actions{display:grid;gap:8px;margin-top:8px}.bottom-nav{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);width:min(424px,calc(100% - 36px));display:flex;gap:8px;background:rgba(255,255,255,.95);border:1px solid var(--border);border-radius:999px;padding:8px;box-shadow:var(--shadow)}.bottom-nav a{flex:1;text-align:center;border-radius:999px;padding:10px 4px;font-size:13px;font-weight:900;color:var(--muted)}.bottom-nav a.active{background:var(--primary);color:#fff}.auth-card{margin-top:28px}.center{text-align:center}.compact-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0 18px}.viewer-row{display:flex;justify-content:space-between;gap:10px;align-items:center;border:1px solid var(--border);border-radius:16px;padding:10px 12px;background:#fff}.viewer-row p{margin:0}.status-link-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:9px}.status-link-row .text-btn.active{background:var(--primary);color:#fff;text-decoration:none;border-radius:999px;padding:5px 9px}


/* v2.4 icons, autofill and nav polish */
.icon-picker {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 9px;
}

.icon-choice {
  min-height: 44px;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 15px;
  font-size: 22px;
  font-weight: 900;
  cursor: pointer;
}

.icon-choice.selected {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(109,46,89,.12);
  background: #F7E9F2;
}

.initial-icon {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  color: white;
  font-weight: 900;
  background: var(--primary);
}

.autofill-card {
  background: #F7E9F2;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 12px;
}

.bottom-nav {
  align-items: center;
}

.bottom-nav a {
  display: grid;
  place-items: center;
  gap: 2px;
  min-height: 52px;
  font-size: 11px;
}

.bottom-nav a span {
  font-size: 20px;
  line-height: 1;
}

.bottom-nav a.active {
  min-height: 58px;
  margin-top: -16px;
  box-shadow: 0 10px 22px rgba(109,46,89,.22);
}


/* v2.5 fixes */
.initial-icon {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  color: var(--primary);
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--border);
}

.tile-icon .initial-icon {
  width: 38px;
  height: 38px;
  font-size: 19px;
}

.icon-choice {
  color: var(--primary);
}

.icon-choice .initial-icon {
  border: none;
  background: transparent;
}

.bottom-nav a {
  display: grid;
  place-items: center;
  gap: 2px;
  min-height: 52px;
  font-size: 11px;
}

.bottom-nav a span {
  font-size: 20px;
  line-height: 1;
}

.bottom-nav a.active {
  min-height: 58px;
  margin-top: -16px;
  box-shadow: 0 10px 22px rgba(109,46,89,.22);
}


/* v2.6 polish fixes */
.gift-colour-icon {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 14px;
  color: #fff;
  font-size: 21px;
  box-shadow: inset 0 -8px 16px rgba(0,0,0,.08);
}

.gift-purple { background: #7A2E68; }
.gift-red { background: #D94D4D; }
.gift-blue { background: #2F80ED; }
.gift-green { background: #3FA66B; }
.gift-gold { background: #D9A441; }
.gift-pink { background: #F06AA3; }
.gift-teal { background: #2AA6A1; }

.icon-choice .gift-colour-icon {
  width: 30px;
  height: 30px;
  border-radius: 11px;
  font-size: 18px;
}

.initial-icon {
  background: #fff !important;
  color: var(--primary) !important;
  border: 1px solid var(--border) !important;
}

.tile-icon .initial-icon {
  width: 38px;
  height: 38px;
  font-size: 19px;
}

.bottom-nav {
  align-items: center;
  padding: 8px;
}

.bottom-nav a,
.bottom-nav a.active {
  display: grid;
  place-items: center;
  gap: 2px;
  min-height: 50px;
  margin-top: 0;
  box-shadow: none;
  font-size: 11px;
}

.bottom-nav a span {
  font-size: 19px;
  line-height: 1;
}

.bottom-nav a.active {
  background: var(--primary);
  color: #fff;
}

.autofill-card {
  background: #F7E9F2;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 12px;
}


/* v2.8 extra icons */
.gift-orange { background: #F97316; }
.gift-lime { background: #84CC16; }
.gift-sky { background: #0EA5E9; }
.gift-violet { background: #8B5CF6; }
.gift-rose { background: #E11D48; }

.icon-picker {
  grid-template-columns: repeat(5, 1fr);
}
