.concept-menu{min-height:var(--app-viewport-height);display:grid;place-items:center;padding:calc(56px + var(--app-safe-top)) calc(28px + var(--app-safe-right)) calc(28px + var(--app-safe-bottom)) calc(28px + var(--app-safe-left));background:#edf2f3;color:#17211b}.concept-menu__shell{display:grid;gap:32px;width:min(100%,1080px)}.concept-menu__masthead{max-width:760px}.concept-menu__eyebrow,.concept-card__eyebrow{margin:0;color:#4f6357;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.concept-menu__title{margin:8px 0 12px;font-size:4rem;line-height:.98;letter-spacing:0}.concept-menu__intro{max-width:660px;margin:0;font-size:1.05rem;line-height:1.5;color:#40534b}.concept-menu__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;width:100%}.concept-card{min-height:270px;display:flex;flex-direction:column;align-items:stretch;gap:16px;padding:24px;border:1px solid rgba(23,33,27,.14);border-radius:8px;background:#fbfcf9;color:inherit;text-align:left;cursor:pointer;box-shadow:0 18px 42px #17211b1a;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.concept-card:hover{transform:translateY(-2px);border-color:#17211b42;box-shadow:0 22px 52px #17211b24}.concept-card__topline{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.concept-card__icon{display:grid;place-items:center;width:48px;height:48px;flex:0 0 auto;border-radius:8px}.concept-card__icon svg{width:25px;height:25px}.concept-card--green .concept-card__icon{background:#22492b1f;color:#22492b}.concept-card--blue .concept-card__icon{background:#1f53701f;color:#1f5370}.concept-card__title{margin-top:auto;font-size:1.9rem;font-weight:800;line-height:1.05}.concept-card__description{min-height:72px;color:#40534b;font-size:.98rem;line-height:1.45}.concept-card__meta{width:fit-content;max-width:100%;padding:8px 10px;border-radius:8px;background:#17211b12;color:#24332b;font-size:.84rem;font-weight:700}@media (max-width: 720px){.concept-menu{place-items:start center;padding:calc(24px + var(--app-safe-top)) calc(16px + var(--app-safe-right)) calc(28px + var(--app-safe-bottom)) calc(16px + var(--app-safe-left))}.concept-menu__shell{gap:20px}.concept-menu__title{font-size:2.35rem;line-height:1.02}.concept-menu__intro{font-size:.96rem}.concept-menu__grid{grid-template-columns:minmax(0,1fr)}.concept-card{min-height:220px;padding:18px}.concept-card__title{font-size:1.45rem}.concept-card__description{min-height:auto;font-size:.92rem}}.project-loading{min-height:var(--app-viewport-height);display:grid;place-items:center;background:#edf2f3;color:#17211b;font-size:.95rem;font-weight:800}html{--app-safe-top: env(safe-area-inset-top, 0px);--app-safe-right: env(safe-area-inset-right, 0px);--app-safe-bottom: env(safe-area-inset-bottom, 0px);--app-safe-left: env(safe-area-inset-left, 0px);--app-viewport-height: 100vh}@supports (height: 100dvh){html{--app-viewport-height: 100dvh}}html,body,#root{margin:0;min-height:100%}body{font-family:IBM Plex Sans,Segoe UI,sans-serif;background:#d8dfd2}main{min-height:var(--app-viewport-height)}*{box-sizing:border-box}.map-mode-toggle{position:absolute;top:calc(20px + var(--app-safe-top));left:calc(20px + var(--app-safe-left));z-index:3;border:0;border-radius:999px;padding:12px 16px;background:#f6f3ebeb;color:#1b2b17;font:inherit;font-weight:700;box-shadow:0 10px 30px #22311b24;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-mode-toggle--active{background:#22492b;color:#f6f3eb}.demo-panel{position:absolute;top:calc(14px + var(--app-safe-top));left:calc(20px + var(--app-safe-left));z-index:2;width:min(420px,calc(100vw - 40px - var(--app-safe-left) - var(--app-safe-right)));padding:20px;border:1px solid rgba(16,36,20,.18);border-radius:24px;background:linear-gradient(180deg,#f6f3ebf5,#e8ede0eb);box-shadow:0 20px 55px #22311b2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.demo-panel--anchored{width:min(320px,calc(100vw - 32px - var(--app-safe-left) - var(--app-safe-right)))}.demo-panel__close{position:absolute;top:8px;right:8px;display:grid;place-items:center;width:32px;height:32px;border:0;border-radius:999px;background:#22492b1a;color:#24301d;font-size:1.25rem;line-height:0;cursor:pointer}.demo-panel:before{content:"";display:none}.demo-panel__eyebrow{margin-bottom:8px;padding-right:40px;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#516144}.demo-panel__title{margin:0 0 8px;font-size:1.75rem;line-height:1.05;color:#162114}.demo-panel__body,.demo-panel__status,.demo-panel__warning,.demo-panel__error,.demo-panel__placeholder{color:#34412e}.demo-panel__body{margin:0 0 12px;line-height:1.45}.demo-panel__status{margin-bottom:16px;padding:10px 12px;border-radius:14px;background:#5c74491f;font-size:.95rem}.demo-panel__form{display:grid;gap:14px}.demo-panel__field{display:grid;gap:8px;font-size:.95rem;color:#24301d}.demo-panel__field textarea,.demo-panel__field input[type=file]{width:100%;padding:12px;border:1px solid rgba(31,47,23,.16);border-radius:14px;background:#ffffffbf;font:inherit}.demo-panel__field textarea{resize:vertical;min-height:88px}.demo-panel__preview,.demo-panel__placeholder{width:100%;min-height:180px;border-radius:18px}.demo-panel__preview{display:block;object-fit:cover;border:1px solid rgba(31,47,23,.16)}.demo-panel__placeholder{display:grid;place-items:center;padding:20px;border:1px dashed rgba(31,47,23,.3);background:#ffffff8c;text-align:center}.demo-panel__button{border:1px solid rgba(34,73,43,.18);border-radius:999px;padding:10px 14px;min-height:36px;background:#f7f4ebf5;color:#21492b;font:inherit;font-size:.78rem;font-weight:700;letter-spacing:.02em;cursor:pointer}.demo-panel__button:disabled{opacity:.7;cursor:wait}.demo-panel__button--secondary{background:#22492b1f;color:#22492b;border:1px solid rgba(34,73,43,.18)}.demo-panel__slider-field{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;font-size:.88rem;color:#516144}.demo-panel__slider-field input[type=range]{width:100%;accent-color:#22492b}.demo-panel__results{margin-top:18px;display:grid;gap:12px}.demo-panel__actions{margin-top:14px;display:flex;justify-content:flex-end}.demo-panel__meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.88rem;color:#516144}.demo-panel__warning,.demo-panel__error{margin-top:14px;padding:12px;border-radius:14px;font-size:.92rem}.demo-panel__warning{background:#a7741e1f}.demo-panel__error{background:#a222221f}.demo-panel__bars{display:grid;gap:10px}.demo-panel__debug{margin-top:14px;padding:12px;border-radius:14px;background:#22492b14}.demo-panel__debug-grid{display:grid;grid-template-columns:1fr auto;gap:6px 12px;margin-top:10px;font-size:.88rem;color:#34412e}.demo-panel__debug-scores{margin-top:10px;font-size:.84rem;color:#516144}.demo-panel__bar-row{display:grid;gap:6px}.demo-panel__bar-label{display:flex;justify-content:space-between;gap:12px;font-size:.92rem;color:#24301d}.demo-panel__bar-track{overflow:hidden;height:10px;border-radius:999px;background:#22492b1f}.demo-panel__bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#4d8b55,#214b2e)}@media (max-width: 720px){.map-mode-toggle{top:14px;left:14px;padding:11px 14px;font-size:.94rem}.demo-panel{top:auto;right:0;bottom:0;left:0;width:auto;max-height:min(68vh,560px);overflow-y:auto;padding:12px 14px calc(14px + env(safe-area-inset-bottom));border-right:0;border-bottom:0;border-left:0;border-radius:22px 22px 0 0;box-shadow:0 -14px 32px #22311b29}.demo-panel--anchored{right:0;left:0;width:auto}.demo-panel:before{display:block;width:44px;height:5px;margin:0 auto 10px;border-radius:999px;background:#24301d2e}.demo-panel__eyebrow{margin-bottom:4px;padding-right:34px;font-size:.66rem}.demo-panel__title{margin-bottom:6px;font-size:1.2rem;line-height:1.1}.demo-panel__body{margin-bottom:10px;font-size:.92rem;line-height:1.35}.demo-panel__status{margin-bottom:12px;padding:8px 10px;font-size:.84rem}.demo-panel__form{gap:10px}.demo-panel__field{gap:6px;font-size:.9rem}.demo-panel__field textarea{min-height:72px;padding:10px 12px}.demo-panel__preview,.demo-panel__placeholder{min-height:120px;border-radius:14px}.demo-panel__placeholder{padding:14px;font-size:.9rem}.demo-panel__button{position:sticky;bottom:0;padding:13px 16px;box-shadow:0 8px 18px #22492b29}.demo-panel__results{margin-top:14px;gap:10px}.demo-panel__warning,.demo-panel__error{margin-top:10px;padding:10px 12px;font-size:.88rem}.demo-panel__bar-label{font-size:.88rem}.demo-panel__bar-track{height:9px}}
