/* DATEI: /assets/css/app.css */
:root{--bg:#f7f4ef;--bg2:#efe8dc;--card:#fffdfb;--ink:#1f2430;--muted:#697180;--line:#e5ded4;--brand:#8A1538;--brand2:#B21E4B;--brand3:#D95D7F;--danger:#b42318;--ok:#147a3f;--soon:#fff2c7;--shadow:0 22px 60px rgba(68,22,36,.13);--soft:0 10px 30px rgba(20,24,32,.08);--radius:26px}*{box-sizing:border-box}html,body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,#fff7f1 0,#f7f4ef 42%,#efe8dc 100%);color:var(--ink)}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit}.container{max-width:1260px;margin:0 auto;padding:24px}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;background:rgba(255,253,251,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(138,21,56,.12)}.brand{display:flex;align-items:center;gap:10px}.brand-dot{width:15px;height:15px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand3));box-shadow:0 0 0 6px rgba(138,21,56,.08)}.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.user-pill,.top-select{padding:8px 12px;border-radius:99px;background:#fff;border:1px solid var(--line);box-shadow:var(--soft)}.top-select{min-width:150px}.page-title{margin:10px 0 22px}.page-title h1{font-size:clamp(30px,4vw,48px);line-height:1.05;margin:0;color:#21151a;letter-spacing:-.04em}.page-title p,.muted{color:var(--muted)}.grid{display:grid;gap:18px}.cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.two{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.card,.module-card,.auth-card{background:rgba(255,253,251,.92);border:1px solid rgba(138,21,56,.10);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.elevated-form{background:linear-gradient(180deg,#fff,#fff8fb)}.compact{padding:14px 18px}.module-card{display:flex;flex-direction:column;min-height:218px;transition:transform .18s ease, box-shadow .18s ease}.module-card:hover{transform:translateY(-3px);box-shadow:0 28px 70px rgba(138,21,56,.18)}.module-card .icon{font-size:34px;width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,#fff0f5,#fff);box-shadow:inset 0 0 0 1px rgba(138,21,56,.08)}.module-card h2{margin:14px 0 6px}.module-card p{color:var(--muted);flex:1}.btn,.ghost,.danger,.primary{border:0;border-radius:15px;padding:11px 16px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800}.btn{background:linear-gradient(135deg,var(--brand),var(--brand2));color:white;box-shadow:0 10px 20px rgba(138,21,56,.22)}.primary{background:linear-gradient(135deg,var(--brand),var(--brand2));color:white;box-shadow:0 12px 28px rgba(138,21,56,.28)}.ghost{background:#fff;border:1px solid rgba(138,21,56,.16);color:var(--brand)}.danger{background:#fee4e2;color:#912018}.small{padding:8px 11px;font-size:14px}.mini{border:0;border-radius:10px;padding:3px 8px;background:#fff;color:var(--danger)}.wide{width:100%}.inline-form{display:inline}.stack-form{display:grid;gap:14px}.row{display:flex;align-items:center}.between{justify-content:space-between}.gap{gap:10px;flex-wrap:wrap}.center{text-align:center}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.section-head{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;flex-wrap:wrap}label{display:grid;gap:7px;font-weight:700}input,select,textarea{width:100%;border:1px solid #ded6cd;border-radius:15px;background:#fff;padding:12px;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(138,21,56,.10)}textarea{resize:vertical}.check{display:flex;align-items:center;gap:10px}.check input{width:auto}.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;margin:10px 0}.detail-card{border:1px solid rgba(138,21,56,.12);border-radius:20px;background:#fff;padding:16px;margin:12px 0;box-shadow:var(--soft)}.detail-card summary{cursor:pointer}.settings-box{border:1px solid rgba(138,21,56,.12);border-radius:22px;padding:18px;margin:16px 0;background:#fff}.flash{padding:12px 14px;border-radius:14px;margin:12px 0;font-weight:800}.flash-ok{background:#dcfae6;color:#05603a}.flash-error{background:#fee4e2;color:#912018}.table-wrap{overflow:auto;border-radius:18px;border:1px solid var(--line);background:#fff}table{width:100%;border-collapse:collapse;background:#fff}th,td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}th{background:#fff3f7}.family-calendar{min-width:900px;font-family:"Arial Narrow",Arial,sans-serif;border:2px solid #2a2a2a}.family-calendar th,.family-calendar td{border-right:1px solid #333;border-bottom:1px solid #cfcfcf;padding:4px 6px}.family-calendar thead th{background:#fafafa;color:#111;text-align:center}.family-calendar .date-col{width:170px;min-width:150px;background:#fff}.family-calendar tbody .date-col{font-weight:500}.family-calendar .date-col span{display:block}.family-calendar .date-col small{display:block;color:#333;font-size:12px}.family-calendar tr.weekend-row .date-col{color:#b91c1c}.family-calendar td{min-width:130px;height:38px}.calendar-print-wrap{overflow:auto;border-radius:18px;background:white;box-shadow:var(--soft)}.calendar-toolbar{position:relative;z-index:1}.cal-chip{position:relative;margin:0 0 5px;padding:6px 24px 6px 8px;border-radius:10px;background:#ffe9f0;border:1px solid rgba(138,21,56,.14);font-size:13px}.cal-chip small{display:block;color:#5d6470}.type-shopping{background:#f0fff5}.type-task{background:#fff8db}.modal{border:0;border-radius:26px;padding:0;max-width:560px;width:calc(100vw - 28px);box-shadow:0 30px 90px rgba(0,0,0,.30);background:#fff}.modal::backdrop{background:rgba(30,20,25,.45);backdrop-filter:blur(5px)}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}.modal-head h2{margin:0}.modal-form{padding:20px}.overview-card{background:linear-gradient(135deg,#fff,#fff1f5)}.mini-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin:10px 0}.mini-overview>div{padding:14px;border-radius:18px;background:#fff;box-shadow:var(--soft)}.dashboard-feed p{background:#fff;border-radius:14px;padding:10px 12px}.big-result{font-size:clamp(34px,6vw,70px);font-weight:900;color:var(--brand)}.dice{display:inline-grid;place-items:center;width:110px;height:110px;border-radius:24px;background:#fff0f5;color:var(--brand);font-size:54px;font-weight:900}.privacy-map{position:relative;min-height:340px;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:linear-gradient(135deg,#eef7ff,#fff7fb)}.privacy-map:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:28px 28px}.map-marker{position:absolute;transform:translate(-50%,-50%);z-index:2}.map-marker span{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--brand);color:white;font-weight:900;box-shadow:0 8px 18px rgba(138,21,56,.35)}.note-readonly{white-space:pre-wrap;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}.public-page{background:#e7ebef}.unavailable-wrap{min-height:100vh;display:grid;place-items:center;padding:30px}.unavailable-card{position:relative;display:flex;align-items:center;gap:44px;max-width:970px;width:100%;padding:36px 42px;background:#eef2f5;border-radius:2px;box-shadow:0 6px 16px rgba(0,0,0,.08);border-top:1px solid #cbd3dc}.language-list p{display:grid;grid-template-columns:36px 1fr;gap:12px;margin:0 0 14px;color:#2f668f;line-height:1.28}.language-list span{font-size:25px}.stop-symbol{flex:0 0 112px;width:112px;height:112px;border-radius:50%;background:#ef3338;box-shadow:0 8px 18px rgba(239,51,56,.25);position:relative}.stop-symbol:before{content:"";position:absolute;left:22px;right:22px;top:50%;height:16px;background:white;border-radius:2px;transform:translateY(-50%)}.hidden-login-form{position:fixed;right:16px;top:16px;z-index:10}.hidden-login{width:24px;height:24px;border:0;border-radius:50%;background:rgba(100,110,120,.22);color:#fff;font-weight:800;line-height:24px;padding:0;font-size:14px;opacity:.55}.hidden-login:hover{opacity:.95;background:rgba(100,110,120,.42)}.login-page{min-height:100vh;background:radial-gradient(circle at top left,#ffe4ed,#f7f4ef 38%,#ece3d8)}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{max-width:520px;width:100%;margin:auto}.glass{background:rgba(255,253,251,.83);backdrop-filter:blur(22px)}.login-mark{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;font-size:28px;font-weight:900;margin:0 auto 14px}.auth-foot{display:flex;justify-content:center;margin-top:14px}.flag{border:1px solid var(--line);background:#fff;border-radius:12px;padding:7px 9px}.danger-zone{margin-top:10px}.manual-field{display:none}.hidden-resume{display:none}.tab-delete-row{margin-top:12px}.training-block{display:grid;gap:5px}.training-block input{padding:7px;font-size:13px}.meal-table textarea{min-width:140px}.backup-card .file-label{display:inline-flex}.import-form{gap:8px;align-items:center}
@media(max-width:760px){.container{padding:14px}.topbar{align-items:stretch;flex-direction:column;padding:10px 12px}.top-actions{justify-content:flex-start}.user-pill,.top-select{width:auto;max-width:100%}.page-title h1{font-size:32px}.cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.module-card{min-height:168px;padding:15px;border-radius:22px}.module-card .icon{width:44px;height:44px;font-size:26px}.module-card h2{font-size:16px}.module-card p{font-size:13px}.btn,.ghost,.danger,.primary{padding:10px 12px;border-radius:13px}.card{padding:16px;border-radius:22px}.form-grid{grid-template-columns:1fr}.unavailable-card{padding:24px;gap:20px}.stop-symbol{display:none}.language-list p{grid-template-columns:30px 1fr;font-size:14px}.family-calendar{font-size:12px;min-width:760px}.family-calendar .date-col{width:125px;min-width:125px}.family-calendar td{min-width:108px}.calendar-toolbar .between{align-items:flex-start}.modal{width:calc(100vw - 14px);border-radius:22px}.privacy-map{min-height:280px}}
@media(max-width:420px){.cards{grid-template-columns:1fr}.top-actions .flag{padding:6px 8px}.family-calendar{min-width:680px}.family-calendar td{min-width:95px}.module-card{min-height:auto}}

/* v1.2: OpenStreetMap-Livekarte ohne externe JavaScript-Bibliothek. */
.osm-map{position:relative;min-height:420px;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#eaf1f5;box-shadow:var(--soft);touch-action:pan-x pan-y}.osm-tiles{position:absolute;inset:0;overflow:hidden}.osm-tiles img{position:absolute;width:256px;height:256px;max-width:none;user-select:none;-webkit-user-drag:none}.osm-markers{position:absolute;inset:0;z-index:2}.osm-marker{position:absolute;transform:translate(-50%,-100%);z-index:3}.osm-marker span{display:grid;place-items:center;width:42px;height:42px;border-radius:50% 50% 50% 8px;transform:rotate(-45deg);background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;font-weight:900;box-shadow:0 12px 26px rgba(138,21,56,.35);border:3px solid #fff}.osm-marker span::first-letter{transform:rotate(45deg)}.osm-marker span{line-height:1}.osm-marker span{font-size:0}.osm-marker span:after{content:attr(data-initial);font-size:15px;transform:rotate(45deg)}.osm-empty{position:absolute;inset:auto 18px 18px 18px;z-index:4;background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:16px;padding:12px;color:var(--muted);text-align:center}.osm-attribution{position:absolute;right:8px;bottom:6px;z-index:4;background:rgba(255,255,255,.82);font-size:11px;padding:3px 7px;border-radius:9px;color:#4b5563}.gps-table-wrap{margin-top:14px}.action-col{width:120px;text-align:center}.tasks-table .action-col button{white-space:nowrap}
@media(max-width:760px){.osm-map{min-height:360px;border-radius:18px}.gps-table-wrap table{font-size:13px}.action-col{width:92px}.tasks-table .action-col button{padding:8px 9px;font-size:12px}}
.osm-marker span{font-size:15px}.osm-marker span:after{content:none}.osm-marker span b{display:block;transform:rotate(45deg);line-height:1}

/* v1.3: alte GPS-Livekarte und besser bedienbare GPS-Zoomsteuerung. */
.legacy-live-map{position:relative;min-height:460px;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#eaf1f5;box-shadow:var(--soft)}
.map-privacy-note{margin-top:10px;font-size:13px}.osm-controls{position:absolute;left:12px;top:12px;z-index:5;display:grid;gap:6px}.osm-controls button{width:42px;height:42px;border:0;border-radius:12px;background:#fff;color:var(--brand);font-size:24px;font-weight:900;box-shadow:0 8px 20px rgba(0,0,0,.16)}.meal-actions{margin-top:14px}.meal-table textarea{min-height:76px}
@media(max-width:760px){.legacy-live-map{min-height:380px;border-radius:18px}.meal-table textarea{min-width:118px;min-height:70px}.meal-actions{align-items:stretch}.meal-actions button{flex:1}}

/* v1.4: deutlich bessere GPS-Karte für Mobile/Desktop.
   - Alte Kartenvariante nutzte eigene Zoom-/Pan-/Fullscreen-Bedienelemente.
   - OpenStreetMap-Fallback ist jetzt als eigene Slippy-Map mit Drag, Wheel-Zoom,
     Verlaufslinien und Marker-Liste umgesetzt. */
.gps-provider-note{margin-top:14px;padding:14px 16px;border:1px solid rgba(138,21,56,.18);border-radius:18px;background:linear-gradient(135deg,#fff1f6,#fffdfb);color:#43202c;line-height:1.45}.map-actionbar{display:flex;gap:10px;align-items:center;justify-content:flex-end;margin:8px 0 14px;flex-wrap:wrap}.live-map-shell{min-height:560px;border-radius:26px;border:1px solid rgba(138,21,56,.16);box-shadow:0 24px 70px rgba(68,22,36,.16);overflow:hidden}.legacy-live-map{min-height:560px}.osm-map{position:relative;background:#dbeaf2;touch-action:none;cursor:grab;user-select:none}.osm-map.is-dragging{cursor:grabbing}.osm-tiles{position:absolute;inset:0;overflow:hidden;background:#dbeaf2}.osm-tiles img{position:absolute;width:256px;height:256px;max-width:none;user-select:none;-webkit-user-drag:none}.osm-paths{position:absolute;inset:0;width:100%;height:100%;z-index:2;pointer-events:none}.osm-paths polyline{fill:none;stroke:var(--brand);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;opacity:.72;filter:drop-shadow(0 2px 3px rgba(255,255,255,.65))}.osm-markers{position:absolute;inset:0;z-index:3;pointer-events:none}.osm-marker{position:absolute;transform:translate(-50%,-100%);z-index:4;filter:drop-shadow(0 14px 18px rgba(80,20,42,.25))}.osm-marker-pin{display:grid;place-items:center;width:46px;height:46px;border-radius:50% 50% 50% 10px;transform:rotate(-45deg);background:linear-gradient(135deg,var(--brand),var(--brand2));border:3px solid #fff;color:#fff;font-weight:900}.osm-marker-pin b{transform:rotate(45deg);font-size:15px;line-height:1}.osm-marker-label{position:absolute;left:50%;top:50px;transform:translateX(-50%);padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.94);border:1px solid rgba(138,21,56,.15);box-shadow:0 8px 20px rgba(0,0,0,.14);font-size:12px;font-weight:800;color:#281820;white-space:nowrap}.osm-controls{position:absolute;left:14px;top:14px;z-index:7;display:grid;gap:8px}.osm-controls button{width:48px;height:48px;border:0;border-radius:16px;background:rgba(255,255,255,.96);color:var(--brand);font-size:26px;font-weight:900;box-shadow:0 10px 24px rgba(0,0,0,.18)}.osm-controls button:active{transform:scale(.96)}.osm-hint{position:absolute;left:74px;top:17px;z-index:6;background:rgba(255,255,255,.92);border:1px solid rgba(138,21,56,.12);border-radius:999px;padding:9px 13px;color:#4b5563;font-size:13px;box-shadow:0 8px 20px rgba(0,0,0,.12)}.osm-empty{position:absolute;left:50%;top:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);z-index:8;background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:18px;padding:14px 18px;color:var(--muted);text-align:center;box-shadow:var(--soft)}.osm-attribution{position:absolute;right:8px;bottom:8px;z-index:7;background:rgba(255,255,255,.86);font-size:11px;padding:4px 8px;border-radius:10px;color:#4b5563}.gps-table-wrap{margin-top:16px}.gps-table-wrap td p{margin:.2rem 0}.gps-table-wrap td:first-child{font-weight:800;color:#321621}@media(max-width:760px){.map-actionbar{justify-content:stretch}.map-actionbar button{flex:1}.live-map-shell,.legacy-live-map,.osm-map{min-height:62vh;border-radius:22px}.osm-controls button{width:46px;height:46px}.osm-hint{left:12px;right:12px;top:auto;bottom:38px;text-align:center;border-radius:16px;font-size:12px}.osm-marker-label{display:none}.gps-table-wrap{font-size:13px}}
/* v1.4 specificity corrections: override older generic .osm-marker span rules. */
.osm-marker .osm-marker-pin{display:grid;place-items:center;width:46px;height:46px;border-radius:50% 50% 50% 10px;transform:rotate(-45deg);background:linear-gradient(135deg,var(--brand),var(--brand2));border:3px solid #fff;color:#fff;font-weight:900;line-height:1;font-size:15px}.osm-marker .osm-marker-pin:after{content:none}.osm-marker .osm-marker-pin b{display:block;transform:rotate(45deg);font-size:15px;line-height:1}.osm-marker .osm-marker-label{display:block;position:absolute;left:50%;top:50px;transform:translateX(-50%);width:auto;height:auto;padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.94);border:1px solid rgba(138,21,56,.15);box-shadow:0 8px 20px rgba(0,0,0,.14);font-size:12px;font-weight:800;color:#281820;white-space:nowrap;line-height:1.1}.osm-marker .osm-marker-label:after{content:none}@media(max-width:760px){.osm-marker .osm-marker-label{display:none}}


/* v1.5: GPS-Karte mit echtem Leaflet + OpenStreetMap wie im Fahrer-Modul. */
.leaflet-live-map{position:relative;min-height:560px;border-radius:26px;border:1px solid rgba(138,21,56,.16);box-shadow:0 24px 70px rgba(68,22,36,.16);overflow:hidden;background:#dbeaf2}.leaflet-live-map .leaflet-control-zoom a{color:var(--brand);font-weight:900}.leaflet-live-map .leaflet-control-attribution{font-size:11px;background:rgba(255,255,255,.86);border-radius:10px;margin:0 8px 8px 0;padding:4px 8px}.pf-leaflet-marker-wrap{background:transparent;border:0}.pf-leaflet-marker{position:absolute;left:50%;top:0;width:46px;height:46px;transform:translateX(-50%) rotate(-45deg);border-radius:50% 50% 50% 10px;background:linear-gradient(135deg,var(--brand),var(--brand2));border:3px solid #fff;box-shadow:0 14px 24px rgba(80,20,42,.28);display:grid;place-items:center}.pf-leaflet-marker span{display:block;transform:rotate(45deg);color:#fff;font-weight:900;font-size:15px;line-height:1}.pf-leaflet-label{position:absolute;top:50px;left:50%;transform:translateX(-50%);background:rgba(255,255,255,.96);border:1px solid rgba(138,21,56,.15);border-radius:999px;padding:5px 9px;color:#281820;font-size:12px;font-weight:800;white-space:nowrap;box-shadow:0 8px 20px rgba(0,0,0,.14)}.map-error{display:grid;place-items:center;height:100%;min-height:360px;padding:22px;text-align:center;color:var(--muted);background:#fff;border-radius:22px}.leaflet-popup-content strong{color:var(--brand)}@media(max-width:760px){.leaflet-live-map{min-height:62vh;border-radius:22px}.pf-leaflet-label{display:none}.leaflet-live-map .leaflet-control-zoom a{width:42px;height:42px;line-height:42px;font-size:24px}.leaflet-live-map .leaflet-control-zoom{border:0;box-shadow:0 10px 24px rgba(0,0,0,.18)}}

/* v1.6: Mehrsprachigkeit, Smartphone-Optimierung, Cookie-Dialog, rote Notiz-Badges. */
.flag.active{outline:2px solid rgba(138,21,56,.35);background:#fff1f6}.login-lang-row{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.auth-links{display:flex;justify-content:center;margin-top:12px}.badge-red{display:inline-grid;place-items:center;min-width:24px;height:24px;margin-left:8px;padding:0 7px;border-radius:999px;background:#dc2626;color:#fff;font-size:12px;font-weight:900;vertical-align:middle;box-shadow:0 8px 18px rgba(220,38,38,.25)}.language-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.compact-table table{font-size:14px}.topbar{position:sticky;top:0;z-index:30;backdrop-filter:blur(18px);background:rgba(255,250,247,.92)}.top-actions{max-width:100%;overflow-x:auto;scrollbar-width:thin}.top-select{max-width:220px}.module-card h2{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.settings-box{border:1px solid rgba(138,21,56,.14);border-radius:22px;padding:18px;background:rgba(255,255,255,.72);box-shadow:0 14px 40px rgba(44,18,28,.06)}
@media(max-width:860px){body{font-size:15px}.container{padding:16px 10px 80px}.topbar{align-items:flex-start;gap:10px;padding:10px}.brand{min-width:100%;justify-content:space-between}.top-actions{width:100%;justify-content:flex-start;padding-bottom:4px}.top-select{max-width:160px}.page-title h1{font-size:30px;line-height:1.05}.page-title p{font-size:14px}.grid.two{grid-template-columns:1fr}.mini-overview{grid-template-columns:1fr}.table-wrap{margin-left:-6px;margin-right:-6px;padding:0 6px;overflow:auto;-webkit-overflow-scrolling:touch}.dynamic-table input,.dynamic-table textarea,table input,table select,table textarea{min-height:44px;font-size:16px}.modal::backdrop{background:rgba(22,12,18,.58);backdrop-filter:blur(4px)}.modal{max-height:calc(100dvh - 18px);height:auto;overflow:auto;padding:16px}.modal .form-grid{grid-template-columns:1fr}.row.between{align-items:stretch}.row.gap{gap:8px}.calendar-toolbar .row{width:100%}.calendar-toolbar .row .inline-form{flex:1}.calendar-toolbar .row .inline-form button{width:100%}.family-calendar{font-size:12px}.family-calendar th,.family-calendar td{padding:7px 6px}.cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.module-card{padding:14px;border-radius:20px}.module-card p{display:none}.module-card .icon{width:42px;height:42px}.module-card h2{font-size:15px}.module-card .btn{width:100%}.leaflet-live-map{min-height:65dvh}.auth-card{width:min(100%,460px);padding:20px}.login-wrap{padding:18px 10px;align-items:flex-start}.settings-box{padding:14px}}
@media(max-width:430px){.cards{grid-template-columns:1fr}.top-actions .ghost,.top-actions .danger,.top-actions .btn,.top-actions .primary{padding:8px 10px}.top-actions .flag{min-width:40px}.top-select{max-width:140px}.page-title h1{font-size:28px}.card{padding:14px}.family-calendar{min-width:720px}.modal{width:calc(100vw - 10px);border-radius:20px}.check-grid{grid-template-columns:1fr}.language-grid{grid-template-columns:1fr}}
