*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#faf6f3;color:#2b2b2b;-webkit-font-smoothing:antialiased;font-size:16px}button{font:inherit;cursor:pointer;border-radius:8px;border:1px solid transparent;padding:.6rem 1rem;background:#b03060;color:#fff;transition:background .12s ease}button:hover{background:#8d2650}button.secondary{background:#fff;color:#b03060;border-color:#b03060}button.danger{background:#c0392b}button.btn-link{background:transparent;color:#b03060;border:none;padding:.25rem .5rem}input,select,textarea{font:inherit;width:100%;padding:.55rem .7rem;border:1px solid #d8c8c8;border-radius:8px;background:#fff;color:#2b2b2b}input:focus,select:focus,textarea:focus{outline:2px solid #b03060;outline-offset:1px}label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.25rem;color:#444}a{color:#b03060;text-decoration:none}a:hover{text-decoration:underline}.layout{display:flex;flex-direction:column;min-height:100vh}.topbar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #ecdcdc;position:sticky;top:0;z-index:10}.brand{font-weight:700;flex:1;color:#b03060}.content{flex:1;padding:1rem 1rem 5rem;max-width:720px;width:100%;margin:0 auto}.bottombar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;background:#fff;border-top:1px solid #ecdcdc;padding:.5rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom));z-index:10}.bottombar a{flex:1;text-align:center;padding:.5rem;border-radius:8px;font-size:.85rem;color:#777}.bottombar a.active{color:#b03060;background:#fdebef;font-weight:600}.centered{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.1rem;color:#888}.phase{font-size:.8rem;padding:.2rem .6rem;border-radius:999px;background:#eee;color:#555;white-space:nowrap}.phase-menstruation{background:#f8d6df;color:#a01a3c}.phase-follicolare{background:#d4ecd4;color:#2d6a31}.phase-fertile{background:#d6e6f7;color:#1f4d7a}.phase-ovulazione{background:#b9d8f7;color:#143b66;font-weight:600}.phase-luteale{background:#fff1c1;color:#7a5a13}.phase-premestruale{background:#f9c8c1;color:#8a3013}.phase-unknown{background:#eee;color:#555}.card{background:#fff;border:1px solid #ecdcdc;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 2px #00000008}.card h2{margin:0 0 .75rem;font-size:1.1rem;color:#b03060}.row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.field{margin-bottom:.75rem}.muted{color:#888;font-size:.9rem}.list{list-style:none;margin:0;padding:0}.list li{padding:.6rem 0;border-bottom:1px solid #f0e0e0}.list li:last-child{border-bottom:none}.error{background:#fdecea;color:#a01818;padding:.6rem .8rem;border-radius:8px;margin-bottom:.75rem}.med-intake{padding:.75rem .25rem;border-bottom:1px solid #f0e0e0}.med-intake:last-child{border-bottom:none}.med-intake-head{display:flex;align-items:center;gap:.5rem;justify-content:space-between}.med-intake-name{flex:1;font-weight:500}.med-intake .dose{color:#888;font-size:.9rem}.intakes{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.intake-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;background:#fdebef;color:#8d2650;border-radius:999px;font-variant-numeric:tabular-nums;font-size:.9rem}.intake-chip .btn-link{color:inherit}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:.5rem}.calendar .dow,.calendar .day{text-align:center;padding:.4rem 0;font-size:.85rem;border-radius:6px}.calendar .dow{font-weight:600;color:#888}.calendar .day{background:#fff;border:1px solid #f0e0e0;cursor:pointer}.calendar .day.empty{visibility:hidden}.calendar .day.today{border-color:#b03060;font-weight:700}.calendar .day.menstruation{background:#f8d6df}.calendar .day.follicolare{background:#e8f5e8}.calendar .day.fertile{background:#e2eef9}.calendar .day.ovulazione{background:#b9d8f7;font-weight:700}.calendar .day.luteale{background:#fff7d9}.calendar .day.premestruale{background:#f9d6cf}.calendar .day.has-headache:after{content:"•";color:#c0392b;margin-left:2px;font-weight:700}.cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.auth-card{max-width:360px;margin:3rem auto;background:#fff;border-radius:14px;padding:2rem;box-shadow:0 4px 20px #b0306014}.auth-card h1{text-align:center;color:#b03060;margin-top:0;font-size:1.4rem}.auth-card .field+.field{margin-top:.75rem}.auth-card button{width:100%;margin-top:1rem}
