
.crp-shell{
    --crp-bg:#efe9dc;
    --crp-surface:rgba(255,255,255,.52);
    --crp-text:#2f3136;
    --crp-muted:#66758b;
    --crp-accent:#0d72d9;
    --crp-shadow:0 18px 50px rgba(28,42,59,.07);
    max-width:1240px;
    margin:0 auto;
    padding:42px 24px 80px;
    color:var(--crp-text);
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
.crp-header{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(300px,.85fr);
    gap:28px;
    align-items:end;
    margin-bottom:26px;
}
.crp-kicker{
    font-size:14px;
    font-weight:700;
    margin-bottom:12px;
}
.crp-header h2{
    margin:0;
    font-size:clamp(2rem,3.6vw,3.2rem);
    line-height:1.02;
    letter-spacing:-.03em;
}
.crp-intro{
    color:var(--crp-muted);
    font-size:1.06rem;
    line-height:1.8;
}
.crp-grid{
    display:grid;
    grid-template-columns:340px minmax(0,1fr);
    gap:26px;
}
.crp-panel,
.crp-results{
    background:var(--crp-surface);
    border-radius:28px;
    box-shadow:var(--crp-shadow);
    border:1px solid rgba(255,255,255,.45);
    backdrop-filter:blur(10px);
}
.crp-panel{
    padding:24px;
    align-self:start;
    position:sticky;
    top:20px;
}
.crp-field{
    margin-bottom:18px;
}
.crp-field label{
    display:block;
    font-weight:700;
    margin-bottom:8px;
}
.crp-field select,
.crp-share-actions input{
    width:100%;
    min-height:48px;
    border:1px solid rgba(47,49,54,.1);
    border-radius:16px;
    padding:10px 14px;
    background:#fff;
    font:inherit;
}
.crp-actions{
    margin-top:8px;
}
.crp-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:0 18px;
    border:none;
    border-radius:999px;
    background:var(--crp-accent);
    color:#fff;
    text-decoration:none;
    font-weight:700;
    cursor:pointer;
    box-shadow:0 12px 30px rgba(13,114,217,.22);
}
.crp-btn-secondary{
    background:#fff;
    color:var(--crp-text);
    box-shadow:none;
    border:1px solid rgba(47,49,54,.1);
}
.crp-note{
    margin-top:18px;
    color:var(--crp-muted);
    line-height:1.7;
    font-size:.95rem;
}
.crp-results{
    padding:24px;
}
.crp-status{
    color:var(--crp-muted);
    margin-bottom:18px;
}
.crp-summary{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
    margin-bottom:20px;
}
.crp-summary-card{
    background:#fff;
    border-radius:18px;
    padding:16px;
    box-shadow:var(--crp-shadow);
}
.crp-summary-card strong{
    display:block;
    font-size:1.3rem;
}
.crp-summary-card span{
    color:var(--crp-muted);
}
.crp-route{
    display:grid;
    gap:16px;
}
.crp-stop{
    display:grid;
    grid-template-columns:56px minmax(0,1fr);
    gap:16px;
    background:#fff;
    border-radius:22px;
    padding:18px;
    box-shadow:var(--crp-shadow);
}
.crp-stop-no{
    width:56px;
    height:56px;
    border-radius:999px;
    background:rgba(13,114,217,.08);
    color:var(--crp-accent);
    display:grid;
    place-items:center;
    font-weight:800;
    font-size:1.15rem;
}
.crp-stop-top{
    display:grid;
    grid-template-columns:120px minmax(0,1fr);
    gap:16px;
    align-items:start;
}
.crp-stop-top img{
    width:120px;
    height:120px;
    object-fit:cover;
    border-radius:18px;
}
.crp-stop-top h3{
    margin:0 0 8px;
    font-size:1.35rem;
    line-height:1.2;
}
.crp-stop-top p{
    margin:10px 0 0;
    color:var(--crp-muted);
    line-height:1.7;
}
.crp-address{
    font-weight:700;
    color:#44556d;
}
.crp-stop-meta{
    display:flex;
    justify-content:space-between;
    gap:16px;
    margin-top:14px;
    color:var(--crp-muted);
    font-size:.95rem;
}
.crp-stop-meta a{
    color:var(--crp-accent);
    font-weight:700;
    text-decoration:none;
}
.crp-share{
    margin-top:22px;
    padding-top:22px;
    border-top:1px solid rgba(47,49,54,.08);
}
.crp-share-head h3{
    margin:0 0 14px;
    font-size:1.35rem;
}
.crp-share-grid{
    display:grid;
    grid-template-columns:220px minmax(0,1fr);
    gap:22px;
    align-items:start;
}
.crp-qr-wrap{
    background:#fff;
    border-radius:20px;
    padding:18px;
    box-shadow:var(--crp-shadow);
    display:grid;
    place-items:center;
}
.crp-share-actions{
    display:grid;
    gap:12px;
}
@media (max-width:980px){
    .crp-header,
    .crp-grid,
    .crp-summary,
    .crp-share-grid,
    .crp-stop-top,
    .crp-stop{
        grid-template-columns:1fr;
    }
    .crp-panel{
        position:static;
    }
}

.crp-picker-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.crp-chip-btn{min-height:38px;padding:0 12px;border-radius:999px;border:1px solid rgba(47,49,54,.1);background:#fff;cursor:pointer;font:inherit;font-weight:600}
.crp-monument-list{max-height:320px;overflow:auto;display:grid;gap:10px;padding-right:4px}
.crp-monument-option{display:block;background:#fff;border:1px solid rgba(47,49,54,.08);border-radius:16px;padding:10px;cursor:pointer}
.crp-monument-option input{margin-right:10px;margin-top:8px}
.crp-monument-option-body{display:grid;grid-template-columns:54px minmax(0,1fr);gap:10px;align-items:center}
.crp-monument-option-body img{width:54px;height:54px;object-fit:cover;border-radius:12px}
.crp-monument-option-body strong{display:block;line-height:1.3}
.crp-monument-option-body small{display:block;margin-top:4px;color:var(--crp-muted)}
.crp-mini-status{color:var(--crp-muted);font-size:.95rem;line-height:1.6}
.crp-map{height:420px;border-radius:24px;overflow:hidden;box-shadow:var(--crp-shadow);margin-bottom:20px}
.crp-map-popup img{width:100%;height:90px;object-fit:cover;border-radius:10px;display:block;margin-bottom:8px}
.crp-map-popup{width:180px;font-size:.95rem}


/* v1.2.0 fixes */
.crp-chip-btn,
.crp-btn-secondary{
    color: var(--crp-text) !important;
}
.crp-chip-btn{
    background:#fff;
}
.crp-btn-secondary{
    background:#fff !important;
    border:1px solid rgba(47,49,54,.12);
}
.crp-monument-option input{
    accent-color: var(--crp-accent);
}
.crp-map{
    height:460px;
}
.leaflet-container{
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}


/* v1.3.0 routed map styling */
.crp-map .leaflet-routing-container{
    display:none !important;
}


/* v1.4.0 routing fix */
.crp-map .leaflet-routing-container{
    display:none !important;
}


/* v1.9.0 premium PDF release */


/* v2.2.0 numbered markers */
.crp-numbered-pin-wrap{
    background: transparent;
    border: none;
}
.crp-numbered-pin{
    width: 34px;
    height: 34px;
    border-radius: 999px 999px 999px 0;
    transform: rotate(-45deg);
    background: #0d72d9;
    border: 3px solid #fff;
    box-shadow: 0 8px 18px rgba(13,114,217,.28);
    position: relative;
}
.crp-numbered-pin span{
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: rotate(45deg);
    color: #fff;
    font-weight: 800;
    font-size: 12px;
}
