:root{
  --bg:#f0fdf4; --bg-hero:#e8ffef; --section-alt-bg:#ecfdf5; --card:#fff;
  --text:#064e3b; --muted:#4b5563; --accent:#16a34a; --accent-2:#22c55e;
  --stroke:rgba(0,0,0,.08); --A:#15803d; --B:#16a34a; --C:#22c55e; --D:#84cc16; --E:#f59e0b; --F:#f97316; --G:#ef4444;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial}
a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
header{position:sticky;top:0;backdrop-filter:saturate(180%) blur(8px);background:rgba(240,253,244,.95);border-bottom:1px solid var(--stroke);z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;gap:10px;align-items:center;font-weight:800}
.logo{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:inline-block}
.menu{display:flex;gap:18px;align-items:center}
.btn{display:inline-block;padding:10px 16px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:white;font-weight:800;border:0;cursor:pointer;box-shadow:0 2px 0 rgba(0,0,0,.06)}
.btn.outline{background:transparent;border:1px solid var(--stroke);color:var(--text)}
.kicker{color:var(--accent);font-weight:800;margin:0 0 8px}
.hero{padding:90px 0 56px;background:radial-gradient(1200px 600px at 50% -220px, var(--bg-hero), transparent)}
.hero h1{font-size:42px;line-height:1.15;margin:0 0 10px}
.hero p{max-width:760px;opacity:.95;margin:0 0 24px}
.bullets{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.pill{border:1px solid var(--stroke);border-radius:999px;padding:8px 12px;background:#fff}
.pill-warm{background:#fff7ed;border-color:#fed7aa}
.pill-cool{background:#ecfeff;border-color:#bae6fd}
.section{padding:56px 0}
.section.alt{background:var(--section-alt-bg);border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke)}
.card{background:var(--card);border:1px solid var(--stroke);border-radius:18px;padding:18px;box-shadow:0 2px 6px rgba(0,0,0,.05)}
.app{display:grid;grid-template-columns:1.1fr .9fr;gap:22px}
.q{display:flex;flex-direction:column;gap:12px}
.q .row{display:flex;gap:10px;align-items:center}
.icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(14,165,165,.12);border:1px solid var(--stroke)}
label{font-size:14px;color:var(--muted)}
select,input,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--stroke);background:#fff;color:var(--text)}
.app-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.aside-title{margin-top:0;font-size:20px}
.badge{display:inline-flex;align-items:center;justify-content:center;width:148px;height:148px;border-radius:32px;font-weight:900;font-size:64px;background:#dcfce7;border:2px solid var(--stroke)}
.scale{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin:10px 0 14px}
.scale div{height:10px;border-radius:3px}
.sep{border-color:transparent;border-top:1px solid var(--stroke);margin:14px 0}
.hint{color:var(--muted);font-size:14px}
.plan-grid{display:grid;grid-template-columns:1fr 340px;gap:16px}
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:10px}
.group{display:flex;gap:8px;align-items:center;padding:8px 10px;border:1px solid var(--stroke);border-radius:12px;background:#f0fdf4}
.canvasWrap{position:relative;border:1px solid var(--stroke);border-radius:14px;overflow:hidden;background:#fff}
#planCanvas{display:block;width:100%;height:540px;touch-action:none}
.pad{padding:10px}
.table{border:1px solid var(--stroke);border-radius:12px;overflow:hidden;background:#fff}
.table header{background:#ecfeff;border-bottom:1px solid var(--stroke);padding:8px 10px;font-weight:600;color:#155e75}
.table .row{display:grid;grid-template-columns:1.2fr .9fr .7fr .5fr 40px;gap:8px;align-items:center;padding:8px 10px;border-bottom:1px dashed rgba(0,0,0,.06)}
.table .row:last-child{border-bottom:0}
.type-badge{padding:4px 8px;border-radius:999px;border:1px solid var(--stroke);background:#ecfdf5}
.chk{display:flex;gap:6px;align-items:center}
.works{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.work{border:1px solid var(--stroke);border-radius:14px;padding:14px;background:#f9fafb}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pro{display:flex;gap:12px}
.avatar{width:56px;height:56px;border-radius:12px;background:#bbf7d0;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.stars{letter-spacing:2px;color:#ca8a04}
.totals{margin-top:10px;font-weight:700}
footer{padding:32px 0;border-top:1px solid var(--stroke);opacity:.9;margin-top:40px;background:#ecfdf5}
.foot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.links{display:flex;gap:12px}
.hidden{display:none}
@media (max-width: 980px){.app{grid-template-columns:1fr}.plan-grid{grid-template-columns:1fr}}
@media (max-width: 760px){.grid3{grid-template-columns:1fr}.works{grid-template-columns:1fr}}

.objective{margin:14px 0 18px;padding:12px 14px;border:1px solid var(--stroke);border-radius:14px;background:var(--card)}
.objective .goalLabel{font-weight:600;margin-bottom:8px}
input[type=range]#goalSlider{width:100%;height:28px;appearance:none;background:linear-gradient(90deg,var(--A),var(--B) 16%,var(--C) 33%,var(--D) 50%,var(--E) 66%,var(--F) 83%,var(--G) 100%);border-radius:999px;outline:none}
input[type=range]#goalSlider::-webkit-slider-thumb{appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid #111;box-shadow:0 2px 6px rgba(0,0,0,.15)}
input[type=range]#goalSlider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid #111;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.dpeTicks{display:flex;justify-content:space-between;margin-top:6px;font-weight:800;font-family:ui-sans-serif,system-ui}
.dpeTicks span{font-size:12px;opacity:.95}
.dpeTicks .A{color:var(--A)} .dpeTicks .B{color:var(--B)} .dpeTicks .C{color:var(--C)} .dpeTicks .D{color:var(--D)}
.dpeTicks .E{color:var(--E)} .dpeTicks .F{color:var(--F)} .dpeTicks .G{color:var(--G)}


/* Ortho snap label visibility on mobile */
.orthoLabel{font-weight:700}
@media (max-width:760px){
  .orthoLabel{color:#111;background:#fff;padding:2px 6px;border-radius:6px;box-shadow:0 1px 0 rgba(0,0,0,.06)}
  .toolbar .chk input{transform:scale(1.2)}
}
/* Recommendation grade pill */
.badge-grade{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;font-weight:800;font-size:12px;border:1px solid var(--stroke);background:var(--card)}
.badge-grade .dot{width:10px;height:10px;border-radius:50%}
.badge-grade.A .dot{background:var(--A)} .badge-grade.B .dot{background:var(--B)} .badge-grade.C .dot{background:var(--C)}
.badge-grade.D .dot{background:var(--D)} .badge-grade.E .dot{background:var(--E)} .badge-grade.F .dot{background:var(--F)} .badge-grade.G .dot{background:var(--G)}
