:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;color:#0f172a;background:#f8fafc;--lobster: #dc2626}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column;padding:0 1rem 4.75rem}.app-shell__header{padding:1rem .5rem .75rem;border-bottom:1px solid #e2e8f0;max-width:34rem;margin:0 auto;width:100%}.app-shell__brand{display:flex;align-items:center;justify-content:space-between;width:100%}.app-shell__brand-text{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.app-shell__logo{width:4rem;height:4rem;align-self:stretch;border-radius:.5rem;object-fit:contain}.app-shell__header h1{margin:0;font-size:1.5rem}.app-shell__header p{margin:.35rem 0 0;color:#475569;font-size:.92rem}.app-shell__content{flex:1;max-width:34rem;margin:0 auto;width:100%}.bottom-nav{position:fixed;left:0;right:0;bottom:.75rem;margin:0 auto;max-width:36rem;padding:0 .75rem}.bottom-nav__list{list-style:none;margin:0;padding:.35rem;display:grid;grid-template-columns:repeat(3,1fr);background:#fff;border-radius:999px;border:1px solid #cbd5e1}.bottom-nav__link{display:block;width:100%;text-align:center;text-decoration:none;color:#334155;padding:.75rem .25rem;border-radius:999px;font-size:.95rem;font-weight:600}.bottom-nav__link.active{background:#0f172a;color:#fff}section{padding:1rem .25rem 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.card{border:1px solid #cbd5e1;border-radius:.75rem;padding:1rem;background:#fff;margin:1rem 0}.card--primary{width:100%;background:#0f172a;color:#fff;border-color:#0f172a;border-radius:.75rem;padding:.9rem 1rem;font-size:1rem;font-weight:700}.card--secondary{width:100%;background:#e2e8f0;color:#0f172a;border-color:#cbd5e1;border-radius:.75rem;padding:.65rem .9rem;font-size:.95rem;font-weight:600}.config-form{display:grid;gap:.5rem;margin:.7rem 0 0}.config-section{margin-top:1rem;display:grid;gap:.5rem}.form-field{display:grid;gap:.5rem;font-weight:600;color:#334155}.form-field input,.form-field select{border:1px solid #cbd5e1;border-radius:.65rem;padding:.6rem .75rem;font:inherit}.form-field input{min-width:0}.form-actions{display:grid;gap:.6rem}.saved-places{margin-top:1rem;display:grid;gap:.5rem}.saved-places__list{margin:.7rem 0 0;list-style:none;padding:0;display:grid}.saved-place{padding:.85rem 0;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:.75rem;justify-content:space-between}.saved-place:first-child{border-top:1px solid #e2e8f0}.saved-place__content{display:grid;gap:.18rem;min-width:0}.saved-place__content p{margin:0}.saved-place__name{color:#0f172a;font-size:1rem;font-weight:700;line-height:1.25}.saved-place__address{color:#475569;font-size:.92rem;line-height:1.35;overflow-wrap:anywhere}.saved-place__coordinates{color:#64748b;font-size:.82rem;line-height:1.3}.saved-place__actions{display:flex;gap:.5rem;align-items:center}.saved-place__actions--row{flex:0 0 auto;justify-content:flex-end}.saved-place__editor-actions{justify-content:flex-end}.saved-place__icon-btn{border:1px solid transparent;color:#475569;background:transparent;border-radius:.55rem;width:2rem;height:2rem;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.saved-place__icon-btn:hover{color:#0f172a;background:#e2e8f0}.saved-place__editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;align-items:center;justify-items:center;padding:1rem;z-index:30}.saved-place__editor{width:min(100%,28rem);max-height:90vh;overflow-y:auto;display:grid;gap:.6rem}.saved-places__coords{display:grid;gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr))}.saved-places__coords .form-field{margin:0}.saved-places__form{display:grid;gap:.5rem;border:1px solid #cbd5e1;border-radius:.75rem;padding:.8rem;margin-top:.4rem}.saved-places__subheading{margin:0;font-size:1rem;text-align:center}.required-marker{color:var(--lobster)}.form-note--error{color:#dc2626}.form-note{margin:.8rem 0 0;color:#475569;font-size:.9rem}.settings-summary{margin:.4rem 0;display:grid;gap:.7rem}.settings-title{margin:0;font-size:1.02rem;line-height:1.3}.settings-summary dt{color:#475569}.settings-summary dd{margin:.25rem 0 0}.list{margin:1rem 0 0;padding-left:1.25rem}.list li+li{margin-top:.5rem}.capability-matrix__viewport{margin-top:.75rem;overflow-x:auto}.capability-matrix{min-width:980px;border-collapse:separate;border-spacing:0;width:100%}.capability-row{display:grid;grid-template-columns:minmax(10rem,1.35fr) repeat(6,minmax(10rem,1fr));padding:0}.capability-row>div{border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;padding:.6rem .75rem;font-size:.92rem;line-height:1.3;min-height:100%}.capability-row>div:first-child{position:sticky;left:0;z-index:2;background:#fff}.capability-row>div:last-child{border-right:0}.capability-row:last-child>div{border-bottom:0}.capability-header{position:sticky;top:0;background:#e2e8f0;font-weight:700;z-index:3}.capability-header>div{background:#e2e8f0}.capability-header>div:first-child{position:sticky;left:0;z-index:4}.provider-name{font-weight:700;color:#0f172a}.matrix-note{margin:.5rem 0 0;color:#475569;font-size:.9rem}.capability-cell{display:flex;align-items:center;justify-content:center;font-size:1.2rem}.matrix-legend{margin-top:.6rem;display:flex;flex-wrap:wrap;gap:.5rem .8rem;color:#334155;font-size:.86rem}.matrix-legend-item{display:inline-flex;align-items:center;gap:.26rem}
