:root{--primary:#e6005c;--primary-dark:#c9004f;--pink-soft:#fff2f7;--pink-light:#ffe6f0;--pink-lighter:#fff8fb;--text:#111827;--text-soft:#374151;--muted:#6b7280;--border:#ececf0;--border-soft:#f3f4f6;--success:#22a45d;--warning:#f59e0b;--danger:#ef4444;--white:#fff;--bg:#fffaf7;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--radius-pill:999px;--shadow-sm:0 2px 8px #0f172a0a;--shadow-md:0 8px 24px #0f172a0f;--shadow-lg:0 20px 50px #0f172a14;--shadow-pink:0 10px 28px #e6005c38;--shadow-card:0 24px 60px #1118271a;--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-script:"Dancing Script", cursive}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);color:var(--text);background:linear-gradient(180deg, var(--bg) 0%, var(--pink-lighter) 100%);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:15px;line-height:1.55}a{color:inherit;text-decoration:none}ul{list-style:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}input{font:inherit;color:inherit}h1{color:var(--text);font-weight:800;line-height:1.2}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:30px 20px;display:flex;position:relative;overflow:hidden}.floral-decoration{pointer-events:none;opacity:.7;width:200px;position:absolute;top:30px}.floral-decoration.left{left:0}.floral-decoration.right{right:0}.floral-decoration svg{width:100%;height:auto}.auth-container{z-index:1;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:480px;display:flex;position:relative}.logo{align-items:center;gap:4px;line-height:1;display:flex}.logo-script{font-family:var(--font-script);color:var(--primary);font-size:1.9rem;font-weight:700}.logo-block{flex-direction:column;line-height:1;display:flex}.logo-bold{letter-spacing:1px;color:var(--text);font-size:1.1rem;font-weight:800}.logo-sub{letter-spacing:4px;color:var(--muted);margin-top:2px;font-size:.6rem;font-weight:500}.auth-card{background:var(--white);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-card);border:1px solid var(--border-soft);padding:40px 36px 32px}.auth-header{text-align:center;margin-bottom:28px}.auth-header h1{letter-spacing:-.5px;margin-bottom:8px;font-size:1.8rem}.auth-header p{color:var(--muted);font-size:.92rem;line-height:1.5}.auth-form{flex-direction:column;gap:18px;margin-bottom:22px;display:flex}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label{color:var(--text);font-size:.85rem;font-weight:600}.input-wrap{align-items:center;display:flex;position:relative}.input-icon{color:var(--muted);pointer-events:none;position:absolute;left:16px}.input-wrap input{border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--white);width:100%;padding:12px 16px 12px 46px;font-size:.95rem;transition:all .15s}.input-wrap input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--pink-light);outline:none}.input-wrap input.error{border-color:var(--danger)}.toggle-pwd{width:32px;height:32px;color:var(--muted);border-radius:8px;justify-content:center;align-items:center;display:inline-flex;position:absolute;right:12px}.toggle-pwd:hover{color:var(--primary);background:var(--pink-soft)}.field-error{color:var(--danger);min-height:1em;font-size:.78rem}.form-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:-4px;display:flex}.remember{cursor:pointer;color:var(--text-soft);align-items:center;gap:8px;font-size:.88rem;display:inline-flex}.remember input{opacity:0;pointer-events:none;position:absolute}.check-mark{border:1.5px solid var(--border);background:var(--white);border-radius:5px;justify-content:center;align-items:center;width:18px;height:18px;transition:all .15s;display:inline-flex}.remember input:checked+.check-mark{border-color:var(--primary);background:var(--primary)}.remember input:checked+.check-mark:after{content:"";border-left:2px solid var(--white);border-bottom:2px solid var(--white);width:9px;height:5px;transform:rotate(-45deg)translate(1px,-1px)}.forgot{color:var(--primary);font-size:.88rem;font-weight:600}.forgot:hover{text-decoration:underline}.form-error{background:var(--pink-soft);color:var(--danger);border-radius:var(--radius-md);border:1px solid #ef444433;align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;display:flex}.btn{border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;border:2px solid #0000;justify-content:center;align-items:center;gap:8px;padding:13px 24px;font-size:.95rem;font-weight:600;line-height:1.2;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:var(--white);box-shadow:var(--shadow-pink)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px)}.btn-block{width:100%}.arrow{display:inline-flex}.divider{color:var(--muted);align-items:center;margin:22px 0;font-size:.78rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border-soft);flex:1;height:1px}.divider span{padding:0 14px}.demo-accounts{flex-direction:column;gap:10px;margin-bottom:22px;display:flex}.demo-btn{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-md);text-align:left;align-items:center;gap:14px;padding:14px 18px;transition:all .2s;display:flex}.demo-btn:hover{border-color:var(--primary);background:var(--pink-soft);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.demo-btn>div{flex:1;line-height:1.3}.demo-btn strong{color:var(--text);margin-bottom:2px;font-size:.92rem;font-weight:700;display:block}.demo-btn span:not(.arrow):not(.demo-icon){color:var(--muted);font-size:.78rem}.demo-btn .arrow{color:var(--primary);opacity:.5;font-size:1.1rem;transition:opacity .2s,transform .2s}.demo-btn:hover .arrow{opacity:1;transform:translate(4px)}.demo-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex}.demo-icon.sposi{background:var(--pink-light);color:var(--primary)}.demo-icon.planner{color:#0369a1;background:#bae6fd66}.demo-icon.admin{color:#c2410c;background:#fed7aa80}.demo-creds{background:var(--pink-lighter);border:1px solid var(--pink-light);border-radius:var(--radius-md);margin-bottom:18px;padding:12px 16px;font-size:.82rem}.demo-creds summary{cursor:pointer;color:var(--primary);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;font-weight:600;list-style:none;display:flex}.demo-creds summary:after{content:"+";font-size:1.2rem;line-height:1}.demo-creds[open] summary:after{content:"−"}.demo-creds ul{border-top:1px solid var(--pink-light);margin-top:12px;padding-top:12px}.demo-creds li{color:var(--text-soft);padding:4px 0;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:.78rem}.demo-creds strong{color:var(--text);margin-right:4px}.auth-footer{text-align:center;color:var(--muted);border-top:1px solid var(--border-soft);padding-top:20px;font-size:.88rem}.auth-footer a{color:var(--primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.back-home{color:var(--muted);font-size:.85rem;transition:color .15s}.back-home:hover{color:var(--primary)}.toast{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;align-items:center;gap:10px;padding:14px 18px;font-size:.9rem;animation:.3s slideIn;display:flex;position:fixed;top:24px;right:24px}.toast.success{border-color:var(--success);color:var(--success)}.toast.error{border-color:var(--danger);color:var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (max-width:600px){.auth-page{padding:20px 16px}.auth-card{border-radius:var(--radius-lg);padding:28px 22px 24px}.auth-header h1{font-size:1.5rem}.floral-decoration{display:none}.demo-btn{gap:12px;padding:12px 14px}.demo-icon{width:36px;height:36px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:4px}
