:root{font-family:Segoe UI,Trebuchet MS,Arial,sans-serif;--bg-base: #f2f8f5;--bg-top-a: #d8efe4;--bg-top-b: #e9f7e9;--text-main: #10231b;--text-sub: #4d6358;--card-bg: #ffffff;--card-border: #c8ddd2;--card-soft: #f8fcfa;--item-card-bg: #ebf5ef;--item-card-border: #bad5c6;--accent: #0f8c5a;--accent-2: #207f60;--danger: #be2f2f;--chip-bg: #e3f3eb;--chip-border: #b4d7c7;--chip-text: #1d5c45;--link: #136fdb}:root[data-theme=ocean]{--bg-base: #eef6fb;--bg-top-a: #d7e8f7;--bg-top-b: #dff6f5;--text-main: #0e2230;--text-sub: #4a6274;--card-bg: #ffffff;--card-border: #c4d7e6;--card-soft: #f7fbff;--item-card-bg: #eaf3fc;--item-card-border: #b9d0e4;--accent: #1a75b8;--accent-2: #2b6a96;--danger: #b53a45;--chip-bg: #e7f1fb;--chip-border: #b6d0ea;--chip-text: #1d4f74;--link: #1f5ecf}:root[data-theme=sand]{--bg-base: #faf5ea;--bg-top-a: #f3e4c9;--bg-top-b: #f7edd6;--text-main: #2f2417;--text-sub: #6b5a45;--card-bg: #fffdf7;--card-border: #e1d2b9;--card-soft: #fffaf0;--item-card-bg: #f7ecd8;--item-card-border: #dbc49f;--accent: #a06a2c;--accent-2: #8c5922;--danger: #b34a37;--chip-bg: #f8ead1;--chip-border: #e0c79f;--chip-text: #6e4a1e;--link: #915c1e}:root[data-mode=dark]{--bg-base: #121416;--bg-top-a: #1b2523;--bg-top-b: #1a2026;--text-main: #ecf2ef;--text-sub: #b4c3bc;--card-bg: #1a1f22;--card-border: #2f3b40;--card-soft: #1f2529;--item-card-bg: #273037;--item-card-border: #415059;--accent: #4ca97a;--accent-2: #3f8b65;--danger: #cf5b5b;--chip-bg: #223129;--chip-border: #355146;--chip-text: #b9e8cf;--link: #76b8ff}*{box-sizing:border-box}body{margin:0}.app-shell{min-height:100vh;color:var(--text-main);background:radial-gradient(circle at 10% 0%,var(--bg-top-a) 0%,transparent 30%),radial-gradient(circle at 90% 0%,var(--bg-top-b) 0%,transparent 30%),linear-gradient(180deg,color-mix(in srgb,var(--bg-base),#ffffff 18%) 0%,var(--bg-base) 100%)}.app-header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--card-bg),transparent 10%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--card-border);padding:clamp(8px,2vw,12px) clamp(10px,2.8vw,16px);display:flex;flex-direction:column;align-items:stretch;gap:8px}.header-top{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}.logo{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--accent);text-decoration:none;font-size:clamp(14px,2.8vw,18px);min-width:0;align-self:flex-start}.admin-links{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-left:auto}.header-family-btn{display:inline-flex;align-items:center;gap:6px;min-height:32px;padding:4px 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent),#ffffff 18%);background:linear-gradient(135deg,color-mix(in srgb,var(--accent),#ffffff 12%),color-mix(in srgb,var(--accent-2),#000000 8%));box-shadow:0 2px 8px color-mix(in srgb,var(--accent),transparent 72%);color:#fff;font-size:11px;font-weight:700;text-decoration:none;line-height:1}.header-family-btn:hover{text-decoration:none;filter:brightness(1.04)}.header-family-icon{font-size:14px;line-height:1}.brand-logo{width:clamp(36px,8vw,56px);height:clamp(36px,8vw,56px);object-fit:contain;flex:0 0 auto}.env-badge{display:inline-flex;align-items:center;justify-content:center;min-height:20px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.08em;line-height:1;border:1px solid transparent;white-space:nowrap}.env-badge-dev{color:#fff;background:linear-gradient(135deg,#e53935,#ff8f00);border-color:#b71c1c;box-shadow:0 2px 8px color-mix(in srgb,#e53935,transparent 65%)}.top-controls{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end;min-width:0;width:100%}.header-tip-row{width:100%;display:flex;justify-content:flex-start}.tip-toast{width:100%;border:1px solid color-mix(in srgb,var(--accent),var(--card-border) 60%);background:color-mix(in srgb,var(--chip-bg),var(--card-bg) 20%);border-radius:10px;padding:8px 10px;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.tip-toast.compact{padding:6px 8px;border-radius:9px}.tip-toast-main{min-width:0;display:flex;align-items:center;gap:8px}.tip-toast-icon{width:20px;height:20px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent),#ffffff 25%);color:var(--accent);background:color-mix(in srgb,var(--accent),#ffffff 90%);font-weight:800;font-size:12px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;line-height:1}.tip-toast-text{font-size:12px;color:var(--text-main);line-height:1.35}.tip-toast-actions{display:flex;align-items:center;gap:6px}.tip-toast-btn{min-height:26px;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent),var(--card-border) 45%);background:color-mix(in srgb,var(--accent),#ffffff 88%);color:var(--accent);font-size:11px;font-weight:700;padding:4px 8px;cursor:pointer}.tip-toast-btn.secondary{border-color:var(--card-border);background:color-mix(in srgb,var(--card-bg),var(--chip-bg) 30%);color:var(--text-sub)}.mode-toggle{display:inline-flex;align-items:center;gap:6px;font-size:clamp(11px,2.8vw,12px);color:var(--text-sub);white-space:nowrap}.top-controls select{min-width:90px}.app-main{width:min(100%,980px);margin:0 auto;padding:clamp(10px,2.8vw,16px) clamp(8px,2.5vw,12px) clamp(16px,4vw,24px)}.stack{display:grid;gap:clamp(8px,2vw,12px)}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;padding:clamp(10px,2.4vw,14px);overflow:hidden}.page-title-row{display:flex;align-items:center;gap:8px}.page-title-row h1{margin:0}.form{display:grid;grid-template-columns:1fr;gap:8px}.form-compact{display:grid;grid-template-columns:1fr 70px 140px auto;gap:6px;align-items:center}input,select,textarea,button{padding:10px 12px;border:1px solid var(--card-border);border-radius:10px;font-size:clamp(13px,3.2vw,14px);background:var(--card-soft);color:var(--text-main);min-height:40px;max-width:100%}button{background:var(--accent);color:#fff;border-color:var(--accent)}button.secondary{background:var(--accent-2);border-color:var(--accent-2)}button.danger{background:var(--danger);border-color:var(--danger);width:100px;min-width:100px}.btn-sm{padding:6px 9px;font-size:clamp(11px,2.8vw,12px);border-radius:8px;min-height:34px}.list{display:grid;gap:8px}.list-item{background:var(--item-card-bg);border:1px solid var(--item-card-border);border-radius:12px;padding:10px;display:grid;gap:8px;box-shadow:0 2px 10px color-mix(in srgb,var(--text-main),transparent 92%)}.item-main{display:flex;gap:10px;align-items:center;color:inherit;text-decoration:none;min-width:0}.item-title{font-weight:700;overflow-wrap:anywhere}.link{color:var(--link);text-decoration:none}.link:hover{text-decoration:underline}.item-sub{font-size:clamp(11px,2.9vw,12px);color:var(--text-sub);overflow-wrap:anywhere}.thumb{width:clamp(44px,14vw,56px);height:clamp(44px,14vw,56px);border-radius:10px;object-fit:cover;background:color-mix(in srgb,var(--card-soft),#ffffff 15%);border:1px solid var(--card-border);flex:0 0 auto}.thumb-empty{display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-sub)}.chip-list{display:flex;flex-wrap:wrap;gap:6px}.chip{border-radius:999px;background:var(--chip-bg);color:var(--chip-text);border:1px solid var(--chip-border);padding:6px 10px;font-size:12px}.row-actions{display:flex;gap:6px;flex-wrap:wrap}.family-member-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.family-member-actions{margin-left:auto;display:inline-flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}.family-summary-stack{gap:6px}.family-summary-card{transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.family-card-collapsed-clickable{cursor:pointer}.family-card-collapsed-clickable:hover{border-color:color-mix(in srgb,var(--accent),var(--card-border) 35%);box-shadow:0 4px 12px color-mix(in srgb,var(--accent),transparent 86%)}.family-card-collapsed-clickable:focus-visible{outline:2px solid color-mix(in srgb,var(--accent),#ffffff 20%);outline-offset:2px}.family-activity-list{display:grid;gap:5px}.family-activity-row{border:1px solid var(--chip-border);background:color-mix(in srgb,var(--chip-bg),#ffffff 24%);border-radius:10px;padding:6px 8px;display:grid;gap:2px}.family-chat-unread-pill{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:24px;padding:2px 8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--danger),#ffffff 35%);background:color-mix(in srgb,var(--danger),#ffffff 80%);color:color-mix(in srgb,var(--danger),#000000 18%);font-size:12px;font-weight:700}.family-chat-box{display:grid;gap:6px;border:1px solid var(--chip-border);background:color-mix(in srgb,var(--card-soft),#ffffff 10%);border-radius:10px;padding:7px}.family-chat-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.family-chat-feed{display:grid;gap:5px;max-height:220px;overflow:auto;padding:8px 6px 8px 4px;border-radius:10px;border:1px solid color-mix(in srgb,var(--chip-border),var(--card-border) 35%);background:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--accent),transparent 93%) 1px,transparent 0) 0 0 / 10px 10px,linear-gradient(180deg,color-mix(in srgb,var(--bg-base),var(--card-bg) 22%),color-mix(in srgb,var(--item-card-bg),var(--card-soft) 45%))}.family-chat-item{max-width:88%;border:1px solid color-mix(in srgb,var(--chip-border),var(--card-border) 42%);border-radius:14px;padding:6px 9px;display:grid;gap:3px;width:fit-content;box-shadow:0 1px 2px color-mix(in srgb,var(--text-main),transparent 88%)}.family-chat-item-own{margin-left:auto;margin-right:0;background:color-mix(in srgb,var(--accent),#ffffff 78%);border-color:color-mix(in srgb,var(--accent),var(--chip-border) 42%)}.family-chat-item-other{margin-right:auto;margin-left:0;background:color-mix(in srgb,var(--card-bg),#ffffff 10%);border-color:color-mix(in srgb,var(--card-border),var(--chip-border) 30%)}.family-chat-item-alt.family-chat-item-own{background:color-mix(in srgb,var(--accent),#ffffff 72%)}.family-chat-item-alt.family-chat-item-other{background:color-mix(in srgb,var(--card-soft),var(--card-bg) 35%)}.family-chat-meta{font-size:11px;color:color-mix(in srgb,var(--text-sub),var(--text-main) 14%);display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:0}.family-chat-sender{font-size:13.75px;font-weight:700;line-height:1.1;color:var(--text-main)}.family-chat-meta-sep,.family-chat-time{font-size:11px;color:color-mix(in srgb,var(--text-sub),var(--text-main) 14%)}.family-chat-text{font-size:13px;line-height:1.3;color:var(--text-main);overflow-wrap:anywhere}:root[data-mode=dark] .family-chat-feed{border-color:color-mix(in srgb,var(--chip-border),#000000 35%);background:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--accent),transparent 88%) 1px,transparent 0) 0 0 / 10px 10px,linear-gradient(180deg,color-mix(in srgb,var(--card-soft),#000000 18%),color-mix(in srgb,var(--item-card-bg),#000000 20%))}:root[data-mode=dark] .family-chat-item-own{background:color-mix(in srgb,var(--accent),#0b1511 68%);border-color:color-mix(in srgb,var(--accent),#31473d 45%)}:root[data-mode=dark] .family-chat-item-other{background:color-mix(in srgb,var(--card-bg),#000000 22%);border-color:color-mix(in srgb,var(--card-border),#000000 34%)}:root[data-mode=dark] .family-chat-item-alt.family-chat-item-own{background:color-mix(in srgb,var(--accent),#101a14 62%)}:root[data-mode=dark] .family-chat-item-alt.family-chat-item-other{background:color-mix(in srgb,var(--card-soft),#000000 24%)}:root[data-mode=dark] .family-chat-meta{color:color-mix(in srgb,var(--text-sub),#ffffff 22%)}:root[data-mode=dark] .family-chat-meta-sep,:root[data-mode=dark] .family-chat-time{color:color-mix(in srgb,var(--text-sub),#ffffff 22%)}:root[data-mode=dark] .family-chat-sender{color:color-mix(in srgb,var(--text-main),#ffffff 12%)}.family-chat-compose{display:grid;gap:6px}.family-chat-compose textarea{min-height:72px;resize:vertical}.family-chat-compose-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.container-card{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:5px 6px}.container-card .item-main{flex:1 1 auto;min-width:0}.container-card .row-actions{margin-left:auto;justify-content:flex-end}.container-card .thumb{width:32px;height:32px}.manage-location-card{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:5px 6px}.manage-location-card .item-main{flex:1 1 auto;min-width:0}.manage-location-card .row-actions{margin-left:auto;justify-content:flex-end}.manage-location-card .thumb{width:32px;height:32px}.upload-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:10px;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--chip-text);font-size:14px;cursor:pointer;min-height:40px}.upload-btn input{display:none}.menu{position:relative}.menu summary{list-style:none;cursor:pointer;padding:5px 6px;border-radius:8px;border:1px solid var(--chip-border);background:color-mix(in srgb,var(--chip-bg),#ffffff 15%);color:var(--chip-text);font-size:11px;line-height:1.1}.menu summary::-webkit-details-marker{display:none}.menu-body{margin-top:6px;display:grid;gap:6px;min-width:min(200px,72vw)}.card-title-inline{display:flex;align-items:center;gap:8px;margin-bottom:8px}.card-title-inline h2{margin:0}.card-title-actions{margin-left:auto;display:inline-flex;align-items:center;gap:6px}.icon-add-btn{width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:999px;font-size:20px;font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--accent),#ffffff 18%);background:linear-gradient(135deg,color-mix(in srgb,var(--accent),#ffffff 12%),color-mix(in srgb,var(--accent-2),#000000 8%));box-shadow:0 2px 8px color-mix(in srgb,var(--accent),transparent 72%);cursor:pointer}.household-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.places-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px}.household-tile{min-height:112px;padding:7px;gap:0;position:relative;overflow:hidden;display:flex;align-items:flex-start;background-size:cover;background-position:center;cursor:pointer}.household-tile:focus-visible{outline:2px solid color-mix(in srgb,var(--accent),#ffffff 20%);outline-offset:2px}.household-tile-header{width:100%;min-height:100%;display:block;position:relative;z-index:2}.household-tile-name{display:inline-flex;align-items:center;justify-content:center;min-height:30px;flex:1 1 auto;min-width:0;border-radius:8px;padding:5px 8px;text-decoration:none;font-size:13px;font-weight:700;line-height:1.2;color:var(--text-main);background:color-mix(in srgb,var(--card-bg),transparent 10%);border:1px solid color-mix(in srgb,var(--card-border),#ffffff 10%);box-shadow:0 2px 6px color-mix(in srgb,var(--text-main),transparent 92%);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.household-tile-has-bg{border-color:color-mix(in srgb,var(--accent),var(--item-card-border) 55%)}.household-tile-has-bg .household-tile-name{color:#f7fffb;text-shadow:0 1px 1px color-mix(in srgb,#000000,transparent 36%);background:color-mix(in srgb,#0a1612,transparent 30%);border-color:color-mix(in srgb,#f5fff7,transparent 64%)}.household-tile-no-bg{background:linear-gradient(180deg,color-mix(in srgb,var(--item-card-bg),#ffffff 8%),color-mix(in srgb,var(--item-card-bg),#000000 3%))}.household-tile-no-bg:before{content:"";position:absolute;left:50%;bottom:39px;transform:translate(-50%);width:58px;height:34px;border-radius:8px 8px 2px 2px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent),transparent 70%),color-mix(in srgb,var(--accent),transparent 82%));clip-path:polygon(50% 0%,100% 62%,94% 70%,6% 70%,0% 62%);box-shadow:0 2px 6px color-mix(in srgb,var(--accent),transparent 88%);pointer-events:none}.household-tile-no-bg:after{content:"";position:absolute;left:50%;bottom:8px;transform:translate(-50%);width:54px;height:38px;border-radius:5px;border:2px solid color-mix(in srgb,var(--accent),transparent 70%);background:linear-gradient(color-mix(in srgb,var(--accent),transparent 63%) 0,color-mix(in srgb,var(--accent),transparent 63%) 0) 20px 18px / 14px 18px no-repeat,linear-gradient(color-mix(in srgb,var(--accent),transparent 63%) 0,color-mix(in srgb,var(--accent),transparent 63%) 0) 9px 8px / 8px 7px no-repeat,linear-gradient(color-mix(in srgb,var(--accent),transparent 63%) 0,color-mix(in srgb,var(--accent),transparent 63%) 0) 37px 8px / 8px 7px no-repeat,linear-gradient(180deg,color-mix(in srgb,var(--accent),transparent 90%),color-mix(in srgb,var(--accent),transparent 94%));box-shadow:0 2px 8px color-mix(in srgb,var(--accent),transparent 88%);pointer-events:none}.household-tile .icon-edit-btn{position:absolute;right:2px;bottom:2px;width:24px;min-width:24px;height:24px;min-height:24px;font-size:12px}.household-edit-menu summary{margin:0}.menu summary.icon-add-btn,.menu summary.icon-edit-btn{width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:999px;font-size:20px;font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--accent),#ffffff 18%);background:linear-gradient(135deg,color-mix(in srgb,var(--accent),#ffffff 12%),color-mix(in srgb,var(--accent-2),#000000 8%));box-shadow:0 2px 8px color-mix(in srgb,var(--accent),transparent 72%);color:#fff;cursor:pointer}.icon-edit-btn{width:32px;min-width:32px;height:32px;min-height:32px;font-size:15px;padding:0;line-height:1}.icon-collapse-btn{font-size:16px;font-weight:800}.icon-log-btn{font-size:14px;font-weight:700}.create-modal-card{width:min(440px,100%);display:grid;gap:8px}.family-log-modal-card{width:min(760px,100%);max-height:min(82vh,820px);display:grid;gap:8px;overflow:hidden}.family-log-modal-card .family-activity-list{overflow:auto;max-height:calc(82vh - 120px);padding-right:3px}.place-tile{min-height:0;aspect-ratio:3 / 4;padding:5px;gap:0;position:relative;overflow:hidden;display:flex;align-items:flex-start;background-size:cover;background-position:center;cursor:pointer}.drag-tile{cursor:grab;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease,border-color .12s ease;-webkit-user-select:none;user-select:none}.drag-tile.dragging{opacity:.62;transform:scale(.98);box-shadow:0 8px 18px color-mix(in srgb,var(--text-main),transparent 82%);cursor:grabbing}.drag-tile.drag-over{border-color:color-mix(in srgb,var(--accent),var(--item-card-border) 22%);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent),transparent 70%),0 8px 16px color-mix(in srgb,var(--text-main),transparent 88%);transform:translateY(-1px)}.place-tile:focus-visible{outline:2px solid color-mix(in srgb,var(--accent),#ffffff 20%);outline-offset:2px}.place-tile-header{width:100%;min-height:100%;display:block;position:relative;z-index:2}.place-tile-name{display:flex;align-items:center;justify-content:center;width:100%;flex:1 1 auto;min-height:24px;min-width:0;margin:0 auto;border-radius:6px;padding:3px 5px;text-decoration:none;font-size:11px;font-weight:700;line-height:1.1;color:var(--text-main);background:color-mix(in srgb,var(--card-bg),transparent 12%);border:1px solid color-mix(in srgb,var(--card-border),#ffffff 12%);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.place-tile-has-bg{border-color:color-mix(in srgb,var(--accent),var(--item-card-border) 55%)}.place-tile-has-bg .place-tile-name{color:#f7fffb;text-shadow:0 1px 1px color-mix(in srgb,#000000,transparent 36%);background:color-mix(in srgb,#0a1612,transparent 30%);border-color:color-mix(in srgb,#f5fff7,transparent 64%)}.place-tile-no-bg{background:linear-gradient(180deg,color-mix(in srgb,var(--item-card-bg),#ffffff 8%),color-mix(in srgb,var(--item-card-bg),#000000 3%))}.place-tile-no-bg:before{content:"";position:absolute;left:50%;bottom:8px;transform:translate(-50%);width:28px;height:38px;border-radius:7px;border:2px solid color-mix(in srgb,var(--accent),transparent 68%);background:radial-gradient(circle at 21px 11px,color-mix(in srgb,var(--accent),transparent 58%) 0 1.5px,transparent 1.8px),radial-gradient(circle at 21px 26px,color-mix(in srgb,var(--accent),transparent 58%) 0 1.5px,transparent 1.8px),linear-gradient(color-mix(in srgb,var(--accent),transparent 64%) 0,color-mix(in srgb,var(--accent),transparent 64%) 0) 0 18px / 100% 2px no-repeat,linear-gradient(180deg,color-mix(in srgb,var(--accent),transparent 90%),color-mix(in srgb,var(--accent),transparent 94%));box-shadow:0 2px 8px color-mix(in srgb,var(--accent),transparent 84%);pointer-events:none}.place-tile-no-bg:after{content:"";position:absolute;left:50%;bottom:4px;transform:translate(-50%);width:20px;height:3px;border-radius:999px;background:color-mix(in srgb,var(--accent),transparent 82%);pointer-events:none}.place-tile .icon-edit-btn{position:absolute;right:2px;bottom:2px;width:24px;min-width:24px;height:24px;min-height:24px;font-size:12px}.menu-inline summary{padding:4px 6px;font-size:10px}.code-block{margin:0;white-space:pre-wrap;word-break:break-word;padding:10px;border:1px solid var(--card-border);border-radius:10px;background:var(--card-soft);font-size:12px}.json-area{width:100%;resize:vertical;min-height:92px;font-family:ui-monospace,Cascadia Code,Courier New,monospace;font-size:12px;line-height:1.35}.admin-form-grid{grid-template-columns:1fr}.scan-card{border:1px dashed var(--chip-border);border-radius:12px;padding:8px;display:grid;gap:8px}.scan-video{width:100%;min-height:clamp(160px,42vw,220px);border-radius:10px;border:1px solid var(--card-border);background:#0c1110;object-fit:cover;display:block}.scan-video-wrap{position:relative;width:100%;max-width:420px;border-radius:10px;overflow:hidden}.scan-reticle{position:absolute;left:8%;top:33%;width:84%;height:34%;border:2px solid color-mix(in srgb,var(--accent),#ffffff 15%);border-radius:12px;box-shadow:0 0 0 9999px color-mix(in srgb,#000000,transparent 70%);pointer-events:none}.scan-reticle-hint{position:absolute;left:50%;bottom:8px;transform:translate(-50%);padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700;color:#f5fff7;background:color-mix(in srgb,#000000,transparent 34%);border:1px solid color-mix(in srgb,var(--accent),#ffffff 10%);pointer-events:none}.scan-video-hidden{display:none}.scan-card-primary{padding:7px;gap:6px}.add-item-quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}.quick-action-btn{width:100%}.ean-quick-row{grid-template-columns:1fr 70px auto}.scan-feedback-options{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.scan-feedback-option{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-sub)}.scan-feedback-option input{min-height:0;width:14px;height:14px;padding:0}.scan-zoom-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center}.scan-zoom-row label{font-size:12px;color:var(--text-sub)}.scan-zoom-row input[type=range]{min-height:0;height:20px;padding:0}.scan-zoom-row span{font-size:12px;font-weight:700;color:var(--text-main)}.scan-summary-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,#000000,transparent 55%);display:flex;align-items:center;justify-content:center;padding:12px;z-index:1000}.scan-summary-modal{width:min(560px,96vw);max-height:80vh;overflow:auto}.summary-list{display:grid;gap:6px}.list-search-row{display:grid;grid-template-columns:1fr auto auto;gap:6px;margin-bottom:6px}.category-group{display:grid;gap:4px}.category-separator{display:flex;align-items:center;gap:8px;font-size:clamp(15px,3.9vw,16px);color:var(--text-sub);font-weight:800}.category-separator:before,.category-separator:after{content:"";height:2px;flex:1 1 auto;background:color-mix(in srgb,var(--item-card-border),#ffffff 10%)}.category-separator span{white-space:nowrap}.container-item-row{display:grid;gap:3px;padding:6px 7px}.container-item-top{width:100%}.container-item-bottom{display:flex;align-items:center;justify-content:space-between;gap:6px}.container-item-bottom .item-main{flex:1 1 auto;min-width:0;gap:8px}.container-item-bottom .thumb{width:34px;height:34px}.container-item-text{min-width:0;display:grid;gap:2px}.container-item-title-single{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.15;font-size:14px}.container-item-side{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.container-item-qty{font-size:clamp(22px,5vw,24px);font-weight:800;color:var(--accent);line-height:1;text-align:right;white-space:nowrap}.container-item-actions{gap:4px;flex-wrap:nowrap}.container-item-actions button{margin:0}.icon-item-action-btn{width:26px;min-width:26px;height:26px;min-height:26px;font-size:16px;padding:0;line-height:1;cursor:pointer}.icon-add-btn:disabled,.icon-edit-btn:disabled,.icon-item-action-btn:disabled{cursor:not-allowed}.icon-item-delete-btn{background:linear-gradient(135deg,#c54242,#a22828);border-color:#962323;box-shadow:0 2px 8px color-mix(in srgb,#9a2727,transparent 70%)}@media(max-width:480px){.container-item-title-single{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.2;font-size:13px}}.add-item-box{display:grid;gap:8px}.search-row{display:grid;grid-template-columns:1fr auto;gap:6px}.search-dropdown{border:1px solid var(--card-border);border-radius:10px;background:var(--card-soft);overflow:hidden}.search-option{width:100%;text-align:left;border:0;border-bottom:1px solid color-mix(in srgb,var(--card-border),#ffffff 15%);border-radius:0;background:transparent;color:var(--text-main);display:grid;gap:2px;padding:8px 10px}.search-option:last-child{border-bottom:0}.search-main{font-size:13px;font-weight:600}.search-sub{font-size:11px;color:var(--text-sub)}.compact-menu{min-width:0}.add-item-modal{width:min(520px,100%);display:grid;gap:8px}.modal-title-row{justify-content:space-between;align-items:center}.ean-modal-grid{grid-template-columns:1fr 100px}.modal-actions{justify-content:flex-end}.modal-actions-split{justify-content:space-between}.summary-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:1px solid var(--item-card-border);border-radius:10px;background:var(--item-card-bg);box-shadow:0 2px 10px color-mix(in srgb,var(--text-main),transparent 92%)}.summary-row-compact{gap:8px;padding:6px 8px}.summary-row-compact .summary-left{gap:8px}.summary-row-compact .thumb{width:clamp(30px,9vw,36px);height:clamp(30px,9vw,36px)}.summary-row-compact .item-title{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(58vw,420px)}.search-hit{border-color:color-mix(in srgb,var(--accent),var(--item-card-border) 35%);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent),transparent 72%),0 2px 10px color-mix(in srgb,var(--text-main),transparent 92%)}.search-results-panel{border:2px solid color-mix(in srgb,var(--accent),var(--item-card-border) 55%);border-radius:12px;background:color-mix(in srgb,var(--item-card-bg),#ffffff 12%);padding:8px;display:grid;gap:6px}.search-results-header{font-size:13px;font-weight:800;color:var(--text-main)}.summary-left{display:flex;gap:10px;align-items:center;min-width:0}.summary-left .thumb{width:clamp(36px,11vw,42px);height:clamp(36px,11vw,42px)}.qty-badge{min-width:36px;text-align:center;padding:6px 10px;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--chip-text);font-weight:700;font-size:13px}.error{color:var(--danger);font-size:13px}.admin-toolbar{display:grid;grid-template-columns:1fr;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,#000000,transparent 55%);display:grid;place-items:center;z-index:80;padding:16px}.modal-card{width:min(440px,100%);background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;padding:14px;box-shadow:0 10px 24px color-mix(in srgb,var(--text-main),transparent 75%)}.selected-image-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid var(--item-card-border);border-radius:10px;background:var(--item-card-bg)}.selected-image-row .thumb{width:36px;height:36px}.image-editor-modal{width:min(520px,100%);display:grid;gap:8px}.image-editor-viewport-wrap{display:grid;gap:6px}.image-editor-viewport{position:relative;width:100%;border-radius:12px;overflow:hidden;border:1px solid var(--card-border);background:radial-gradient(circle at center,color-mix(in srgb,var(--card-soft),#ffffff 4%),color-mix(in srgb,var(--card-soft),#000000 6%));touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab}.image-editor-viewport:active{cursor:grabbing}.image-editor-image{position:absolute;max-width:none;pointer-events:none}.image-editor-frame{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid color-mix(in srgb,var(--accent),#ffffff 16%);border-radius:12px;box-shadow:inset 0 0 0 9999px color-mix(in srgb,#000000,transparent 88%);pointer-events:none}.image-editor-controls{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:8px}.image-editor-controls input[type=range]{width:100%}.image-editor-help{margin-top:-2px}.image-editor-actions{justify-content:space-between}.login-brand{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:8px}.login-logo{width:min(62vw,260px);height:min(62vw,260px);object-fit:contain}.login-brand+.tip-toast{margin-bottom:8px}a{color:var(--link)}.back-btn{display:inline-flex;align-items:center;gap:8px;width:fit-content;text-decoration:none;color:var(--text-main);background:color-mix(in srgb,var(--card-bg),var(--chip-bg) 35%);border:1px solid var(--card-border);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:600;box-shadow:0 2px 8px color-mix(in srgb,var(--text-main),transparent 88%);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.back-btn:before{content:"←";font-size:14px;line-height:1;color:var(--accent)}.back-btn:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent),var(--card-border) 45%);box-shadow:0 6px 14px color-mix(in srgb,var(--text-main),transparent 84%)}.health-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.health-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:8px}.health-kpi{border:1px solid var(--item-card-border);border-radius:10px;background:var(--item-card-bg);padding:8px}.health-kpi-label{font-size:11px;color:var(--text-sub)}.health-kpi-value{font-size:14px;font-weight:700}.health-badge{border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--chip-text)}.health-badge.ok{background:color-mix(in srgb,var(--accent),#ffffff 78%);color:var(--accent);border-color:color-mix(in srgb,var(--accent),#ffffff 50%)}.health-badge.warning{background:#fff3cf;color:#8d6500;border-color:#e4ce89}.health-badge.critical{background:color-mix(in srgb,var(--danger),#ffffff 82%);color:var(--danger);border-color:color-mix(in srgb,var(--danger),#ffffff 60%)}.health-metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:8px}.health-metric{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--item-card-border);border-radius:10px;background:var(--item-card-bg);padding:7px 8px;font-size:12px}.health-metric strong{font-size:14px}.health-pairs{display:grid;grid-template-columns:1fr;gap:4px;font-size:12px}.health-chart{display:grid;gap:6px;margin-top:8px;padding-top:6px;border-top:1px dashed var(--card-border)}.health-chart-row{display:grid;grid-template-columns:minmax(96px,1.2fr) minmax(120px,3fr) auto;gap:8px;align-items:center}.health-chart-label{font-size:11px;color:var(--text-sub)}.health-chart-bar-wrap{width:100%;height:8px;border-radius:999px;border:1px solid var(--chip-border);background:color-mix(in srgb,var(--chip-bg),#ffffff 20%);overflow:hidden}.health-chart-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--accent),#ffffff 10%),color-mix(in srgb,var(--accent-2),#ffffff 12%))}.health-chart-bar.frontend{background:linear-gradient(90deg,color-mix(in srgb,var(--link),#ffffff 8%),color-mix(in srgb,var(--accent),#ffffff 12%))}.health-chart-value{font-size:11px;font-weight:700;color:var(--text-main);text-align:right;white-space:nowrap}@media(min-width:720px){.form{grid-template-columns:1fr 160px auto}.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-toolbar{grid-template-columns:1fr 160px 160px auto}.health-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.health-metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:780px){.form-compact{grid-template-columns:1fr}.app-header{padding:6px 8px;gap:6px}.logo{gap:6px}.admin-links{gap:4px}.brand-logo{width:44px;height:44px}.top-controls{width:100%;justify-content:flex-end;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;gap:4px}.top-controls::-webkit-scrollbar{display:none}.top-controls>*{flex:0 0 auto}.top-controls select{min-width:68px;min-height:30px;padding:6px 8px;font-size:10px;border-radius:8px}.mode-toggle{gap:4px;font-size:10px}.tip-toast{grid-template-columns:1fr;gap:6px;padding:7px 8px}.tip-toast-actions{justify-content:flex-end}.tip-toast-text{font-size:11px}.tip-toast-btn{min-height:24px;font-size:10px;padding:4px 7px}.env-badge{min-height:18px;padding:2px 6px;font-size:10px}.btn-sm{min-height:30px;padding:5px 7px;font-size:10px}.header-family-btn{min-height:30px;padding:4px 8px;font-size:10px;gap:4px}.header-family-icon{font-size:12px}}@media(max-width:560px){.logo span{font-size:14px}.app-main{padding-left:8px;padding-right:8px}.card{border-radius:12px}.summary-row{padding:7px 8px}.add-item-quick-actions,.ean-modal-grid{grid-template-columns:1fr}.household-tile{min-height:100px}.place-tile{min-height:0}.header-tip-row .tip-toast{border-radius:8px}.image-editor-controls{grid-template-columns:auto 1fr auto}.image-editor-controls span{grid-column:1 / -1;justify-self:end;font-size:11px}}@media(min-width:760px){.household-grid,.places-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:960px){.places-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
