.tool{max-width:760px;margin:0 auto;padding:2.5rem 1.25rem 4rem}.crumbs{font-family:Public Sans,sans-serif;font-size:.75rem;color:var(--ink-60);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.25rem}.crumbs a{color:var(--ink-60)}.crumbs a:hover{color:var(--mauve)}.crumbs span{color:var(--ink-40);margin:0 .4rem}.tool-head{margin-bottom:2.5rem}.tool-head h1{font-size:clamp(2.25rem,6vw,3.25rem);line-height:1.05;margin-bottom:.75rem}.tool-head h1 em{color:var(--mauve);font-family:EB Garamond,serif;font-style:italic;font-weight:400}.lede{font-family:EB Garamond,serif;font-style:italic;font-size:1.2rem;color:var(--ink-80);line-height:1.55;margin-bottom:.5rem}.ephemeral{font-family:Public Sans,sans-serif;font-size:.78rem;color:var(--mauve);text-transform:uppercase;letter-spacing:.1em}.step{margin:2.5rem 0}.step-row{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem}.step-num{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--mauve);color:#fff;font-family:Sora,sans-serif;font-weight:800;font-size:1rem;flex-shrink:0}.step-label{font-family:Sora,sans-serif;font-weight:700;font-size:1.15rem;color:var(--ink)}.step-hint{font-size:.92rem;color:var(--ink-60);margin-bottom:1rem;margin-left:51px}.date-input{margin-left:51px;padding:.85rem 1.1rem;border:1.5px solid var(--ink-16);border-radius:var(--radius-field);background:var(--surface);font-family:Manrope,sans-serif;font-size:1.05rem;color:var(--ink);width:calc(100% - 51px);max-width:280px;transition:border-color .2s,box-shadow .2s}.date-input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-tint)}.day-grid{margin-left:51px;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem}@media(max-width:560px){.day-grid{margin-left:0;grid-template-columns:repeat(7,minmax(0,1fr));gap:.35rem}.step-hint,.date-input{margin-left:0}.date-input{width:100%;max-width:none}}.day-cell{background:var(--surface);border:1.5px solid var(--ink-08);border-radius:14px;padding:.85rem .4rem;text-align:center;cursor:pointer;user-select:none;transition:all .18s ease;min-height:78px;display:flex;flex-direction:column;justify-content:center;gap:.25rem;font-family:inherit;color:var(--ink)}.day-cell:hover{border-color:var(--mauve);transform:translateY(-2px);box-shadow:0 6px 14px #3a22180f}.day-cell.active{background:var(--pink);color:#fff;border-color:var(--pink);box-shadow:0 8px 20px var(--pink-glow)}.day-cell.active:hover{transform:translateY(-2px)}.day-cell .dow{font-family:Public Sans,sans-serif;font-weight:700;font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-60)}.day-cell.active .dow{color:#ffffffd9}.day-cell .dom{font-family:Sora,sans-serif;font-weight:800;font-size:1.4rem;line-height:1}.day-cell .mon{font-family:Public Sans,sans-serif;font-weight:600;font-size:.7rem;color:var(--ink-60)}.day-cell.active .mon{color:#ffffffd9}.actions{display:flex;gap:.65rem;margin-left:51px;flex-wrap:wrap}@media(max-width:560px){.actions{margin-left:0}}.btn-primary{background:var(--pink);color:#fff;padding:.95rem 1.85rem;border:none;border-radius:999px;font-family:Public Sans,sans-serif;font-weight:700;font-size:.9rem;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:var(--shadow-button);letter-spacing:.02em}.btn-primary:hover{background:var(--mauve);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--ink-60);padding:.95rem 1.5rem;border:1.5px solid var(--ink-16);border-radius:999px;font-family:Public Sans,sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:border-color .2s,color .2s}.btn-ghost:hover{border-color:var(--mauve);color:var(--mauve)}.result{margin:3rem 0 2rem;padding:2rem 1.5rem;background:var(--surface);border-radius:28px;box-shadow:var(--shadow-card);border:1.5px solid var(--ink-08);opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.result[data-shown=true]{opacity:1;transform:translateY(0)}.result-head{text-align:center;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--ink-08)}.result-eyebrow{font-family:Public Sans,sans-serif;font-weight:700;font-size:.7rem;color:var(--mauve);text-transform:uppercase;letter-spacing:.14em;display:block;margin-bottom:.6rem}.result-title{font-family:Sora,sans-serif;font-weight:800;font-size:clamp(1.4rem,4vw,1.75rem);line-height:1.2;color:var(--ink);margin:0;letter-spacing:-.015em}.result-title .accent{color:var(--mauve);font-family:EB Garamond,serif;font-style:italic;font-weight:400}.result-days{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.4rem}.result-row{display:grid;grid-template-columns:88px 1fr auto;gap:.85rem;align-items:center;padding:.75rem 1rem;border-radius:14px;border:1.5px solid;font-size:.92rem}.result-row.tuhr{background:var(--green-bg);border-color:var(--green-border);color:var(--green-fg)}.result-row.hayd{background:var(--red-bg);border-color:var(--red-border);color:var(--red-fg)}.result-row.istihadha{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber-fg)}.result-row.pending{background:var(--mauve-tint);border-color:var(--mauve);color:var(--mauve)}.result-row .row-date{font-family:Sora,sans-serif;font-weight:800;font-size:.95rem}.result-row .row-state{font-family:Public Sans,sans-serif;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;padding:.3rem .6rem;background:#fff6;border-radius:999px}.result-row .row-note{grid-column:1 / -1;font-size:.83rem;line-height:1.55;margin-top:.3rem;opacity:.9}.result-foot{text-align:center;font-family:EB Garamond,serif;font-style:italic;color:var(--ink-60);font-size:.95rem;margin:0}.over-banner{background:var(--mauve-tint);border:1.5px solid var(--mauve-light);border-radius:16px;padding:1.25rem 1.4rem;margin:0 0 1.5rem}.over-banner[hidden]{display:none}.over-banner-head{display:flex;align-items:center;gap:.65rem;margin-bottom:.65rem;flex-wrap:wrap}.over-pill{background:var(--mauve);color:#fff;padding:.25rem .7rem;border-radius:999px;font-family:Public Sans,sans-serif;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em}.over-banner-head strong{font-family:Sora,sans-serif;font-weight:700;color:var(--ink);font-size:1rem}.over-banner p{color:var(--ink-80);font-size:.92rem;line-height:1.6;margin:0 0 .6rem}.over-banner-cta a{color:var(--mauve);font-family:Public Sans,sans-serif;font-weight:600}.over-banner-cta a:hover{color:var(--pink)}.explain{margin:3rem 0 1.5rem}.explain h2{font-size:1.35rem;margin-bottom:1.25rem;color:var(--ink)}.explain ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.85rem}.explain li{background:var(--parchment);padding:1rem 1.25rem;border-radius:16px;line-height:1.55}.tool-reassurance{font-family:EB Garamond,serif;font-style:italic;color:var(--mauve);font-size:1rem;margin:0 0 1.5rem;max-width:36ch;line-height:1.5}.tool-reassurance em{font-style:italic}.ruling-pill{display:inline-block;background:var(--mauve);color:#fff;padding:.2rem .6rem;border-radius:999px;font-family:Public Sans,sans-serif;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;margin-right:0;flex-shrink:0}.ruling-card{background:var(--surface);border:1.5px solid var(--ink-08);border-radius:18px;padding:0;margin:0 0 .75rem;overflow:hidden;transition:border-color .2s,box-shadow .2s}.ruling-card[open]{border-color:var(--mauve-light);box-shadow:var(--shadow-card)}.ruling-summary{display:flex;align-items:center;gap:.85rem;padding:1rem 1.25rem;cursor:pointer;list-style:none;min-height:56px}.ruling-summary::-webkit-details-marker{display:none}.ruling-summary:hover{background:var(--mauve-tint)}.ruling-title{flex:1;font-family:Sora,sans-serif;font-weight:700;font-size:1rem;color:var(--ink);line-height:1.3}.ruling-chevron{transition:transform .2s;color:var(--mauve);flex-shrink:0}.ruling-card[open] .ruling-chevron{transform:rotate(180deg)}.ruling-body{padding:0 1.25rem 1.25rem}.ruling-body p{color:var(--ink-80);font-size:.92rem;line-height:1.6;margin:0 0 .6rem}.src-link{display:inline-block;margin-top:.5rem;font-family:Public Sans,sans-serif;font-weight:600;font-size:.82rem;color:var(--mauve)}.src-link:hover{color:var(--pink)}.see-also{margin-top:1.25rem;color:var(--ink-60);font-size:.95rem}.oos{margin-top:1.5rem;background:var(--canvas-deep);padding:1rem 1.25rem;border-radius:14px;font-size:.9rem}.oos summary{cursor:pointer;font-family:Public Sans,sans-serif;font-weight:600;color:var(--ink-80);list-style:none}.oos summary::-webkit-details-marker{display:none}.oos summary:before{content:"+ ";color:var(--mauve);font-weight:700}.oos[open] summary:before{content:"− "}.oos p{margin-top:.6rem;color:var(--ink-80);line-height:1.6}
