/* Tool pages — quiz, calc, visualizer, ingredients, recipes, storage, compare */

/* ---------- Shared tool shells ---------- */
.cor-quiz-app, .cor-calc-app, .cor-vis-app, .cor-ing-app, .cor-recipe-app, .cor-storage-app, .cor-compare-app {
	background: var(--cor-paper);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius-lg);
	padding: clamp(24px, 3.5vw, 40px);
	box-shadow: var(--cor-shadow);
}

/* ---------- Quiz ---------- */
.cor-quiz-progress { background: var(--cor-line); height: 6px; border-radius: 999px; overflow: hidden; margin-bottom: 1.2rem; }
.cor-quiz-progress > div { background: linear-gradient(90deg, var(--cor-sage), var(--cor-cream)); height: 100%; transition: width .3s ease; }
.cor-quiz-step { font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: var(--cor-muted); margin: 0 0 .5rem; }
.cor-quiz-q { font-size: clamp(1.4rem, 2vw + .8rem, 2rem); margin: 0 0 .35rem; }
.cor-quiz-help { color: var(--cor-muted); margin: 0 0 1.5rem; }
.cor-quiz-options { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 10px; }
.cor-quiz-opt {
	background: #fff; border: 1px solid var(--cor-line); border-radius: var(--cor-radius);
	padding: 16px 18px; text-align: left; display: flex; align-items: center; gap: 12px; cursor: pointer;
	transition: border-color .15s ease, background .15s ease, transform .15s ease;
	font-size: 1rem; color: var(--cor-ink);
}
.cor-quiz-opt:hover { border-color: var(--cor-ink); }
.cor-quiz-opt.is-picked { border-color: var(--cor-sage-d); background: var(--cor-sage-l); }
.cor-quiz-emoji { font-size: 1.4rem; line-height: 1; }
.cor-quiz-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 1.5rem; }
.cor-quiz-nav .cor-btn-cta[disabled] { background: var(--cor-line-2); box-shadow: none; }
.cor-quiz-result h2 { font-size: clamp(1.6rem, 3vw + .8rem, 2.4rem); margin: .5rem 0 .8rem; }
.cor-quiz-why { font-size: 1.05rem; color: var(--cor-ink-2); margin-bottom: 1.5rem; }
.cor-quiz-cta-row { margin: 1.5rem 0; }
.cor-quiz-secondary { background: var(--cor-cream-l); border-radius: var(--cor-radius); padding: 20px 24px; margin-top: 1.5rem; }
.cor-quiz-secondary h3 { margin: 0 0 .5rem; }
.cor-quiz-disclosure { font-size: .78rem; color: var(--cor-muted); margin: 1rem 0 .5rem; }

/* ---------- Calculator ---------- */
.cor-calc-shell { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
@media (max-width: 760px) { .cor-calc-shell { grid-template-columns: 1fr; } }
.cor-calc-controls { display: flex; flex-direction: column; gap: 14px; }
.cor-calc-label { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--cor-muted); letter-spacing: .04em; text-transform: uppercase; }
.cor-calc-label input, .cor-calc-label select { padding: 12px 14px; border-radius: var(--cor-radius-sm); border: 1px solid var(--cor-line); background: #fff; font-weight: 500; color: var(--cor-ink); text-transform: none; letter-spacing: 0; font-size: 1rem; }
.cor-calc-result {
	background: linear-gradient(135deg, var(--cor-sage-l) 0%, var(--cor-paper) 100%);
	border-radius: var(--cor-radius); padding: 28px 32px;
	display: flex; flex-direction: column; gap: 8px;
}
.cor-calc-bignum { display: flex; align-items: baseline; gap: 8px; font-family: var(--cor-serif); }
.cor-calc-num { font-size: clamp(2.5rem, 5vw + .5rem, 4rem); font-weight: 600; color: var(--cor-sage-d); line-height: 1; }
.cor-calc-unit { font-size: 1.5rem; color: var(--cor-cream-d); }
.cor-calc-equiv { color: var(--cor-muted); font-size: .92rem; margin: 0; }
.cor-calc-note { color: var(--cor-ink-2); font-size: .95rem; margin: 8px 0 14px; }

/* ---------- Visualizer ---------- */
.cor-vis-shell { display: grid; gap: 24px; }
.cor-vis-controls { display: flex; flex-direction: column; gap: 14px; }
.cor-vis-tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.cor-vis-tab { background: #fff; border: 1px solid var(--cor-line); padding: 9px 14px; border-radius: 999px; font-weight: 500; color: var(--cor-ink); cursor: pointer; font-size: .9rem; }
.cor-vis-tab.is-active { background: var(--cor-ink); color: #fff; border-color: var(--cor-ink); }
.cor-vis-temp { display: flex; flex-direction: column; gap: 8px; font-size: .92rem; color: var(--cor-muted); }
.cor-vis-temp input[type="range"] { accent-color: var(--cor-sage-d); }
.cor-vis-stage { display: grid; grid-template-columns: 220px 1fr; gap: 28px; align-items: center; padding: 24px; background: var(--cor-bg-warm); border-radius: var(--cor-radius); }
@media (max-width: 600px) { .cor-vis-stage { grid-template-columns: 1fr; } }
.cor-vis-jar {
	width: 200px; height: 240px; margin: 0 auto;
	background: rgba(255,255,255,.85); border-radius: 16% 16% 28% 28%;
	box-shadow: inset -10px 10px 30px rgba(0,0,0,.06), 0 16px 40px rgba(0,0,0,.06);
	position: relative; overflow: hidden;
}
.cor-vis-oil { position: absolute; bottom: 0; left: 8%; right: 8%; transition: height .4s ease, background .4s ease, border-radius .4s ease; box-shadow: inset 0 4px 8px rgba(0,0,0,.06); }
.cor-vis-readout { display: grid; grid-template-columns: auto 1fr; gap: 6px 18px; font-size: .92rem; margin: 0; }
.cor-vis-readout dt { font-weight: 600; color: var(--cor-muted); }
.cor-vis-readout dd { margin: 0; color: var(--cor-ink-2); }
.cor-vis-swatch { display: inline-block; width: 24px; height: 24px; border-radius: 6px; border: 1px solid var(--cor-line-2); vertical-align: middle; }
.cor-vis-notes { color: var(--cor-ink-2); }

/* ---------- Ingredient DB ---------- */
.cor-ing-shell { }
.cor-ing-controls { display: flex; gap: 12px; margin-bottom: 1rem; }
.cor-ing-search { flex: 1; padding: 12px 16px; border-radius: 999px; border: 1px solid var(--cor-line); background: #fff; }
.cor-ing-cat { padding: 10px 14px; border-radius: 999px; border: 1px solid var(--cor-line); background: #fff; }
.cor-ing-count { font-size: .85rem; color: var(--cor-muted); margin: 0 0 1rem; }
.cor-ing-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.cor-ing-card { background: #fff; border: 1px solid var(--cor-line); border-radius: var(--cor-radius); padding: 22px 24px; display: flex; flex-direction: column; gap: 10px; }
.cor-ing-card h3 { margin: 0; font-size: 1.1rem; }
.cor-ing-inci { margin: 0; font-size: .85rem; color: var(--cor-muted); }
.cor-ing-excerpt { margin: 4px 0 0; color: var(--cor-ink-2); font-size: .92rem; }
.cor-ing-comedo { display: flex; align-items: center; gap: 8px; margin-top: 4px; }
.cor-ing-comedo-bar { flex: 1; background: var(--cor-line); height: 8px; border-radius: 999px; overflow: hidden; }
.cor-ing-comedo-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--cor-sage), var(--cor-cta)); }
.cor-ing-comedo-num { font-size: .8rem; color: var(--cor-muted); font-weight: 600; }
.cor-ing-details { font-size: .9rem; }
.cor-ing-details summary { cursor: pointer; font-weight: 600; padding: 4px 0; }
.cor-ing-details ul { padding-left: 1.2em; margin: .25em 0 .5em; color: var(--cor-ink-2); }

/* ---------- Recipe generator ---------- */
.cor-recipe-shell { display: grid; gap: 28px; }
.cor-recipe-pickers { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 760px) { .cor-recipe-pickers { grid-template-columns: 1fr; } }
.cor-recipe-shell fieldset { border: 0; padding: 0; margin: 0; }
.cor-recipe-shell legend { font-weight: 600; font-size: .85rem; letter-spacing: .04em; text-transform: uppercase; color: var(--cor-muted); margin-bottom: .8rem; }
.cor-recipe-grid-pick { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px; }
.cor-recipe-radio {
	display: flex; flex-direction: column; align-items: center; gap: 6px;
	background: #fff; border: 1px solid var(--cor-line); border-radius: var(--cor-radius); padding: 14px 10px;
	cursor: pointer; transition: border-color .15s ease, background .15s ease;
	text-align: center; font-size: .88rem; font-weight: 500;
}
.cor-recipe-radio input { display: none; }
.cor-recipe-radio.is-on { border-color: var(--cor-sage-d); background: var(--cor-sage-l); }
.cor-recipe-emoji { font-size: 1.4rem; }
.cor-recipe-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.cor-recipe-chip {
	background: #fff; border: 1px solid var(--cor-line); border-radius: 999px;
	padding: 7px 14px; cursor: pointer; font-size: .85rem; font-weight: 500; transition: background .12s ease;
}
.cor-recipe-chip input { display: none; }
.cor-recipe-chip.is-on { background: var(--cor-cream-l); border-color: var(--cor-cream); color: var(--cor-ink); }

.cor-recipe-output { background: var(--cor-paper); border: 1px solid var(--cor-line); border-radius: var(--cor-radius); padding: clamp(20px, 3vw, 32px); }
.cor-recipe-output h2 { font-size: clamp(1.4rem, 2vw + .6rem, 1.9rem); margin: .25rem 0 .5rem; }
.cor-recipe-meta { color: var(--cor-muted); margin: 0 0 1.5rem; }
.cor-recipe-cols { display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px; margin-bottom: 1.5rem; }
@media (max-width: 760px) { .cor-recipe-cols { grid-template-columns: 1fr; gap: 20px; } }
.cor-recipe-cols h3 { font-size: 1rem; font-family: var(--cor-sans); letter-spacing: .04em; text-transform: uppercase; color: var(--cor-muted); margin: 0 0 .5rem; }
.cor-recipe-cols ul, .cor-recipe-cols ol { margin: 0; padding-left: 1.4em; font-size: .95rem; }
.cor-recipe-cols li { margin-bottom: .35rem; }
.cor-recipe-print { font-size: .85rem; color: var(--cor-muted); margin: 1rem 0 0; }

/* ---------- Storage tracker ---------- */
.cor-storage-shell { display: grid; gap: 24px; }
.cor-storage-form { background: var(--cor-bg-warm); padding: 24px; border-radius: var(--cor-radius); }
.cor-storage-form h3 { margin: 0 0 1rem; }
.cor-storage-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 12px; margin-bottom: 1rem; }
@media (max-width: 760px) { .cor-storage-row { grid-template-columns: 1fr 1fr; } }
.cor-storage-form label { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--cor-muted); }
.cor-storage-form input, .cor-storage-form select { padding: 10px 12px; border-radius: var(--cor-radius-sm); border: 1px solid var(--cor-line); background: #fff; font-weight: 500; color: var(--cor-ink); font-size: 1rem; }
.cor-storage-list { display: grid; gap: 10px; }
.cor-jar { display: flex; justify-content: space-between; align-items: center; gap: 16px; background: #fff; border: 1px solid var(--cor-line); border-left: 4px solid var(--cor-sage); border-radius: var(--cor-radius); padding: 16px 20px; }
.cor-jar.is-soon { border-left-color: var(--cor-cream); }
.cor-jar.is-warning { border-left-color: var(--cor-cta); background: #FFF8F4; }
.cor-jar.is-expired { border-left-color: #B92C0C; background: #FFEEE6; }
.cor-jar-meta h4 { margin: 0; font-size: 1.05rem; }
.cor-jar-meta p { margin: .25rem 0 0; font-size: .85rem; color: var(--cor-muted); }
.cor-jar-type { display: inline-block; background: var(--cor-bg-warm); border-radius: 999px; padding: 2px 10px; font-weight: 600; font-size: .75rem; letter-spacing: .04em; }
.cor-jar-status { display: flex; align-items: center; gap: 10px; }
.cor-jar-pill { background: var(--cor-sage-l); color: var(--cor-sage-d); padding: 5px 12px; border-radius: 999px; font-size: .82rem; font-weight: 600; }
.cor-jar.is-warning .cor-jar-pill { background: #FBE9DD; color: var(--cor-cta-d); }
.cor-jar.is-expired .cor-jar-pill { background: #B92C0C; color: #fff; }
.cor-jar-remove { background: transparent; border: 0; color: var(--cor-muted); font-size: 1.4rem; line-height: 1; cursor: pointer; padding: 0 6px; }
.cor-jar-remove:hover { color: var(--cor-cta); }
.cor-storage-restock { background: var(--cor-cream-l); border-radius: var(--cor-radius); padding: 20px 24px; }
.cor-storage-restock h4 { margin: 0 0 .8rem; }
.cor-storage-note { font-size: .85rem; color: var(--cor-muted); margin: 0; }

/* ---------- Comparison tool ---------- */
.cor-compare-app-shell { display: grid; gap: 24px; }
.cor-compare-pickers { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: end; }
@media (max-width: 600px) { .cor-compare-pickers { grid-template-columns: 1fr; } .cor-compare-vs { display: none; } }
.cor-compare-side label { font-weight: 600; font-size: .85rem; letter-spacing: .04em; text-transform: uppercase; color: var(--cor-muted); display: block; margin-bottom: 6px; }
.cor-compare-side select { width: 100%; padding: 12px 14px; border-radius: var(--cor-radius-sm); border: 1px solid var(--cor-line); background: #fff; }
.cor-compare-vs { font-family: var(--cor-serif); font-style: italic; color: var(--cor-cream-d); font-size: 1.6rem; padding-bottom: 8px; }
.cor-compare-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .cor-compare-cards { grid-template-columns: 1fr; } }
.cor-cmp-card { background: #fff; border: 1px solid var(--cor-line); border-radius: var(--cor-radius); padding: 20px; text-align: center; }
.cor-cmp-card img { width: 120px; height: 120px; object-fit: contain; margin: 0 auto 10px; background: var(--cor-bg-warm); border-radius: var(--cor-radius-sm); padding: 8px; }
.cor-cmp-card h3 { margin: 0 0 .35rem; font-size: 1.1rem; }
.cor-compare-tablewrap { overflow-x: auto; border: 1px solid var(--cor-line); border-radius: var(--cor-radius); }
.cor-compare-verdict { background: var(--cor-cream-l); border-radius: var(--cor-radius); padding: 20px 24px; }
.cor-compare-verdict h3 { margin: 0 0 .5rem; }
.cor-compare-verdict p { margin: 0; }
