:root{--line-green:#06c755;--line-green-dark:#029946;--line-ink:#162114;--line-soft:#f6f8f2;--line-panel:rgba(255,255,255,0.78);--line-border:rgba(22,33,20,0.1);--line-muted:#5e6c5d;--line-highlight:#eefbda;--line-other:#ffffff;--line-self:#d9fdb9;--line-shadow:0 24px 60px rgba(17,41,15,0.12);--font-body:"Hiragino Maru Gothic ProN","Tsukushi A Round Gothic","BIZ UDPGothic","Yu Gothic",sans-serif;--font-mono:"SFMono-Regular","Menlo","Consolas","Monaco",monospace}*{box-sizing:border-box}body,html{margin:0;min-height:100%}body{font-family:var(--font-body),sans-serif;color:var(--line-ink);background:radial-gradient(circle at top left,rgba(6,199,85,.22),transparent 22%),radial-gradient(circle at top right,rgba(255,214,102,.16),transparent 18%),linear-gradient(180deg,#edf7e8,#f7f5ef 40%,#fdfcf7)}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}.landing-page,.page-shell{min-height:100vh;padding:32px 20px 64px}.landing-page{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,440px);grid-gap:28px;gap:28px;align-items:center;max-width:1240px;margin:0 auto}.chat-frame,.hero-card,.panel-card,.phone-card,.surface-card{border:1px solid var(--line-border);background:var(--line-panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--line-shadow)}.hero-card,.panel-card,.surface-card{border-radius:28px}.hero-card{padding:40px}.hero-tag{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background:rgba(6,199,85,.12);color:var(--line-green-dark);font-size:14px;font-weight:700}.hero-title{margin:18px 0 12px;font-size:clamp(42px,7vw,76px);line-height:.96;letter-spacing:-.06em}.hero-title span{color:var(--line-green-dark)}.hero-copy{max-width:40rem;color:var(--line-muted);font-size:18px;line-height:1.8}.composer-row,.hero-actions,.quick-links,.status-row,.tab-row,.toolbar-row{display:flex;flex-wrap:wrap;gap:12px}.ghost-button,.line-button,.pill,.tab-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:12px 18px;border:1px solid transparent;transition:transform .16s ease,background .16s ease,border-color .16s ease}.line-button{background:var(--line-green);color:white;font-weight:700}.ghost-button:hover,.line-button:hover,.tab-chip:hover{transform:translateY(-1px)}.ghost-button{background:rgba(255,255,255,.72)}.ghost-button,.tab-chip{border-color:var(--line-border)}.tab-chip{background:rgba(255,255,255,.66);color:var(--line-muted)}.tab-chip--active{background:var(--line-green);color:white}.phone-card{overflow:hidden;border-radius:34px}.phone-topbar{display:flex;justify-content:space-between;padding:18px 22px;background:linear-gradient(135deg,var(--line-green) 0,#18b560 100%);color:white;font-weight:700}.message-list,.notification-list,.phone-list,.resident-list,.thread-list,.timeline-list{display:grid;grid-gap:14px;gap:14px}.phone-body{padding:18px;background:linear-gradient(180deg,#edf7e8,#f7f4ec)}.notification-item,.preview-item,.resident-card,.thread-card,.timeline-item{border-radius:22px;border:1px solid rgba(17,41,15,.08);background:rgba(255,255,255,.86);padding:16px}.notification-item strong,.preview-item strong,.resident-card strong,.thread-card strong,.timeline-item strong{display:block;margin-bottom:4px;font-size:15px}.meta-line,.metric-label,.notification-meta,.preview-item small,.timeline-meta{color:var(--line-muted)}.page-shell{max-width:1240px;margin:0 auto}.surface-card{padding:26px}.page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.page-title{margin:0;font-size:clamp(26px,4vw,40px);line-height:1.08}.page-copy{margin:8px 0 0;color:var(--line-muted)}.grid-2{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.8fr);grid-gap:18px;gap:18px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px;gap:14px}.metric-card{padding:18px;border-radius:22px;border:1px solid var(--line-border);background:rgba(255,255,255,.78)}.metric-value{margin-top:12px;font-size:34px;font-weight:800;letter-spacing:-.04em}.line-layout{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);grid-gap:20px;gap:20px}.chat-frame{display:grid;grid-template-rows:auto 1fr auto;min-height:78vh;border-radius:34px;overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;background:linear-gradient(135deg,var(--line-green) 0,#18b560 100%);color:white}.chat-scroll{padding:24px 18px 28px;background:linear-gradient(180deg,rgba(242,247,232,.95),rgba(248,245,236,.97)),linear-gradient(120deg,rgba(6,199,85,.08),transparent 60%);overflow-y:auto}.message-group{display:flex;gap:10px;align-items:flex-end}.message-group--self{justify-content:flex-end}.avatar-dot{width:42px;height:42px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:rgba(6,199,85,.16);color:var(--line-green-dark);font-weight:800;flex-shrink:0}.message-stack{display:grid;grid-gap:6px;gap:6px;max-width:min(74%,560px)}.message-sender{font-size:13px;color:var(--line-muted);padding-left:8px}.bubble{border-radius:24px;padding:14px 16px;line-height:1.68;font-size:15px;box-shadow:0 12px 24px rgba(17,41,15,.08)}.bubble--other{background:var(--line-other);border-top-left-radius:10px}.bubble--self{background:var(--line-self);border-top-right-radius:10px}.message-time{color:var(--line-muted);font-size:12px;padding:0 8px}.composer{display:grid;grid-gap:10px;gap:10px;padding:16px;background:rgba(255,255,255,.84);border-top:1px solid var(--line-border)}.composer textarea,.field-input,.field-textarea{width:100%;border-radius:20px;border:1px solid rgba(17,41,15,.16);background:rgba(255,255,255,.9);padding:14px 16px;resize:vertical;min-height:52px}.field-textarea{min-height:120px}.notice-card{border-radius:18px;padding:12px 14px;background:rgba(255,244,204,.88);color:#7a5d00;border:1px solid rgba(122,93,0,.12)}.meta-line{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:13px}.session-card{display:grid;grid-gap:12px;gap:12px;padding:18px;border-radius:24px;background:linear-gradient(135deg,rgba(6,199,85,.1),rgba(255,255,255,.88));border:1px solid rgba(6,199,85,.14)}.chat-list-shell{max-width:760px;margin:0 auto;display:grid;grid-gap:18px;gap:18px}.chat-list-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.chat-list-surface{border:1px solid var(--line-border);background:rgba(255,255,255,.88);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--line-shadow);border-radius:28px;overflow:hidden}.chat-list-row{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:14px;gap:14px;padding:18px 20px;border-bottom:1px solid rgba(22,33,20,.08)}.chat-list-row:last-child{border-bottom:0}.chat-list-avatar{width:50px;height:50px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(6,199,85,.18),rgba(255,255,255,.95));color:var(--line-green-dark);font-weight:800;flex-shrink:0}.chat-list-main{min-width:0;display:grid;grid-gap:8px;gap:8px}.chat-list-bottomline,.chat-list-topline{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-list-topline strong{min-width:0;font-size:16px}.chat-list-bottomline p{margin:0;min-width:0;overflow:hidden;text-overflow:ellipsis}.chat-list-bottomline p,.chat-list-time{color:var(--line-muted);white-space:nowrap}.chat-list-time{font-size:12px}.chat-list-status{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.chat-list-badge,.chat-list-chip{display:inline-flex;align-items:center;justify-content:center;min-width:24px;min-height:24px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700}.chat-list-chip{color:var(--line-green-dark);background:rgba(6,199,85,.12)}.chat-list-badge{color:white;background:var(--line-green)}.auth-card{max-width:520px;margin:40px auto}.auth-form,.settings-form{display:grid;grid-gap:14px;gap:14px}.stack{display:grid;grid-gap:18px;gap:18px}.mono{font-family:var(--font-mono),monospace}.empty{padding:18px;border-radius:20px;border:1px dashed rgba(17,41,15,.16);color:var(--line-muted);text-align:center}.page-shell--chat{display:flex;justify-content:center}.line-phone{width:min(100%,440px);min-height:calc(100vh - 96px);display:grid;grid-template-rows:auto auto 1fr;border-radius:34px;overflow:hidden;border:1px solid rgba(17,41,15,.1);background:rgba(255,255,255,.95);box-shadow:0 28px 60px rgba(17,41,15,.14)}.line-phone--thread{grid-template-rows:auto auto auto 1fr auto}.line-screen-head,.line-thread-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 16px 14px;background:rgba(255,255,255,.94);border-bottom:1px solid rgba(17,41,15,.08)}.line-screen-kicker{margin:0 0 6px;font-size:12px;color:var(--line-muted)}.line-screen-title{margin:0;font-size:32px;line-height:1;letter-spacing:-.04em}.line-header-actions{display:flex;align-items:center;gap:8px}.line-composer-icon,.line-icon-button,.line-send-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:0}.line-composer-icon,.line-icon-button{background:rgba(17,41,15,.06);color:var(--line-ink)}.line-icon-button--ghost{background:transparent}.line-composer-icon svg,.line-icon-button svg,.line-send-button svg{width:20px;height:20px}.line-summary-strip{padding:0 16px 14px;display:grid;grid-gap:10px;gap:10px;background:rgba(255,255,255,.94)}.line-summary-strip--compact{padding-top:12px;padding-bottom:0}.line-overview-card{padding:14px;border-radius:22px;background:linear-gradient(135deg,rgba(6,199,85,.12),rgba(255,255,255,.94)),rgba(255,255,255,.8);border:1px solid rgba(6,199,85,.12)}.line-overview-card strong{display:block;font-size:16px}.line-overview-card p{margin:8px 0 0;color:var(--line-muted);line-height:1.6;font-size:13px}.line-mini-pill-row,.line-talk-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.line-mini-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 12px;border-radius:999px;background:rgba(17,41,15,.06);color:var(--line-muted);font-size:12px;font-weight:700;margin-top:12px}.line-mini-pill--accent{background:rgba(6,199,85,.12);color:var(--line-green-dark)}.line-talk-list{overflow-y:auto;background:#fff}.line-talk-row{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:12px;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(17,41,15,.06);transition:background .14s ease}.line-talk-row:active,.line-talk-row:hover{background:rgba(17,41,15,.03)}.line-talk-avatar{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;border-radius:18px;color:white;font-size:18px;font-weight:800;flex-shrink:0}.line-talk-body{min-width:0;display:grid;grid-gap:6px;gap:6px}.line-talk-bottomline,.line-talk-topline{display:flex;align-items:center;justify-content:space-between;gap:10px}.line-talk-topline strong{min-width:0;font-size:16px}.line-talk-time{color:var(--line-muted);font-size:12px;white-space:nowrap}.line-talk-bottomline p{margin:0;min-width:0;color:#60685d;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-chat-chip,.line-talk-badge{display:inline-flex;align-items:center;justify-content:center;min-height:22px;padding:0 10px;border-radius:999px;font-size:11px;font-weight:700}.line-chat-chip{background:rgba(6,199,85,.12);color:var(--line-green-dark)}.line-talk-badge{min-width:22px;background:var(--line-green);color:white}.line-thread-head{padding-block:10px}.line-thread-title-block{min-width:0;flex:1 1;text-align:center}.line-thread-title-block span,.line-thread-title-block strong{display:block}.line-thread-title-block strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:16px}.line-thread-title-block span{margin-top:2px;color:var(--line-muted);font-size:12px}.line-thread-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:rgba(6,199,85,.08);color:var(--line-green-dark);font-size:12px;font-weight:700}.line-message-scroll{overflow-y:auto;padding:14px;background:radial-gradient(circle at top,rgba(6,199,85,.08),transparent 24%),linear-gradient(180deg,#eef3e8,#f5f3ec)}.line-date-divider{display:flex;justify-content:center;margin:10px 0 16px}.line-date-divider span{padding:4px 12px;border-radius:999px;background:rgba(17,41,15,.08);color:var(--line-muted);font-size:12px}.line-message-group{display:flex;align-items:flex-end;gap:8px;margin-bottom:16px}.line-message-group--self{justify-content:flex-end}.line-message-avatar{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:white;font-size:13px;font-weight:800;flex-shrink:0}.line-message-stack{display:grid;grid-gap:4px;gap:4px;max-width:78%}.line-message-name{padding-left:8px;color:var(--line-muted);font-size:12px}.line-message-bubble{padding:12px 14px;border-radius:20px;line-height:1.6;font-size:14px;box-shadow:0 10px 20px rgba(17,41,15,.08)}.line-message-bubble--other{background:white;border-top-left-radius:8px}.line-message-bubble--self{background:#d7f8c5;border-top-right-radius:8px}.line-message-meta{display:flex;justify-content:flex-end;gap:6px;padding:0 4px;color:var(--line-muted);font-size:11px}.line-read-state{color:var(--line-green-dark);font-weight:700}.line-composer{display:grid;grid-gap:8px;gap:8px;padding:10px 12px 14px;background:rgba(255,255,255,.96);border-top:1px solid rgba(17,41,15,.08)}.line-inline-notice{padding:10px 12px;border-radius:16px;background:rgba(255,244,204,.82);color:#7a5d00;font-size:12px}.line-composer-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;grid-gap:8px;gap:8px;align-items:center}.line-composer-icon:disabled{opacity:.5;cursor:default}.line-composer-input{width:100%;height:42px;padding:0 14px;border-radius:999px;border:1px solid rgba(17,41,15,.12);background:white;min-width:0}.line-composer-input:disabled{background:rgba(17,41,15,.04)}.line-send-button{background:var(--line-green);color:white}.line-send-button:disabled{background:rgba(6,199,85,.34);cursor:default}.line-empty{padding:36px 18px;color:var(--line-muted);text-align:center}@media (max-width:960px){.grid-2,.grid-3,.landing-page,.line-layout{grid-template-columns:1fr}.chat-frame{min-height:72vh}}@media (max-width:720px){.landing-page,.page-shell{padding-inline:14px}.hero-card,.surface-card{padding:22px}.chat-list-row{padding-inline:14px}.message-stack{max-width:88%}.page-shell--chat{padding:0}.line-phone{width:100%;min-height:100vh;border-radius:0;border-inline:0;box-shadow:none}.line-composer,.line-message-scroll,.line-screen-head,.line-summary-strip,.line-thread-banner,.line-thread-head{padding-inline:14px}.line-thread-banner{padding-block:10px}.line-message-stack{max-width:84%}}.mockup-page{min-height:100dvh;background-color:#f8f8f8}.mockup-frame{--mockup-max-width:430px;position:relative;width:min(100%,var(--mockup-max-width));max-width:var(--mockup-max-width);height:100dvh;margin:0 auto;background-color:#f8f8f8;overflow:hidden}.mockup-frame--wide{width:100%;max-width:none}.mockup-ui,.mockup-ui *{box-sizing:border-box}.mockup-ui{position:relative;height:100%;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Hiragino Sans,Hiragino Kaku Gothic ProN,メイリオ,Meiryo,sans-serif;-webkit-font-smoothing:antialiased}.mockup-ui a{color:inherit;text-decoration:none}.mockup-ui .screen{display:flex;flex-direction:column;background-color:#fff}.mockup-ui .screen--with-nav{height:calc(100% - 60px)}.mockup-ui .screen--full{height:100%}.mockup-ui .screen-header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;min-height:56px}.mockup-ui .screen-header h1{margin:0;font-size:20px;font-weight:600;color:#000}.mockup-ui .header-icons{display:flex;gap:20px}.mockup-ui .back-button,.mockup-ui .header-menu-button,.mockup-ui .icon-plain-button,.mockup-ui .input-icon-button,.mockup-ui .nav-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;padding:0}.mockup-ui .icon-plain-button{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;color:#000;cursor:pointer}.mockup-ui .back-button svg,.mockup-ui .header-menu-button svg,.mockup-ui .icon-plain-button svg,.mockup-ui .input-icon-button svg,.mockup-ui .nav-item svg,.mockup-ui .send-button svg{width:22px;height:22px;fill:currentColor}.mockup-ui .talk-list{flex:1 1;overflow-y:auto;background-color:#fff}.mockup-ui .talk-item{display:flex;padding:12px 16px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s}.mockup-ui .talk-item:active{background-color:#f5f5f5}.mockup-ui .talk-avatar{width:50px;height:50px;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-right:12px;flex-shrink:0}.mockup-ui .avatar-photo{width:100%;height:100%;object-fit:cover;display:block}.mockup-ui .avatar-text{color:#fff;font-size:18px;font-weight:600}.mockup-ui .talk-content{flex:1 1;min-width:0}.mockup-ui .talk-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;gap:8px}.mockup-ui .talk-name{font-size:16px;font-weight:600;color:#000;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mockup-ui .talk-time{font-size:12px;color:#999;flex-shrink:0}.mockup-ui .talk-preview{display:flex;justify-content:space-between;align-items:center;gap:8px}.mockup-ui .talk-message{margin:0;font-size:14px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1}.mockup-ui .unread-badge{background-color:#06c755;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;flex-shrink:0}.mockup-ui .message-header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:12px 16px;display:flex;align-items:center;gap:10px;min-height:56px}.mockup-ui .message-header-avatar{width:34px;height:34px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mockup-ui .message-header-avatar span{color:#fff;font-size:13px;font-weight:600}.mockup-ui .back-button,.mockup-ui .header-menu-button{font-size:20px;color:#000;cursor:pointer;padding:8px}.mockup-ui .back-button{margin-left:-8px}.mockup-ui .header-menu-button{margin-right:-8px}.mockup-ui .header-menu-spacer{width:36px;flex-shrink:0}.mockup-ui .message-header-info{flex:1 1;text-align:center;min-width:0}.mockup-ui .header-name{display:block;font-size:16px;font-weight:600;color:#000;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mockup-ui .header-members{display:block;font-size:12px;color:#999;margin-top:2px;min-height:16px}.mockup-ui .message-container{flex:1 1;overflow-y:auto;padding:16px;background-color:#f8f8f8}.mockup-ui .date-divider{text-align:center;margin:16px 0}.mockup-ui .date-divider span{background-color:rgba(0,0,0,.05);color:#666;font-size:12px;padding:4px 12px;border-radius:12px}.mockup-ui .message-group{display:flex;margin-bottom:16px;align-items:flex-start}.mockup-ui .message-group.other{flex-direction:row}.mockup-ui .message-group.self{flex-direction:row-reverse}.mockup-ui .message-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-right:8px;flex-shrink:0}.mockup-ui .message-group.self .message-avatar{margin-right:0;margin-left:8px}.mockup-ui .message-avatar span{color:#fff;font-size:14px;font-weight:600}.mockup-ui .message-content{max-width:70%}.mockup-ui .message-name{font-size:12px;color:#666;margin-bottom:4px;padding-left:12px}.mockup-ui .message-bubble{background-color:#fff;padding:10px 14px;border-radius:18px;font-size:15px;line-height:1.5;color:#000;word-wrap:break-word;box-shadow:0 1px 2px rgba(0,0,0,.05)}.mockup-ui .message-group.self .message-bubble{background-color:#06c755;color:#fff}.mockup-ui .message-time{font-size:11px;color:#999;margin-top:4px;padding-left:12px;display:flex;align-items:center;gap:4px}.mockup-ui .message-group.self .message-time{text-align:right;padding-right:12px;padding-left:0;justify-content:flex-end}.mockup-ui .read-status{font-size:11px;color:#999;font-weight:500}.mockup-ui .message-input-container{background-color:#fff;border-top:1px solid #e0e0e0;padding:8px 12px;display:grid;grid-gap:8px;gap:8px}.mockup-ui .message-input-row{display:flex;align-items:center;gap:8px}.mockup-ui .input-icon-button{font-size:24px;color:#666;cursor:pointer;padding:8px;display:inline-flex;align-items:center;justify-content:center}.mockup-ui .message-input{flex:1 1;border:1px solid #e0e0e0;border-radius:20px;padding:10px 16px;font-size:15px;outline:none;font-family:inherit}.mockup-ui .message-input:disabled{background-color:#f4f4f4}.mockup-ui .send-button{background-color:#06c755;border:none;color:#fff;font-size:18px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mockup-ui .send-button:disabled{background-color:#9edeb7;cursor:default}.mockup-ui .bottom-nav{position:absolute;bottom:0;left:0;right:0;height:60px;background-color:#fff;border-top:1px solid #e0e0e0;display:flex;justify-content:space-around;align-items:center;z-index:1000}.mockup-ui .nav-item{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;padding:8px;position:relative;transition:color .2s;color:#999;min-height:60px}.mockup-ui .nav-item svg{font-size:24px;margin-bottom:4px}.mockup-ui .nav-item span{font-size:11px}.mockup-ui .nav-item.active{color:#06c755}.mockup-ui .nav-badge{position:absolute;top:4px;right:calc(50% - 20px);background-color:#ff3b30;color:#fff;font-size:10px;font-weight:600;padding:2px 5px;border-radius:10px;min-width:16px;text-align:center}.mockup-ui .settings-container{flex:1 1;overflow-y:auto;background-color:#f8f8f8;padding-bottom:20px}.mockup-ui .profile-section{background-color:#fff;padding:24px 16px;display:flex;align-items:center;border-bottom:1px solid #e0e0e0;margin-bottom:12px}.mockup-ui .profile-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);display:inline-flex;align-items:center;justify-content:center;margin-right:16px;color:#fff;flex-shrink:0}.mockup-ui .profile-avatar svg{width:28px;height:28px;fill:currentColor}.mockup-ui .profile-avatar--settings{background:linear-gradient(135deg,#06c755,#00b548)}.mockup-ui .avatar-text.large{font-size:28px}.mockup-ui .profile-info{flex:1 1;min-width:0}.mockup-ui .profile-name{font-size:18px;font-weight:600;color:#000;margin-bottom:4px}.mockup-ui .profile-id{font-size:13px;color:#999;overflow-wrap:anywhere}.mockup-ui .settings-group{background-color:#fff;margin-bottom:12px}.mockup-ui .mockup-form-group{padding:16px;display:grid;grid-gap:14px;gap:14px}.mockup-ui .mockup-field{display:grid;grid-gap:8px;gap:8px}.mockup-ui .mockup-field-label{font-size:13px;color:#666}.mockup-ui .mockup-input,.mockup-ui .mockup-textarea{width:100%;border:1px solid #e0e0e0;border-radius:16px;padding:12px 14px;font-size:15px;font-family:inherit;background-color:#fff;outline:none}.mockup-ui .mockup-textarea{resize:vertical;min-height:120px}.mockup-ui .mockup-helper-text{margin:-2px 0 0;font-size:12px;line-height:1.5;color:#999}.mockup-ui .mockup-primary-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;min-height:46px;border-radius:23px;background-color:#06c755;color:#fff;font-size:15px;font-weight:600;cursor:pointer}.mockup-ui .mockup-primary-button:disabled{background-color:#9edeb7;cursor:default}.mockup-ui .mockup-input-notice,.mockup-ui .mockup-status-bar{background-color:#fff7d8;color:#7a5d00;font-size:12px;line-height:1.4}.mockup-ui .mockup-status-bar{padding:10px 16px;border-bottom:1px solid #f1e2a8}.mockup-ui .mockup-input-notice{padding:8px 12px;border-radius:12px}.mockup-ui .mockup-empty{padding:24px 16px;color:#999;font-size:14px;text-align:center}.mockup-ui .mockup-menu-overlay{position:absolute;inset:0;z-index:1200}.mockup-ui .mockup-menu-overlay:before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.08)}.mockup-ui .mockup-menu-panel{position:absolute;top:56px;right:12px;width:180px;background:#fff;border-radius:14px;box-shadow:0 10px 24px rgba(0,0,0,.14);overflow:hidden}.mockup-ui .mockup-menu-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;border:0;background:#fff;padding:14px 16px;text-align:left;font-size:14px;color:#000;cursor:pointer}.mockup-ui .mockup-menu-item+.mockup-menu-item{border-top:1px solid #f0f0f0}.mockup-ui .mockup-menu-item--danger{color:#d93025}.mockup-ui .admin-screen-header{align-items:center}.mockup-ui .admin-layout{display:grid;grid-template-columns:240px minmax(0,1fr);height:100%;min-height:0}.mockup-ui .admin-sidebar{background:#f7f8f9;border-right:1px solid #e6e8eb;padding:22px 16px;display:grid;align-content:start;grid-gap:16px;gap:16px;min-height:0;overflow-y:auto}.mockup-ui .admin-sidebar-brand{display:grid;grid-gap:4px;gap:4px;padding:4px 6px 8px}.mockup-ui .admin-sidebar-brand span{font-size:11px;letter-spacing:.08em;color:#7b8087}.mockup-ui .admin-sidebar-brand strong{font-size:20px;color:#111}.mockup-ui .admin-sidebar-stats{display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-sidebar-nav{display:grid;grid-gap:8px;gap:8px}.mockup-ui .admin-sidebar-link{display:inline-flex;align-items:center;min-height:44px;padding:0 14px;border-radius:14px;color:#4b5560;font-size:14px;font-weight:600;transition:background-color .16s ease,color .16s ease}.mockup-ui .admin-sidebar-link:hover{background:#eceff1}.mockup-ui .admin-sidebar-link.active{background:#111;color:#fff}.mockup-ui .admin-sidebar-logout{margin-top:auto}.mockup-ui .admin-main{min-width:0;min-height:0;display:flex;flex-direction:column}.mockup-ui .admin-screen-heading{display:flex;flex-direction:column;gap:10px}.mockup-ui .admin-header-actions{display:flex;align-items:center;gap:10px}.mockup-ui .admin-back-link{display:inline-flex;align-items:center;font-size:12px;font-weight:600;color:#5f6368}.mockup-ui .admin-header-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:#f1f3f5;color:#222;padding:10px 14px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer}.mockup-ui .admin-console-toolbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px;padding:12px 16px;background:#fff;border-bottom:1px solid #ececec}.mockup-ui .admin-summary-pill{border-radius:16px;background:#f6f7f8;padding:12px;display:flex;flex-direction:column;gap:2px}.mockup-ui .admin-summary-pill strong{font-size:18px;color:#111}.mockup-ui .admin-summary-pill span{font-size:11px;color:#777}.mockup-ui .admin-tab-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:8px;gap:8px;padding:12px 16px;background:#fff;border-bottom:1px solid #ececec}.mockup-ui .admin-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:#f1f3f5;color:#666;border-radius:999px;padding:10px 12px;font-size:13px;font-weight:600;cursor:pointer}.mockup-ui .admin-tab.active{background:#06c755;color:#fff}.mockup-ui .admin-console-scroll{flex:1 1;min-height:0;overflow-y:auto;background:#f5f5f5;padding:14px}.mockup-ui .admin-panel,.mockup-ui .admin-section-stack{display:grid;grid-gap:14px;gap:14px}.mockup-ui .admin-panel{background:#fff;border-radius:20px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.04)}.mockup-ui .admin-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.mockup-ui .admin-panel-header h2{margin:0;font-size:17px;color:#111}.mockup-ui .admin-panel-header p{margin:4px 0 0;font-size:12px;color:#777;line-height:1.5}.mockup-ui .admin-list-header{display:flex;align-items:center;justify-content:space-between;gap:14px}.mockup-ui .admin-list-header h2{margin:0;font-size:18px;color:#111}.mockup-ui .admin-list-header p{margin:4px 0 0;font-size:12px;color:#777}.mockup-ui .admin-list-grid{display:grid;grid-gap:12px;gap:12px}.mockup-ui .admin-list-card{display:grid;grid-gap:10px;gap:10px;background:#f8f8f8;border:1px solid #ececec;border-radius:18px;padding:16px;transition:background-color .16s ease,border-color .16s ease}.mockup-ui .admin-list-card:hover{background:#f1fff6;border-color:#ccefd8}.mockup-ui .admin-list-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.mockup-ui .admin-list-card-header strong{font-size:16px;color:#111}.mockup-ui .admin-list-card p{margin:0;font-size:13px;color:#555;line-height:1.5}.mockup-ui .admin-list-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:#777}.mockup-ui .admin-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.mockup-ui .admin-preview-card{display:grid;grid-gap:12px;gap:12px;border:1px solid #ececec;border-radius:18px;background:#fafafa;padding:14px}.mockup-ui .admin-preview-card h3{margin:0;font-size:14px;color:#111}.mockup-ui .admin-preview-summary{margin:0;font-size:13px;color:#555;line-height:1.6}.mockup-ui .admin-metadata-list{margin:0;display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-metadata-list div{display:grid;grid-gap:3px;gap:3px}.mockup-ui .admin-metadata-list dt{font-size:11px;letter-spacing:.04em;color:#888;text-transform:uppercase}.mockup-ui .admin-metadata-list dd{margin:0;font-size:13px;color:#111;word-break:break-word}.mockup-ui .admin-diff-list{display:grid;grid-gap:10px;gap:10px;max-height:420px;overflow-y:auto}.mockup-ui .admin-diff-item{display:grid;grid-gap:6px;gap:6px;border-top:1px solid #ececec;padding-top:10px}.mockup-ui .admin-diff-item:first-child,.mockup-ui .admin-history-item:first-child{border-top:0;padding-top:0}.mockup-ui .admin-diff-item strong,.mockup-ui .admin-history-item strong{font-size:12px;color:#111}.mockup-ui .admin-diff-item span,.mockup-ui .admin-history-item span{display:block;font-size:12px;color:#666;white-space:pre-wrap;word-break:break-word}.mockup-ui .admin-history-list{display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-history-item{display:grid;grid-gap:4px;gap:4px;border-top:1px solid #ececec;padding-top:10px}.mockup-ui .admin-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#eef7f0;color:#179b48;font-size:11px;font-weight:600;padding:6px 10px;white-space:nowrap}.mockup-ui .admin-chip--muted{background:#f1f3f5;color:#666}.mockup-ui .admin-chip--warning{background:#fff2e8;color:#c45d12}.mockup-ui .admin-chip-row,.mockup-ui .admin-derivation-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.mockup-ui .admin-derivation-code{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:11px;color:#666;word-break:break-all}.mockup-ui .admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.mockup-ui .admin-span-full{grid-column:1/-1}.mockup-ui .admin-codearea{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;line-height:1.5}.mockup-ui .admin-room-member-list{display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-room-member{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border-radius:14px;background:#f7f7f7}.mockup-ui .admin-room-member-body{flex:1 1;min-width:0;display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-room-member-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.mockup-ui .admin-room-member strong{display:block;font-size:14px;color:#111}.mockup-ui .admin-room-member p{margin:4px 0 0;font-size:12px;color:#777}.mockup-ui .admin-room-member-summary{margin:0;font-size:12px;line-height:1.6;color:#5a5f65}.mockup-ui .admin-member-badge{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,#ffc3a0,#ffafbd);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.mockup-ui .admin-member-badge--player{background:linear-gradient(135deg,#06c755,#00b548);font-size:11px}.mockup-ui .admin-room-add,.mockup-ui .admin-user-actions{display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-room-metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.mockup-ui .admin-room-metric-grid--wide{grid-template-columns:repeat(4,minmax(0,1fr))}.mockup-ui .admin-room-metric-card{display:grid;grid-gap:6px;gap:6px;padding:12px;border-radius:14px;background:#f4f6f8;border:1px solid #ebedf0}.mockup-ui .admin-room-metric-card em,.mockup-ui .admin-room-metric-card span{font-size:12px;color:#68707a;font-style:normal}.mockup-ui .admin-room-metric-card strong{font-size:22px;line-height:1;color:#111}.mockup-ui .admin-debug-card-note{margin:0;font-size:12px;line-height:1.6;color:#68707a}.mockup-ui .admin-detail-note-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.mockup-ui .admin-detail-note,.mockup-ui .admin-report-block{display:grid;grid-gap:8px;gap:8px;padding:14px;border-radius:14px;background:#f8f9fb;border:1px solid #eceff3}.mockup-ui .admin-detail-note strong,.mockup-ui .admin-report-block h3{margin:0;font-size:13px;color:#1f2937}.mockup-ui .admin-detail-note p,.mockup-ui .admin-report-block p{margin:0;font-size:13px;line-height:1.7;color:#59616c}.mockup-ui .admin-relationship-bars{display:grid;grid-gap:12px;gap:12px}.mockup-ui .admin-relationship-bar-row{display:grid;grid-gap:6px;gap:6px}.mockup-ui .admin-relationship-bar-labels{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;color:#4b5563}.mockup-ui .admin-relationship-bar-labels strong{color:#111}.mockup-ui .admin-relationship-bar-track{width:100%;height:10px;border-radius:999px;background:#eef1f4;overflow:hidden}.mockup-ui .admin-relationship-bar-fill{height:100%;border-radius:inherit}.mockup-ui .admin-relationship-bar-fill--positive{background:linear-gradient(90deg,#06c755,#52d98d)}.mockup-ui .admin-relationship-bar-fill--negative{background:linear-gradient(90deg,#f59e0b,#f97316)}.mockup-ui .admin-relationship-bar-fill--neutral{background:linear-gradient(90deg,#64748b,#94a3b8)}.mockup-ui .admin-trend-panel{display:grid;grid-gap:14px;gap:14px}.mockup-ui .admin-trend-legend{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:#55606d}.mockup-ui .admin-trend-legend span{display:inline-flex;align-items:center;gap:6px}.mockup-ui .admin-trend-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.mockup-ui .admin-trend-dot--visible{background:#06c755}.mockup-ui .admin-trend-dot--hidden{background:#0f766e}.mockup-ui .admin-trend-chart{width:100%;height:auto;border-radius:16px;background:linear-gradient(180deg,#fbfcfd,#f3f6f9);border:1px solid #e6eaef}.mockup-ui .admin-trend-grid{stroke:#dfe5eb;stroke-width:1}.mockup-ui .admin-trend-line{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.mockup-ui .admin-trend-line--visible{stroke:#06c755}.mockup-ui .admin-trend-line--hidden{stroke:#0f766e}.mockup-ui .admin-memory-day-list,.mockup-ui .admin-memory-topic-list{display:grid;grid-gap:12px;gap:12px}.mockup-ui .admin-memory-day,.mockup-ui .admin-memory-topic{border:1px solid #e6eaef;border-radius:16px;background:#fbfcfd;overflow:hidden}.mockup-ui .admin-memory-day-summary,.mockup-ui .admin-memory-topic-summary{list-style:none;cursor:pointer;display:grid;grid-gap:8px;gap:8px;padding:14px 16px}.mockup-ui .admin-memory-day-summary::-webkit-details-marker,.mockup-ui .admin-memory-topic-summary::-webkit-details-marker{display:none}.mockup-ui .admin-memory-day-summary strong,.mockup-ui .admin-memory-topic-summary strong{display:block;font-size:14px;color:#111827}.mockup-ui .admin-memory-day-summary span,.mockup-ui .admin-memory-topic-summary span{font-size:12px;color:#66707d}.mockup-ui .admin-memory-day-summary p{margin:0;font-size:13px;line-height:1.6;color:#59616c}.mockup-ui .admin-memory-topic-body{display:grid;grid-gap:12px;gap:12px;padding:0 16px 16px}.mockup-ui .admin-memory-topic-body>p{margin:0;font-size:13px;line-height:1.7;color:#475467}.mockup-ui .admin-memory-subgrid{grid-template-columns:repeat(2,minmax(0,1fr))}.mockup-ui .admin-memory-subgrid,.mockup-ui .admin-memory-toolbar{display:grid;grid-gap:12px;gap:12px}.mockup-ui .admin-memory-toolbar-fields{display:grid;grid-template-columns:minmax(0,2fr) minmax(220px,1fr);grid-gap:12px;gap:12px}.mockup-ui .admin-memory-day-grid{padding:0 12px 12px}.mockup-ui .admin-debug-axis-grid,.mockup-ui .admin-debug-signal-grid,.mockup-ui .admin-memory-day-grid{display:grid;grid-gap:12px;gap:12px}.mockup-ui .admin-debug-signal-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.mockup-ui .admin-debug-axis-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mockup-ui .admin-debug-contribution-list{display:grid;grid-gap:8px;gap:8px}@media (max-width:720px){.mockup-ui .admin-debug-axis-grid,.mockup-ui .admin-debug-signal-grid,.mockup-ui .admin-memory-subgrid,.mockup-ui .admin-memory-toolbar-fields{grid-template-columns:1fr}}.mockup-ui .admin-trend-label{font-size:11px;fill:#6b7280}.mockup-ui .admin-report-grid,.mockup-ui .admin-trend-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.mockup-ui .admin-trend-summary-card{display:grid;grid-gap:4px;gap:4px;padding:10px 12px;border-radius:12px;background:#f8fafb;border:1px solid #ecf0f2}.mockup-ui .admin-trend-summary-card strong{font-size:12px;color:#111827}.mockup-ui .admin-trend-summary-card span{font-size:12px;color:#667085}.mockup-ui .admin-report{display:grid;grid-gap:12px;gap:12px}.mockup-ui .admin-report-block ul{margin:0;padding-left:18px;display:grid;grid-gap:6px;gap:6px;color:#5b6470;font-size:13px;line-height:1.6}.mockup-ui .admin-user-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.mockup-ui .admin-user-note{font-size:12px;color:#777}.mockup-ui .admin-inline-link{color:#06c755;font-weight:600}.mockup-ui .admin-switch{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#555}.mockup-ui .asset-field{display:grid;grid-gap:10px;gap:10px}.mockup-ui .asset-field-header{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12px;font-weight:600;color:#444}.mockup-ui .asset-field-helper{font-size:11px;color:#8a8f96;font-weight:500}.mockup-ui .asset-field-body{display:grid;grid-template-columns:108px minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center}.mockup-ui .asset-field-preview{width:108px;height:108px;border-radius:18px;border:1px dashed #d5d9dd;background:#f6f7f8;display:flex;align-items:center;justify-content:center;color:#868b92;font-size:12px;overflow:hidden}.mockup-ui .asset-field-image{width:100%;height:100%;object-fit:cover}.mockup-ui .asset-field-actions{display:grid;grid-gap:10px;gap:10px}.mockup-ui .admin-asset-preview{width:100%;aspect-ratio:1/1;border-radius:16px;overflow:hidden;background:#eef1f3}.mockup-ui .admin-asset-image{width:100%;height:100%;object-fit:cover}.mockup-ui .admin-flash{background:#eefaf1;color:#12733a;border-bottom-color:#d5efdc}.mockup-ui .admin-error{background:#fff2f0;color:#b42318;border-bottom-color:#ffd0cb}.mockup-ui .admin-empty-inline{min-height:0;padding:24px 0}.admin-modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.32);display:flex;align-items:center;justify-content:center;padding:24px;z-index:100}.admin-modal-panel{width:min(720px,100%);max-height:min(88dvh,920px);overflow:auto;background:#fff;border-radius:28px;box-shadow:0 24px 60px rgba(15,23,42,.2)}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 24px 0}.admin-modal-header h2{margin:0;font-size:20px;color:#111}.admin-modal-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:#f1f3f5;color:#444;border-radius:999px;padding:10px 14px;font-size:12px;font-weight:600;cursor:pointer}.admin-modal-body{padding:20px 24px 24px}@media (max-width:520px){.mockup-ui .admin-layout{grid-template-columns:minmax(0,1fr)}.mockup-ui .admin-sidebar{border-right:0;border-bottom:1px solid #e6e8eb}.mockup-ui .admin-sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.mockup-ui .admin-detail-note-grid,.mockup-ui .admin-form-grid,.mockup-ui .admin-report-grid,.mockup-ui .admin-room-metric-grid,.mockup-ui .admin-room-metric-grid--wide,.mockup-ui .admin-trend-summary-grid,.mockup-ui .admin-user-grid{grid-template-columns:minmax(0,1fr)}.mockup-ui .admin-list-header,.mockup-ui .admin-screen-header{align-items:flex-start;flex-direction:column}.mockup-ui .admin-preview-grid{grid-template-columns:minmax(0,1fr)}.mockup-ui .admin-header-actions,.mockup-ui .admin-list-meta{width:100%}.mockup-ui .asset-field-body{grid-template-columns:minmax(0,1fr)}}.mockup-ui ::-webkit-scrollbar{width:6px}.mockup-ui ::-webkit-scrollbar-track{background:transparent}.mockup-ui ::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:3px}.mockup-ui ::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3)}@media (min-width:431px){.mockup-frame{box-shadow:0 12px 32px rgba(0,0,0,.12)}}