/* ============================================================
   家族チャット PWA — アプリ用スタイル（フル画面モバイル）
   ============================================================ */
:root{
  color-scheme:light; /* iOSのダークモードで入力欄が白文字化＝見えなくなるのを防ぐ */
  --screen:#FBF8F2;--card:#FFFFFF;--green:#8BAA56;--green-send:#8FBA50;--green-soft:#EAF0DC;
  --text:#4C4A44;--text-sub:#A29E95;--line:#EFEAE1;--blue-bubble:#D6E4F1;--blue-text:#43536A;--badge:#E79A98;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{font-family:"M PLUS Rounded 1c",sans-serif;background:var(--screen);color:var(--text);overscroll-behavior:none;}
#app{max-width:480px;margin:0 auto;height:100dvh;background:var(--screen);display:flex;flex-direction:column;overflow:hidden;position:relative;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
img{display:block;}

.view{flex:1;display:none;flex-direction:column;min-height:0;}
.view.on{display:flex;}
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.scroll::-webkit-scrollbar{display:none;}

.ic{width:24px;height:24px;flex:none;stroke:#6E6A60;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.ic-btn{display:flex;align-items:center;justify-content:center;}

/* header */
.hd{display:flex;align-items:center;padding:max(22px,env(safe-area-inset-top)) 20px 14px;gap:12px;}
.hd h1{font-size:23px;font-weight:800;line-height:1.2;}
.hd .sub{font-size:13px;color:var(--text-sub);font-weight:500;margin-top:4px;}
.hd-center h2{font-size:18px;font-weight:800;flex:1;text-align:center;}

/* avatars */
.av{width:50px;height:50px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-size:26px;line-height:1;background:#EAE4DA;}
.av.sm{width:42px;height:42px;font-size:21px;}
.av.tiny{width:34px;height:34px;font-size:17px;}

/* list rows (chat list) */
.row{display:flex;align-items:center;gap:14px;background:var(--card);border-radius:20px;padding:14px 15px;margin:0 14px 11px;box-shadow:0 3px 10px rgba(80,70,45,.04);}
.row .meta{flex:1;min-width:0;}
.row .name{font-size:16px;font-weight:700;margin-bottom:3px;}
.row .msg{font-size:13px;color:var(--text-sub);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.badge{background:var(--badge);color:#fff;font-size:12px;font-weight:700;min-width:21px;height:21px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 6px;}
.badge.red{background:#E8403B;min-width:22px;height:22px;border-radius:11px;box-shadow:0 1px 4px rgba(232,64,59,.4);}

/* bottom nav */
.nav{display:flex;justify-content:space-around;align-items:center;padding:10px 8px calc(14px + env(safe-area-inset-bottom));background:var(--screen);border-top:1px solid var(--line);}
.nav .item{display:flex;flex-direction:column;align-items:center;gap:4px;color:#B7B2A8;font-size:11px;font-weight:600;}
.nav .item.on{color:var(--green);}
.nav .item .ic{width:23px;height:23px;stroke:currentColor;}

/* buttons */
.btn{margin:10px 18px;background:var(--green);color:#fff;text-align:center;padding:16px;border-radius:16px;font-size:16px;font-weight:700;box-shadow:0 8px 18px rgba(139,170,86,.3);width:calc(100% - 36px);}
.btn:active{transform:translateY(1px);}
.btn.ghost{background:#fff;color:var(--green);border:1.6px solid var(--green-soft);box-shadow:none;}
.btn:disabled{opacity:.5;}

/* generic */
.center-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:30px;text-align:center;}
.field{width:100%;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-size:16px;font-family:inherit;color:var(--text);-webkit-text-fill-color:var(--text);}
.field::placeholder{color:#C2BDB2;}

/* onboarding emoji picker */
.emoji-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;width:100%;max-width:320px;}
.emoji-grid button{font-size:30px;padding:10px;border-radius:14px;background:#fff;border:2px solid transparent;}
.emoji-grid button.sel{border-color:var(--green);background:var(--green-soft);}

/* SVG人物アイコン */
.av svg,.big svg,.call-big svg,.ob-face svg{width:100%;height:100%;display:block;}
.av{overflow:hidden;}
.ob-face{width:96px;height:96px;border-radius:50%;overflow:hidden;}
.avatar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;width:100%;max-width:330px;}
.avatar-grid button{aspect-ratio:1;border-radius:50%;overflow:hidden;border:3px solid transparent;background:none;padding:0;}
.avatar-grid button.sel{border-color:var(--green);}
.avatar-grid button svg{width:100%;height:100%;display:block;}
.m-emoji svg{width:62px;height:62px;margin:0 auto;display:block;}
.big{overflow:hidden;}.call-big{overflow:hidden;}
.pickrow .av svg{width:100%;height:100%;}

/* chat */
.chat-hd{display:flex;align-items:center;gap:11px;padding:max(20px,env(safe-area-inset-top)) 16px 12px;border-bottom:1px solid var(--line);}
.chat-hd .ti{flex:1;}
.chat-hd .ti .t{font-size:17px;font-weight:800;}
.chat-hd .ti .c{font-size:12px;color:var(--text-sub);font-weight:500;margin-top:1px;}
.chat-body{flex:1;overflow-y:auto;padding:16px 14px 8px;display:flex;flex-direction:column;gap:13px;}
.chat-body::-webkit-scrollbar{display:none;}
.daypill{align-self:center;background:#fff;border:1px solid var(--line);color:#9A968E;font-size:12px;font-weight:600;padding:5px 16px;border-radius:14px;}
.m{display:flex;gap:9px;max-width:86%;}
.m .av{width:34px;height:34px;font-size:17px;align-self:flex-start;}
.m .body{display:flex;flex-direction:column;gap:3px;min-width:0;}
.m .who{font-size:11.5px;color:#9A968E;font-weight:600;margin-left:3px;}
.bubble{background:#fff;border:1px solid #F0EBE2;padding:11px 14px;border-radius:5px 17px 17px 17px;font-size:14.5px;font-weight:500;line-height:1.5;word-break:break-word;white-space:pre-wrap;}
.bubble a{color:var(--green);font-weight:700;}
.bubble img{max-width:200px;border-radius:12px;margin:-2px;}
.m .foot{display:flex;align-items:center;gap:7px;margin-left:3px;}
.time{font-size:10.5px;color:#B7B2A8;font-weight:500;}
.time.pending{color:#E0A23B;font-weight:700;}
.contact-row{display:flex;align-items:center;justify-content:space-between;background:#F4F1EA;border-radius:10px;padding:9px 12px;margin-bottom:6px;font-size:14px;font-weight:600;}
.contact-row .cx{color:#E36A66;font-size:18px;font-weight:700;padding:0 8px;background:none;}

/* 完全オフライン時の画面SOS（周囲に助けを求める）*/
.sos-alarm{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;padding:24px;animation:sosflash .8s steps(1,end) infinite;}
@keyframes sosflash{0%{background:#E0322B}50%{background:#B71C16}100%{background:#E0322B}}
.sa-in{max-width:520px;}
.sa-big{font-size:84px;line-height:1;}
.sa-t{font-size:44px;font-weight:800;margin:6px 0;}
.sa-name{font-size:24px;font-weight:700;margin-bottom:14px;}
.sa-msg{font-size:18px;font-weight:600;line-height:1.8;background:rgba(0,0,0,.18);border-radius:16px;padding:14px 16px;}
.sa-qrbox{margin-top:16px;background:#fff;border-radius:18px;padding:14px;display:inline-block;}
.sa-qrbox #sa-qr{display:flex;justify-content:center;}
.sa-qrbox #sa-qr img,.sa-qrbox #sa-qr canvas{display:block;}
.sa-qrcap{margin-top:8px;color:#B71C16;font-size:12.5px;font-weight:700;max-width:200px;line-height:1.5;}
.sa-coord{margin-top:12px;font-size:14px;font-weight:600;opacity:.9;}
.sa-map{display:inline-block;margin-top:12px;background:#fff;color:#C62828;font-weight:800;padding:12px 20px;border-radius:14px;text-decoration:none;font-size:16px;}
.sa-stop{margin-top:22px;background:rgba(255,255,255,.22);color:#fff;border:2px solid #fff;font-size:16px;font-weight:700;padding:12px 30px;border-radius:14px;}
.btn.sm{font-size:13px;padding:10px 14px;}
.react{background:#fff;border:1px solid var(--line);border-radius:11px;padding:2px 8px;font-size:13px;font-weight:600;color:#7A766D;}
/* 返信引用 */
.reply-quote{font-size:11.5px;color:#8E8A80;font-weight:600;background:#F4F1EA;border-left:3px solid var(--green);border-radius:6px;padding:4px 8px;margin-bottom:4px;max-width:230px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.m.me .reply-quote{align-self:flex-end;}
/* 録音バー */
.rec-bar{background:#FBEAE6;border-top:1px solid #F2C9C2;padding:10px 14px;}
.rec-in{display:flex;align-items:center;gap:10px;}
.rec-dot{width:12px;height:12px;border-radius:50%;background:#E8403B;flex:none;animation:recblink 1s infinite;}
@keyframes recblink{0%,100%{opacity:1}50%{opacity:.25}}
.rec-t{flex:1;font-size:14px;font-weight:700;color:#9A4B43;}
.rec-t b{font-feature-settings:"tnum";}
.rec-cancel{background:#fff;color:#8E8A80;font-size:13px;font-weight:700;padding:8px 14px;border-radius:12px;border:1px solid var(--line);}
.rec-send{background:var(--green);color:#fff;font-size:13px;font-weight:700;padding:8px 18px;border-radius:12px;}

/* 返信バー（入力上） */
.reply-bar{background:#F4F1EA;border-top:1px solid var(--line);padding:8px 14px;}
.rb-in{display:flex;align-items:center;gap:8px;}
.rb-t{flex:1;font-size:12.5px;color:#6E6A60;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rb-x{font-size:18px;color:#9A968E;padding:2px 8px;background:none;}
/* 長押しメニュー（アクションシート） */
.sheet-wrap{position:fixed;inset:0;background:rgba(50,45,35,.4);z-index:250;display:flex;align-items:flex-end;justify-content:center;}
.sheet{background:#fff;width:100%;max-width:460px;border-radius:22px 22px 0 0;padding:10px 12px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -8px 30px rgba(0,0,0,.2);animation:sheetup .2s ease;}
@keyframes sheetup{from{transform:translateY(40px);opacity:.4}to{transform:translateY(0);opacity:1}}
.sheet-react{display:flex;justify-content:space-around;padding:8px 4px 12px;border-bottom:1px solid var(--line);margin-bottom:6px;}
.qr{font-size:30px;padding:4px 8px;border-radius:12px;background:none;}
.qr:active{background:var(--green-soft);transform:scale(1.2);}
.sheet-item{display:block;width:100%;text-align:center;padding:15px;font-size:16px;font-weight:700;color:var(--text);border-radius:12px;background:none;}
.sheet-item.danger{color:#E36A66;}
.sheet-item.cancel{color:#8E8A80;}
.sheet-item:active{background:#F4F1EA;}
.m.me{align-self:flex-end;flex-direction:row-reverse;}
.m.me .body{align-items:flex-end;}
.bubble.me{background:var(--blue-bubble);border:none;color:var(--blue-text);border-radius:17px 5px 17px 17px;}
.m.me .foot{flex-direction:row-reverse;margin-right:3px;margin-left:0;}
.read{font-size:10px;color:#B7B2A8;font-weight:600;}

/* link preview card */
.linkcard{margin-top:6px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;}
.linkcard .lk-host{font-size:11px;color:var(--text-sub);padding:8px 12px 0;}
.linkcard .lk-url{font-size:12.5px;font-weight:700;color:var(--green);padding:2px 12px 10px;word-break:break-all;}

/* input bar */
.inputbar{display:flex;align-items:flex-end;gap:9px;padding:10px 14px calc(14px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--screen);}
.inputbar .ic-btn{padding-bottom:6px;}
.inputbar .ic{width:25px;height:25px;stroke:#9C988E;stroke-width:1.8;}
.inputbar .tf{flex:1;background:#fff;color:var(--text);border:1px solid var(--line);border-radius:20px;padding:10px 16px;font-size:15px;line-height:1.45;font-family:inherit;outline:none;resize:none;max-height:110px;overflow-y:auto;-webkit-text-fill-color:var(--text);}
.tf::placeholder,.field::placeholder{color:var(--text-sub);-webkit-text-fill-color:var(--text-sub);}
.inputbar .tf[contenteditable]{white-space:pre-wrap;word-break:break-word;min-height:24px;cursor:text;-webkit-user-modify:read-write-plaintext-only;}
.tf[contenteditable]:empty:before{content:attr(data-ph);color:var(--text-sub);-webkit-text-fill-color:var(--text-sub);pointer-events:none;}
.inputbar .send{margin-bottom:0;}
.send{width:40px;height:40px;border-radius:50%;background:var(--green-send);flex:none;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px rgba(143,186,80,.34);}
.send .ic{width:20px;height:20px;stroke:#fff;}

/* QR invite */
.qr-box{width:210px;height:210px;background:#fff;border-radius:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(80,70,45,.08);padding:18px;}
.qr-box canvas,.qr-box img{width:100%;height:100%;image-rendering:pixelated;}
.qr-code{font-size:30px;font-weight:800;letter-spacing:.12em;color:var(--green);}
.qr-exp{font-size:12px;color:#B7B2A8;font-weight:600;background:#fff;border:1px solid var(--line);padding:5px 14px;border-radius:12px;}

/* map */
#map{flex:1;min-height:0;width:100%;background:#DCE6DD;z-index:0;}
.maplibregl-map{font-family:inherit;}
.map-pin{display:flex;flex-direction:column;align-items:center;cursor:pointer;}
.map-lbl{background:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:9px;box-shadow:0 2px 6px rgba(0,0,0,.15);white-space:nowrap;margin-bottom:2px;}
.map-av{width:40px;height:40px;border-radius:50%;overflow:hidden;border:3px solid #8BAA56;background:#fff;box-shadow:0 3px 8px rgba(0,0,0,.25);}
.map-av svg{width:100%;height:100%;display:block;}
.map-pin.target .map-av{width:52px;height:52px;border-width:4px;border-color:#E36A66;}
.map-pin.target .map-lbl{background:#E36A66;color:#fff;font-weight:800;}
.map-pin.target:not(.sos) .map-av{border-color:#8BAA56;}
.map-pin.target:not(.sos) .map-lbl{background:#8BAA56;}
.map-pin.sos .map-av{animation:sospulse 1s ease-in-out infinite;}
@keyframes sospulse{0%,100%{box-shadow:0 0 0 0 rgba(227,106,102,.6);}50%{box-shadow:0 0 0 12px rgba(227,106,102,0);}}

/* 利用規約・プライバシー（アプリ内オーバーレイ） */
.terms-overlay{position:fixed;inset:0;background:var(--screen);z-index:300;display:flex;flex-direction:column;max-width:480px;margin:0 auto;}
.terms-head{display:flex;align-items:center;padding:max(18px,env(safe-area-inset-top)) 18px 12px;border-bottom:1px solid var(--line);}
.terms-head .tm-title{flex:1;text-align:center;font-size:17px;font-weight:800;}
.terms-body{flex:1;overflow-y:auto;padding:18px 20px calc(30px + env(safe-area-inset-bottom));}
.terms-body h1{font-size:21px;font-weight:800;margin-bottom:4px;}
.terms-body .upd{color:var(--text-sub);font-size:12px;margin-bottom:16px;}
.terms-body h2{font-size:15px;font-weight:800;color:#6E7A4E;margin:18px 0 6px;}
.terms-body p,.terms-body li{font-size:13.5px;font-weight:500;line-height:1.8;}
.terms-body ul{padding-left:1.2em;margin:4px 0;}
.terms-body .note{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-size:12.5px;color:#6E6A60;margin-top:8px;}
.terms-body .foot{margin-top:24px;color:#B7B2A8;font-size:12px;}
.loc-sheet{background:var(--screen);padding:14px 18px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -6px 20px rgba(0,0,0,.06);}
.loc-row{display:flex;align-items:center;gap:12px;padding:8px 0;}
.loc-row .meta{flex:1;min-width:0;}.loc-row .nm{font-size:14.5px;font-weight:700;}
.loc-row .pl{font-size:12px;color:var(--text-sub);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.loc-row .ago{font-size:11px;color:#B7B2A8;font-weight:600;}
.goto-btn{flex:none;background:var(--green);color:#fff;font-size:12.5px;font-weight:700;padding:8px 12px;border-radius:12px;}
.goto-btn:active{transform:translateY(1px);}
.loc-btns{flex:none;display:flex;flex-direction:column;gap:4px;}
.hist-btn{background:#EEF2E4;color:#6E7A4E;font-size:11.5px;font-weight:700;padding:6px 10px;border-radius:11px;}
.hist-btn:active{transform:translateY(1px);}
.hist-bar{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;}
.hist-h{display:flex;align-items:center;justify-content:space-between;font-size:13.5px;margin-bottom:8px;}
.hist-h b{font-weight:800;}
.hist-time{text-align:center;font-size:14px;font-weight:800;color:var(--green);margin-top:6px;}
#hist-slider{width:100%;accent-color:#8BAA56;}

/* settings */
.prof{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 0 20px;}
.prof .big{width:84px;height:84px;border-radius:50%;background:#F6D2D6;display:flex;align-items:center;justify-content:center;font-size:44px;}
.prof .nm{font-size:18px;font-weight:800;}
.prof .id{font-size:12px;color:var(--text-sub);background:#fff;border:1px solid var(--line);padding:4px 12px;border-radius:12px;}
.set-row{display:flex;align-items:center;gap:14px;padding:15px 20px;border-top:1px solid var(--line);}
.set-row .ic{width:21px;height:21px;stroke:#8E8A80;}
.set-row .lbl{flex:1;font-size:15px;font-weight:600;}
.set-row .chev{width:16px;height:16px;stroke:#CBC6BB;stroke-width:2.2;fill:none;}
.set-row .idval{font-size:12.5px;font-weight:700;color:#A29E95;font-feature-settings:"tnum";}
.linklike{margin-top:6px;color:#8BAA56;font-size:13.5px;font-weight:700;background:none;border:none;padding:8px;}
.linklike:active{opacity:.6;}

/* toast */
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%) translateY(20px);background:#4C4A44;color:#fff;padding:11px 20px;border-radius:20px;font-size:13.5px;font-weight:600;opacity:0;transition:.25s;z-index:99;pointer-events:none;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

.hs-banner{background:var(--green-soft);border:1px solid #DDE7C8;border-radius:16px;margin:0 14px 12px;padding:12px 14px;}
.hs-banner.warn{background:#FBEAE6;border-color:#F2C9C2;}
.hs-banner.warn .hs-txt{color:#9A4B43;}
.hs-banner.warn .hs-make{background:#E36A66;}
.hs-txt{font-size:12.5px;font-weight:600;color:#5E6B3E;line-height:1.65;}
.hs-btns{display:flex;gap:8px;margin-top:10px;}
.hs-make{flex:1;background:var(--green);color:#fff;font-size:13px;font-weight:700;padding:9px;border-radius:11px;}
.hs-x{background:#fff;color:#8E8A80;font-size:13px;font-weight:600;padding:9px 14px;border-radius:11px;border:1px solid var(--line);}

.empty{color:var(--text-sub);font-size:14px;text-align:center;padding:40px 20px;line-height:1.7;}
.demo-tag{position:fixed;top:8px;right:8px;background:var(--badge);color:#fff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:10px;z-index:50;}

/* checkbox（規約同意） */
.cbx{width:22px;height:22px;border-radius:7px;border:2px solid #D7D2C7;flex:none;display:flex;align-items:center;justify-content:center;}
.cbx.on{background:var(--green);border-color:var(--green);}
.cbx.on::after{content:"";width:6px;height:11px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg) translateY(-1px);}

/* modal */
.modal-wrap{position:fixed;inset:0;background:rgba(50,45,35,.45);display:flex;align-items:center;justify-content:center;z-index:200;padding:28px;}
.modal{background:#fff;border-radius:24px;padding:26px 22px 18px;max-width:330px;width:100%;text-align:center;box-shadow:0 20px 50px rgba(0,0,0,.25);}
.m-emoji{font-size:46px;margin-bottom:6px;}
.m-title{font-size:19px;font-weight:800;margin-bottom:8px;}
.m-body{font-size:14px;font-weight:500;color:#6E6A60;line-height:1.7;}
.m-btns{display:flex;gap:10px;margin-top:20px;}
.m-btns button{flex:1;padding:14px;border-radius:14px;font-size:15px;font-weight:700;}
.m-cancel{background:#F0EBE2;color:#6E6A60;}
.m-ok{background:var(--green);color:#fff;}
.m-ok.danger{background:#E36A66;}
.pickrow{display:flex;align-items:center;gap:10px;width:100%;padding:12px;border-radius:12px;background:#F7F4EE;margin-bottom:8px;font-size:15px;font-weight:700;text-align:left;}
.set-sec{font-size:12px;font-weight:800;color:#A29E95;padding:16px 18px 6px;letter-spacing:.02em;}
.trk-sec{font-size:12.5px;font-weight:800;color:#6E6A60;margin:16px 0 8px;padding-top:12px;border-top:1px solid var(--line);}
.genki-card{margin:8px 14px 12px;padding:16px;border-radius:18px;background:linear-gradient(135deg,#FFF4D6,#FFE9C7);text-align:center;}
.genki-card .genki-top{font-size:16px;font-weight:800;color:#8a6d2b;}
.genki-card .genki-sub{font-size:12px;color:#a98a4e;margin:2px 0 12px;}
.genki-btn{font-family:inherit;border:none;cursor:pointer;background:#F2A93B;color:#fff;font-weight:800;font-size:16px;padding:13px 22px;border-radius:999px;box-shadow:0 4px 12px rgba(242,169,59,.35);}
.genki-btn:active{transform:scale(.96);}
.genki-btn.done{background:#CFE3B0;color:#5d7a3a;box-shadow:none;}
.wellness-bubble{background:linear-gradient(135deg,#FFE9C7,#FFD9A0)!important;color:#8a5a1a!important;font-weight:800;}
.mood-row{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px;flex-wrap:wrap;}
.mood-cap{font-size:11.5px;color:#a98a4e;font-weight:700;margin-right:2px;}
.mood-btn{font-family:inherit;border:none;cursor:pointer;background:#fff;border-radius:50%;width:42px;height:42px;font-size:22px;box-shadow:0 2px 6px rgba(0,0,0,.08);}
.mood-btn:active{transform:scale(.9);}
.ai-row .av{font-size:22px;display:flex;align-items:center;justify-content:center;}
.ai-wrap{position:fixed;top:0;left:0;right:0;height:100dvh;z-index:300;background:var(--screen);display:flex;flex-direction:column;max-width:480px;margin:0 auto;overflow:hidden;}
.ai-hd{display:flex;align-items:center;gap:8px;padding:14px 12px;border-bottom:1px solid var(--line);background:#fff;}
.ai-hd .ai-ti{flex:1;font-weight:800;font-size:16px;}
.ai-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;}
.ai-hello{color:var(--text-sub);text-align:center;font-size:14px;line-height:1.9;margin:auto;max-width:300px;}
.ai-m{display:flex;}
.ai-m.user{justify-content:flex-end;}
.ai-m .ai-b{max-width:80%;padding:11px 14px;border-radius:16px;font-size:15px;line-height:1.6;white-space:pre-wrap;word-break:break-word;}
.ai-m.user .ai-b{background:var(--green);color:#fff;border-bottom-right-radius:4px;}
.ai-m.assistant .ai-b{background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px;}
.ai-tpls{display:flex;flex-direction:column;gap:8px;margin-top:18px;text-align:left;}
.ai-tpls-cap{font-size:11.5px;font-weight:800;color:#A29E95;margin-bottom:2px;text-align:center;}
.ai-tpl{font-family:inherit;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;font-size:14px;font-weight:600;color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.04);}
.ai-tpl:active{transform:scale(.98);background:var(--green-soft);}
.ai-img{max-width:200px;max-height:200px;border-radius:10px;display:block;margin-bottom:6px;}
/* ホーム ダッシュボード（シンプルミニマリズム） */
.dash{padding:14px 16px 16px;display:flex;flex-direction:column;gap:14px;}
.dcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;width:100%;text-align:left;font-family:inherit;color:var(--text);}
.dcard.tappable,.dcard.emerg,.dcard.chatlink{cursor:pointer;}
.dcard.tappable:active,.dcard.emerg:active,.dcard.chatlink:active{transform:scale(.99);}
.dash-load{color:var(--text-sub);text-align:center;padding:18px 0;font-size:13px;}
.wx-main{display:flex;align-items:center;gap:14px;margin-bottom:8px;}
.wx-emoji{font-size:46px;line-height:1;}
.wx-temp{font-size:34px;font-weight:800;line-height:1;}
.wx-lbl{font-size:13px;color:var(--text-sub);font-weight:600;margin-top:4px;}
.wx-cap{font-size:11px;color:var(--text-sub);font-weight:700;margin:10px 0 2px;}
.wx-place{font-size:12.5px;color:var(--text-sub);font-weight:700;margin-bottom:6px;}
.wx-carousel{display:flex;align-items:center;gap:4px;}
.wx-arrow{flex:0 0 auto;width:28px;height:80px;border:none;background:var(--screen);border-radius:10px;color:#8A857B;font-size:22px;font-weight:800;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.wx-arrow:active{background:var(--green-soft);}
.wx-hours{flex:1;display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:6px 0 2px;scroll-snap-type:x proximity;touch-action:pan-x;overscroll-behavior-x:contain;cursor:grab;}
.wx-hours:active{cursor:grabbing;}
.wx-hours::-webkit-scrollbar{display:none;}
.wx-h{position:relative;flex:0 0 auto;width:56px;text-align:center;background:var(--screen);border-radius:13px;padding:9px 4px;scroll-snap-align:start;}
.wx-h.tm{background:var(--green-soft);}
.wx-h-day{position:absolute;top:-7px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:9px;font-weight:800;padding:1px 6px;border-radius:8px;white-space:nowrap;}
.wx-h-t{font-size:10.5px;color:var(--text-sub);font-weight:700;}
.wx-h-e{font-size:22px;margin:3px 0;line-height:1;}
.wx-h-tp{font-size:13px;font-weight:800;}
.wx-warn{margin-top:8px;background:#FBE9E7;color:#B0392F;border-radius:12px;padding:10px 12px;font-size:13px;line-height:1.6;font-weight:600;}
.wx-ok{margin-top:8px;color:#6E7A4E;font-size:12.5px;font-weight:700;}
.dc-h{display:flex;align-items:center;justify-content:space-between;font-weight:800;font-size:15px;margin-bottom:8px;}
.dc-go{font-size:12px;color:var(--green);font-weight:700;}
.dc-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:14px;border-top:1px solid var(--line);}
.dc-row .dot{width:9px;height:9px;border-radius:50%;flex:none;}
.dc-row b{flex:1;font-weight:700;}
.dc-when{font-size:11.5px;color:var(--text-sub);}
.dc-empty{color:var(--text-sub);font-size:13px;padding:6px 0;}
.dcard.emerg{background:linear-gradient(135deg,#FCE4E4,#F7CFCF);color:#B0392F;font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:space-between;}
.dcard.emerg .dc-sub{font-size:12px;font-weight:700;opacity:.8;}
.dcard.chatlink{background:var(--green-soft);color:#5d7a3a;font-weight:800;font-size:16px;text-align:center;}
.emerg-row{display:flex;align-items:center;gap:6px;margin-bottom:10px;}
.emerg-call{flex:1;display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;text-decoration:none;color:var(--text);}
.emerg-call:active{background:var(--green-soft);}
.ec-ic{font-size:26px;}
.ec-meta{display:flex;flex-direction:column;}
.ec-meta b{font-size:16px;font-weight:800;}
.ec-meta span{font-size:13px;color:var(--text-sub);}
.ec-del{width:28px;height:28px;border-radius:50%;background:#EFEAE1;color:#A29E95;font-size:16px;flex:none;}
.share-strip{display:flex;align-items:center;gap:4px;padding:6px 16px 10px;flex-wrap:wrap;border-bottom:1px solid var(--line);}
.share-strip .av.xs{width:26px;height:26px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;font-size:14px;background:#EFEAE1;border:1.5px solid #fff;margin-left:-6px;}
.share-strip .av.xs:first-child{margin-left:0;}
.share-strip .av.xs svg{width:100%;height:100%;}
.share-strip .share-lbl{font-size:12px;font-weight:700;color:#8A857B;margin-left:8px;}
.nc-sec{font-size:12.5px;font-weight:800;color:#A29E95;margin:14px 2px 8px;letter-spacing:.02em;}
.nc-sec:first-child{margin-top:2px;}

/* recording */
#ch-mic.recording{background:#E36A66;border-radius:50%;}
#ch-mic.recording .ic{stroke:#fff;}
#ch-mic.recording{animation:pulse 1s infinite;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(227,106,102,.5);}50%{box-shadow:0 0 0 8px rgba(227,106,102,0);}}

/* media bubbles */
.bubble.media{padding:4px;}
.bubble.media img,.bubble.media video{max-width:210px;border-radius:13px;display:block;}
.bubble audio{width:210px;}
.bubble .sub2{font-size:12px;opacity:.7;}
.dec-wait{opacity:.55;font-style:italic;font-size:13px;}
.sos-track-bar{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(14px + env(safe-area-inset-bottom));z-index:350;display:flex;align-items:center;gap:10px;background:#B71C16;color:#fff;padding:9px 12px 9px 14px;border-radius:999px;box-shadow:0 6px 18px rgba(183,28,22,.4);font-size:13px;font-weight:800;}
.sos-track-bar .dot{width:9px;height:9px;border-radius:50%;background:#fff;animation:sostrk 1s ease-in-out infinite;}
.sos-track-bar button{background:rgba(255,255,255,.22);color:#fff;font-weight:800;font-size:12px;padding:5px 11px;border-radius:999px;}
@keyframes sostrk{0%,100%{opacity:.3}50%{opacity:1}}
.bubble.sos-bubble{background:#E36A66;color:#fff;border:none;font-weight:800;font-size:16px;border-radius:17px;animation:pulse 1.2s infinite;}
.bubble.sos-bubble.resolved{background:#9BB36B;animation:none;}
.sos-resolve{display:block;margin-top:8px;background:#fff;color:#C44;font-weight:800;font-size:13px;padding:8px 14px;border-radius:11px;}
.sos-resolve:active{transform:translateY(1px);}
.sos-status{margin-top:8px;font-size:13px;font-weight:800;opacity:.95;}
.ic-btn.sos{font-size:20px;}

/* album */
.alb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;padding:6px 14px;}
.alb-grid .ph{aspect-ratio:1;border-radius:10px;overflow:hidden;position:relative;}
.alb-grid .ph img,.alb-grid .ph video{width:100%;height:100%;object-fit:cover;}
.alb-grid .ph .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;text-shadow:0 1px 6px rgba(0,0,0,.5);}
.viewer{position:fixed;inset:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;}
.callbtn{width:38px;height:38px;border-radius:50%;background:var(--green-soft);display:flex;align-items:center;justify-content:center;flex:none;}

/* scanner */
.scanwrap{flex:1;position:relative;background:#000;display:flex;align-items:center;justify-content:center;}
.scanwrap video{width:100%;height:100%;object-fit:cover;}
.scanwrap .reticle{position:absolute;width:210px;height:210px;border:3px solid #fff;border-radius:24px;box-shadow:0 0 0 9999px rgba(0,0,0,.4);}

/* calendar */
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:6px 20px 12px;}
.cal-head .mon{font-size:18px;font-weight:800;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:0 12px;}
.cal-grid .dow{text-align:center;font-size:11px;font-weight:700;color:#B7B2A8;padding:6px 0;}
.cal-grid .dow.sun{color:#E08A88;}.cal-grid .dow.sat{color:#8FA9CE;}
.cal-grid .day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:13.5px;font-weight:600;border-radius:12px;position:relative;color:#5E5A52;background:none;}
.cal-grid .day.mut{color:#D3CEC4;}
.cal-grid .day.sel{background:var(--green-soft);}
.cal-grid .day.today{background:var(--green);color:#fff;}
.cal-grid .day .dots{position:absolute;bottom:5px;left:0;right:0;display:flex;justify-content:center;gap:2px;}
.cal-grid .day .dots .dot{width:5px;height:5px;border-radius:50%;}
.cal-grid .day.today .dots .dot{box-shadow:0 0 0 1px rgba(255,255,255,.7);}
.cal-list{flex:1;overflow-y:auto;border-top:1px solid var(--line);margin-top:12px;padding-bottom:8px;}
.cal-list::-webkit-scrollbar{display:none;}
.cal-list-h{padding:14px 20px 8px;font-size:13.5px;font-weight:800;color:#6E7A4E;}
.ev{display:flex;gap:12px;align-items:center;padding:11px 18px;}
.ev .tag{width:4px;height:36px;border-radius:3px;flex:none;}
.ev .ti{flex:1;min-width:0;}
.ev .ti .t{font-size:15px;font-weight:700;}
.ev .ti .s{font-size:12px;color:var(--text-sub);font-weight:500;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ev-del{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;}
.ev-colors{display:flex;gap:10px;justify-content:center;margin-bottom:4px;}
.ev-colors button{width:30px;height:30px;border-radius:50%;border:3px solid transparent;}
.ev-colors button.sel{border-color:#4C4A44;}
input.field[type=date],input.field[type=time]{font-family:inherit;}

/* stickers */
.sticker-panel{display:grid;grid-template-columns:repeat(5,1fr);grid-auto-rows:64px;gap:8px;padding:0 14px 12px;max-height:46vh;overflow-y:auto;-webkit-overflow-scrolling:touch;border-top:1px solid var(--line);background:#fff;}
.sticker-panel[hidden]{display:none!important;} /* display:grid が hidden属性 を上書きしていたバグ修正 */
.stk-head{grid-column:1/-1;position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;background:#fff;padding:11px 2px 9px;z-index:2;border-bottom:1px solid var(--line);height:auto;}
.sticker-panel .stk-head{height:auto;}
.stk-head b{font-size:14px;font-weight:800;color:#6E6A60;}
.stk-close{font-size:13.5px;font-weight:800;color:#fff;background:#C9C3B6;border-radius:999px;padding:8px 18px;}
.stk-close:active{transform:scale(.94);}
/* aspect-ratio由来の行崩れ（2段目が潰れて重なる）を防ぐため固定高に */
.sticker-panel .stk{aspect-ratio:auto;height:64px;}
.sticker-panel::-webkit-scrollbar{display:none;}
.stk{font-size:34px;padding:6px;border-radius:14px;background:#F7F4EE;display:flex;align-items:center;justify-content:center;aspect-ratio:1;}
.stk.word{font-size:13px;font-weight:800;color:#6E7A4E;aspect-ratio:auto;padding:10px 6px;line-height:1.3;grid-column:span 2;}
.stk:active{transform:scale(.92);}
.stk.img{padding:0;overflow:hidden;}
.stk.img img{width:100%;height:100%;object-fit:cover;border-radius:14px;}
.stk.add{flex-direction:column;gap:1px;color:#8BAA56;font-size:20px;font-weight:800;background:var(--green-soft);}
.stk.add span{font-size:9px;}
.sticker{font-size:62px;line-height:1.1;padding:2px 4px;}
.sticker.img{width:130px;height:auto;max-height:160px;border-radius:16px;display:block;}
.sticker.word{font-size:19px;font-weight:800;color:#fff;background:linear-gradient(135deg,#9CB67A,#8BAA56);padding:12px 18px;border-radius:18px;display:inline-block;box-shadow:0 4px 12px rgba(139,170,86,.3);}

/* call */
.call{flex:1;background:linear-gradient(160deg,#EAF0DC,#E2D9EE);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;}
.call-big{width:120px;height:120px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:62px;box-shadow:0 10px 30px rgba(0,0,0,.12);}
.call-nm{font-size:24px;font-weight:800;}
.call-st{font-size:14px;color:#7A766D;font-weight:600;}
.call-bar{display:flex;justify-content:center;gap:30px;padding:0 0 46px;background:linear-gradient(160deg,#E2D9EE,#E2D9EE);}
.cbtn{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(0,0,0,.12);}
.cbtn.end{background:#E36A66;}
.cbtn.mute{background:#B7AEC9;}
.cbtn.mute.on{background:#E36A66;}
