:root{
  --bg:#ffffff;
  --surface:#fff;
  --fg:#1a1a1a;
  --muted:#6b6b6b;
  --border:#ececec;
  --primary:#e6157a;
  --primary-hover:#c81169;
  --primary-soft:#fff0f6;
  --shadow: 0 10px 40px rgba(230,21,122,0.08), 0 2px 8px rgba(0,0,0,0.04);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--fg);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

.page{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr;
}
@media(min-width:960px){
  .page{grid-template-columns:1.05fr 1fr}
}

/* Brand panel */
.brand-panel{
  display:none;
  position:relative;
  background:linear-gradient(160deg,#fff5f9 0%,#ffe4ef 50%,#ffd1e3 100%);
  padding:48px;
  overflow:hidden;
}
@media(min-width:960px){.brand-panel{display:flex;flex-direction:column;justify-content:space-between}}
.brand-panel::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at 80% 10%, rgba(230,21,122,.18), transparent 55%),
             radial-gradient(circle at 10% 90%, rgba(230,21,122,.12), transparent 50%);
  pointer-events:none;
}
.brand-logo{
  position:relative;
  font-family:'Playfair Display','Cormorant Garamond',Georgia,serif;
  font-size:40px;
  font-weight:700;
  letter-spacing:-.5px;
}
.brand-logo .ink{color:#1a1a1a}
.brand-logo .accent{color:var(--primary)}
.brand-hero{position:relative;max-width:460px}
.brand-hero h2{
  font-family:'Playfair Display',serif;
  font-weight:600;
  font-size:44px;
  line-height:1.1;
  margin:0 0 18px;
  color:#1a1a1a;
}
.brand-hero h2 em{font-style:italic;color:var(--primary);font-weight:500}
.brand-hero p{color:#5a4a52;font-size:16px;line-height:1.6;margin:0}
.brand-foot{position:relative;font-size:13px;color:#8a6b76;display:flex;gap:16px;flex-wrap:wrap}
.brand-foot span::before{content:"✦ ";color:var(--primary)}

/* Form panel */
.form-panel{
  display:flex;align-items:center;justify-content:center;
  padding:32px 20px;
}
.form-card{
  width:100%;max-width:440px;
}
.mobile-logo{
  text-align:center;margin-bottom:28px;
  font-family:'Playfair Display',serif;font-size:30px;font-weight:700;
}
@media(min-width:960px){.mobile-logo{display:none}}
.mobile-logo .accent{color:var(--primary)}

.form-card h1{
  font-family:'Playfair Display',serif;
  font-size:32px;font-weight:600;margin:0 0 8px;color:var(--fg);
}
.form-card .sub{color:var(--muted);font-size:14px;margin:0 0 28px}

.field{margin-bottom:16px}
.field label{
  display:block;font-size:13px;font-weight:500;
  margin-bottom:6px;color:#3a3a3a;
}
.field input{
  width:100%;height:46px;padding:0 14px;
  border:1px solid var(--border);border-radius:10px;
  background:#fafafa;font-size:15px;color:var(--fg);
  transition:.18s;
  font-family:inherit;
}
.field input:focus{
  outline:none;border-color:var(--primary);
  background:#fff;
  box-shadow:0 0 0 4px rgba(230,21,122,.10);
}

.row{display:flex;justify-content:space-between;align-items:center;margin:6px 0 20px;font-size:13px}
.row label{display:flex;align-items:center;gap:6px;color:var(--muted);cursor:pointer}
.row a{font-weight:500}

.btn{
  width:100%;height:48px;border:none;border-radius:10px;
  font-size:15px;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:inherit;transition:.18s;
}
.btn-primary{
  background:var(--primary);color:#fff;
  box-shadow:0 6px 20px rgba(230,21,122,.28);
}
.btn-primary:hover{background:var(--primary-hover)}
.btn-google{
  background:#fff;color:#3a3a3a;border:1px solid var(--border);
  margin-top:12px;
}
.btn-google:hover{background:#fafafa;border-color:#d8d8d8}
.btn-google svg{width:18px;height:18px}

.divider{
  display:flex;align-items:center;gap:14px;
  margin:22px 0;color:var(--muted);font-size:12px;
  text-transform:uppercase;letter-spacing:1.5px;
}
.divider::before,.divider::after{
  content:"";flex:1;height:1px;background:var(--border);
}

.foot{
  margin-top:28px;text-align:center;
  font-size:14px;color:var(--muted);
}
.foot a{font-weight:600}
